使用平行轴图显示鸢尾花(iris)的四个特征数据(创新实验室联合纳新测试题)

本文主要是介绍使用平行轴图显示鸢尾花(iris)的四个特征数据(创新实验室联合纳新测试题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

也是扯淡,创新实验室纳个新还要出题考试。

出题就出题吧,还出得这么难。

再难也得做啊。。。

先上题:

1.数学建模
1)使用平行轴图显示鸢尾花(iris)的四个特征数据;
2)尝试使用其他方法优化呈现(可文字叙述,选作);

。。。。。。。


啥是鸢尾花

Iris数据集是常用的分类实验数据集,由Fisher, 1936收集整理。

iris以鸢尾花的特征作为数据来源,常用在分类操作中。该数据集由3种不同类型的鸢尾花的50个样本数据构成。其中的一个种类与另外两个种类是线性可分离的,后两个种类是非线性可分离的。
该数据集包含了5个属性:
& Sepal.Length(花萼长度),单位是cm;
& Sepal.Width(花萼宽度),单位是cm;
& Petal.Length(花瓣长度),单位是cm;
& Petal.Width(花瓣宽度),单位是cm;
& 种类:Iris Setosa(山鸢尾)、Iris Versicolour(杂色鸢尾),以及Iris Virginica(维吉尼亚鸢尾)。

我也是醉了。。。

这玩意上哪儿找啊?难不成matlab自带?



too young...


只好下载了一个,2k的文件居然还要我1积分,真是世风日下,人心不古啊。。。





下载下来打开看看:



这堆东西是个啥?arrf又是啥?

我去。。。我的第一个stackoverflow居然就献给这个东西了。。。

http://stackoverflow.com/questions/6952315/how-to-load-arff-format-file-to-matlab

Is there any package to load .arff format file into matlab?The .arff format is used in Weka for running machine learning algorithm.

Yes, there are a few MATLAB interfaces for WEKA files on MATLAB File Exchange, I normally use this one: http://www.mathworks.com/matlabcentral/fileexchange/21204-matlab-weka-interface where you have a saveARFF() and a loadARFF() functions.

 
any examples on how it is used? –  mike_x_ Oct 4 '14 at 15:01
 
If you unzip the fileexchange files into your working directory you can use loadARFF in this way: data = loadARFF('myfile.arf'). –  Matteo De Felice Oct 6 '14 at 7:14
 
I get an error but i ll check again. I have unzipped it and added the folder with subfolders in the path, by clicking the button "set path". Is it correct? Do i have to do anything else so as to import the toolkit?


把这个下载下来看看:

http://www.mathworks.com/matlabcentral/fileexchange/21204-matlab-weka-interface





嗯,看着挺靠谱的。

添加路径:







Error: File: loadARFF.m Line: 9 Column: 12
Arguments to IMPORT must either end with ".*" or else specify a fully qualified class name:
"weka.core.converters.ArffLoader" fails this test.

。。。。。。。

还得下这个开发环境。。。

http://www.cs.waikato.ac.nz/ml/weka/downloading.html

我的java版本不够,果断下载第一个。





安装完之后还报错。。。。。。。

受 saber大牛文章指教:

http://blog.csdn.net/xywlpo/article/details/6531025

——————————————————————————————————————

不要以为下载下来就能用,你会在如下地方报错:

if(~wekaPathCheck),wekaOBJ = []; return,end

import weka.core.converters.ArffLoader;

import java.io.File;

Tricky的事情就是得把weka.jar加入到matlab的classpath.txt列表。classpath.txt在哪儿?到matlab的command窗口敲:

>> which classpath.txt

/Applications/MATLAB_R2010b.app/toolbox/local/classpath.txt

这个是在mac下的结果,windows估计也有类似的文件结构。然后就是到classpath.txt里加入一行,weka.jar的绝对路径,例如:

/Applications/weka-3-6-4.app/Contents/Resources/Java/weka.jar

好了,matlab的借口就配置好了。

这里还有个问题,保存的ARFF中类别信息(class)是numrical型,不是枚举型,至少调用LibSVM会报错。

得手工修改(我的数据有7类):

@attribute class numeric => @attribute class {1,2,3,4,5,6,7}

OK,matlab这边这下没问题了。


——————————————————————————————————————————————

同时参考了以下文章:

http://blog.sina.com.cn/s/blog_890c6aa30101av9x.html

——————————————————————————————————————————————
# 配置MATLAB调用Weka
1. 下载weka
2. 安装weka
3. 在环境变量的系统变量中的Path中加入jre6(或者其他的)中bin文件夹的绝对路径,如:
    C:\ProgramFiles\Java\jre6\bin;
4. 查找MATLAB配置文件classpath.txt
  which classpath.txt%使用这个命令可以查找classpath.txt的位置
5. 修改配置文件classpath.txt
  edit classpath.txt
  在classpath.txt配置文件中将weka安装目录下的weka.jar的绝对安装路径填入,如:
  C:\ProgramFiles\Weka-3-6/weka.jar
6. 重启MATLAB
7. 运行如下命令:
  attributes =javaObject('weka.core.FastVector'); 
  %如果MATLAB没有报错,就说明配置成功了

——————————————————————————————————————————————

java还得添加环境变量,当真麻烦。。。



添加java路径:
还得把反斜杠换成斜杠。。。
D:\000\tools\Weka-3-6\weka.jar

又报错了 。。。



把arff文件复制到当前路径下,解决:



下面用格式转换命令:

[mdata,featureNames,targetNDX,stringVals,relationName] =weka2matlab(data);




====================================我是分割线========================================================





把mdata保存一下,这样,鸢尾花(iris)数据集就可以直接使用了。
————————————————————————————————————————————

我已经将txt格式的鸢尾花数据集上传到我的资源,在matlab下可以一句话加载。

资源:http://download.csdn.net/detail/u013657981/9241121

matlab命令:load('iris.txt')


————————————————————————————————————————————
我们要用mdata矩阵画平行轴图
啥又是平行轴图?



看来大概是这么个东西:


看看这个东西是怎么画出来的:


用Matlab 画出鸢尾花图,可以用下列语句来实现。
subplot(4,4, 1) %分区绘图
plot(x1,y1,'o') %绘制散点图
你有数据的话,可以传至我的邮箱,可以帮你试一下。


嗯,思路大概是,用

subplot(4,4, 1)
分成16个区


以下四个变量:

sepallength  
sepalwidth    
petallength    
petalwidth   


分别为

x1,x2,x3,x4

再来一遍

y1,y2,y3,y4


Iris-setosa,Iris-versicolor,Iris-virginica 是三类,用不同的颜色和形状表示。


iris矩阵是150*5


思路呢,是这么个思路:


每一行是一个数据点(样本),每个样本第五个元素(第五列)是类别标签。


那就把0,1,2三类挑出来,

就是iris(第五列为0的行,的所有列)

然后自己跟自己对应着画图就可以了。

subplot排版略麻烦:


代码是这样的:


Iris_setosa=iris(iris(:,5)==0,:);
Iris_versicolor=iris(iris(:,5)==1,:);
Iris_virginica=iris(iris(:,5)==2,:);
subplot(4,4,1);
%第一列的所有行,第四列的所有行
scatter(Iris_setosa(:,1),Iris_setosa(:,4),'red');
hold on
scatter(Iris_versicolor(:,1),Iris_versicolor(:,4),'g','+');
hold on
scatter(Iris_virginica(:,1),Iris_virginica(:,4),'b','*');subplot(4,4,5);scatter(Iris_setosa(:,1),Iris_setosa(:,3),'red');
hold on
scatter(Iris_versicolor(:,1),Iris_versicolor(:,3),'g','+');
hold on
scatter(Iris_virginica(:,1),Iris_virginica(:,3),'b','*');subplot(4,4,9);scatter(Iris_setosa(:,1),Iris_setosa(:,2),'red');
hold on
scatter(Iris_versicolor(:,1),Iris_versicolor(:,2),'g','+');
hold on
scatter(Iris_virginica(:,1),Iris_virginica(:,2),'b','*');subplot(4,4,13);subplot(4,4,2);
%第一列的所有行,第四列的所有行
scatter(Iris_setosa(:,2),Iris_setosa(:,4),'red');
hold on
scatter(Iris_versicolor(:,2),Iris_versicolor(:,4),'g','+');
hold on
scatter(Iris_virginica(:,2),Iris_virginica(:,4),'b','*');subplot(4,4,6);scatter(Iris_setosa(:,2),Iris_setosa(:,3),'red');
hold on
scatter(Iris_versicolor(:,2),Iris_versicolor(:,3),'g','+');
hold on
scatter(Iris_virginica(:,2),Iris_virginica(:,3),'b','*');subplot(4,4,10);subplot(4,4,14);scatter(Iris_setosa(:,2),Iris_setosa(:,1),'red');
hold on
scatter(Iris_versicolor(:,2),Iris_versicolor(:,1),'g','+');
hold on
scatter(Iris_virginica(:,2),Iris_virginica(:,1),'b','*');subplot(4,4,3);
%第一列的所有行,第四列的所有行
scatter(Iris_setosa(:,3),Iris_setosa(:,4),'red');
hold on
scatter(Iris_versicolor(:,3),Iris_versicolor(:,4),'g','+');
hold on
scatter(Iris_virginica(:,3),Iris_virginica(:,4),'b','*');subplot(4,4,7);subplot(4,4,11);scatter(Iris_setosa(:,3),Iris_setosa(:,2),'red');
hold on
scatter(Iris_versicolor(:,3),Iris_versicolor(:,2),'g','+');
hold on
scatter(Iris_virginica(:,3),Iris_virginica(:,2),'b','*');subplot(4,4,15);scatter(Iris_setosa(:,3),Iris_setosa(:,1),'red');
hold on
scatter(Iris_versicolor(:,3),Iris_versicolor(:,1),'g','+');
hold on
scatter(Iris_virginica(:,3),Iris_virginica(:,1),'b','*');subplot(4,4,4);subplot(4,4,8);
%第一列的所有行,第四列的所有行
scatter(Iris_setosa(:,4),Iris_setosa(:,3),'red');
hold on
scatter(Iris_versicolor(:,4),Iris_versicolor(:,3),'g','+');
hold on
scatter(Iris_virginica(:,4),Iris_virginica(:,3),'b','*');subplot(4,4,12);scatter(Iris_setosa(:,4),Iris_setosa(:,2),'red');
hold on
scatter(Iris_versicolor(:,4),Iris_versicolor(:,2),'g','+');
hold on
scatter(Iris_virginica(:,4),Iris_virginica(:,3),'b','*');subplot(4,4,16);scatter(Iris_setosa(:,4),Iris_setosa(:,1),'red');
hold on
scatter(Iris_versicolor(:,4),Iris_versicolor(:,1),'g','+');
hold on
scatter(Iris_virginica(:,4),Iris_virginica(:,1),'b','*');

结果是这样的:




这篇关于使用平行轴图显示鸢尾花(iris)的四个特征数据(创新实验室联合纳新测试题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/727293

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

使用python生成固定格式序号的方法详解

《使用python生成固定格式序号的方法详解》这篇文章主要为大家详细介绍了如何使用python生成固定格式序号,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录生成结果验证完整生成代码扩展说明1. 保存到文本文件2. 转换为jsON格式3. 处理特殊序号格式(如带圈数字)4

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV