首页 > 其他分享 >R语言SVM、决策树与因子分析对城市空气质量分类与影响因素可视化研究

R语言SVM、决策树与因子分析对城市空气质量分类与影响因素可视化研究

时间:2024-03-07 23:33:06浏览次数:31  
标签:SVM 模型 因子 cost 因子分析 空气质量 我们 决策树

全文链接:https://tecdat.cn/?p=35303

原文出处:拓端数据部落公众号

数据处理和分析在数据科学领域中扮演着至关重要的角色。确保数据的准确性和完整性是数据处理的首要任务。在本研究中,我们以空气质量数据为例,帮助客户进行了数据处理和分析。

根据空气质量的指标(x1~x7),我们将30个城市分成两类,并使用Y1来评估分类的效果。为了便于分类,在本研究中,我们将使用决策树方法和支持向量机(SVM)方法来进行分类分析。这两种方法在机器学习领域被广泛应用,能够有效地处理分类问题,并提高模型的准确性和泛化能力。

读取数据

首先,我们使用R语言中的read.csv函数来导入名为"air.csv"的数据集,并通过skip参数跳过第一行进行读取。

空气质量数据:

image.png

随后,使用head函数来查看数据的前几行,以初步了解数据的结构和内容。

   
data=read.csv("air.csv",skip = 1)  
head(data)

image.png

第一部分:

数据处理 : 我们将Y1的指标转化为0和1,分别表示该城市的空气质量好和差。这种分类方法有助于后续的分析和建模。

   
 data$Y1<-ifelse(data$Y1>365*0.8,'空气好','空气差')   

构建因变量

   
data$Y1<-as.factor(data$Y1)  ## 将因变量格式转为因子型  

构建训练集、测试集

在编程的过程中,我们需要确保每个步骤都得到充分的考虑和完善。从数据预处理、特征工程、数据可视化到建模、验证和优化,每个环节都至关重要,不能有任何遗漏。此外,构建训练集和测试集也是非常关键的一步。我们采用了分层抽样的方法,将数据集分为70%的训练集和30%的测试集。通过这种划分方式,我们可以在训练集上建立模型,并在测试集上验证模型的准确性和泛化能力,从而评估模型的有效性和可靠性。

   
  
  
train<-data[trainindex, ]  ## 去除price变量的训练集  
test<-data[-trainindex, ]  ## 去除price变量的测试集  

训练svm模型

一、使用线性核函数去拟合SVM模型

在训练SVM模型的过程中,我们首先使用线性核函数进行拟合。

1)模型拟合

   
,data=train,kernel='linear',  
             cost=10,scale=F)  
             #kernel='linear'  ## 选择线性核函数  
#scale=F  ## 对数据不进行标准化处理,支持向量机的的损失函数为凸函数,是否标准化不影响最优解,但标准化之后可以使求解速度变快  
#cost=10  ## 参数代表犯错的成本,越大模型对误差的惩罚越大,生成的分类边界越复杂  

在上述代码中,我们使用svm函数拟合了一个SVM模型,其中指定了使用线性核函数(kernel='linear')进行分类。参数cost=10表示对误差的惩罚程度,这个值越大,模型对误差的惩罚越大,生成的分类边界也会更复杂。同时,我们选择不对数据进行标准化处理(scale=FALSE),因为SVM的损失函数是凸函数,标准化数据不会影响最优解,但可以加快求解速度。

   
 summary ( svmfit1 )

image.png 在上述代码中,我们使用summary函数对拟合的SVM模型进行了摘要。该摘要包含了模型的关键参数和性能指标,如下所示:

  • SVM-Type: C-classification
  • SVM-Kernel: linear
  • cost: 10
  • gamma: 0.02173913
  • Support Vectors数量: 8

从摘要中可以看出,我们拟合的SVM模型是一个C-classification类型的模型,使用了线性核函数,cost参数为10。此外,模型中有8个支持向量,这些支持向量在决定分类边界时起到关键作用。最后,模型中共有2个类别,分别为"空气差"和"空气好"。

2)对svmfit1模型进行改进,选择最优的cost值

在对已拟合的svmfit1模型进行改进时,我们选择了最优的cost值。以下是具体步骤和结果的解释:

   

    ranges =list(cost=c(0.001 ,  
                                   0.01, 0.1, 1,5,10,100) ))  
summary (tune.out )

image.png

在上述代码中,我们使用tune函数对svm模型进行参数调优,通过10折交叉验证的方式选择最优的cost值。summary函数用于查看调优结果摘要,包括最佳参数和性能指标。

从上述结果中可以看出,经过参数调优后,最佳的cost值为0.1,对应的误差率为0.05。在调优过程中,我们对不同的cost值进行了评估,并选择了性能最优的参数值。

           

   
summary ( best.mode1 )

image.png

在最优模型摘要中,我们可以看到调优后的最佳模型参数为C-classification类型的线性SVM模型,使用线性核函数,cost参数为0.1。模型中共有11个支持向量,共包含2个类别:"空气差"和"空气好"。这些结果表明通过参数调优,我们成功选择了最优的cost值,优化了SVM模型的性能。

3)模型评估

在对模型进行评估的过程中,我们首先对SVM模型进行评估,然后训练决策树模型。

   
ypred<-predict(

image.png

在上述代码中,我们使用predict函数对训练好的SVM模型进行预测,得到了预测结果。这些结果可以与真实值进行对比,从而评估模型的性能。以上结果展示了SVM模型的预测情况,包括真实值和预测值的对比,可以进一步分析模型的准确性和性能。

训练决策树模型

接下来,我们训练决策树模型,以下是具体步骤和结果的解释:

   
.-label-Y1,  
             method="class", dat
             

image.png

在上述代码中,我们使用rpart函数训练了一个决策树模型,其中method="class"表示进行分类分析。模型使用了数据集中除了label和Y1以外的其他变量作为预测因子。 通过plotcp函数可视化交叉验证结果,进一步评估模型的性能。以下是可视化结果:

   
plotcp(fit) # visualize cross-validation results

image.png

   
summary(fit) # 

image.png 最后,利用summary函数对训练的决策树模型进行摘要,包括模型的性能指标、变量重要性以及节点信息。通过摘要结果,我们可以深入了解模型的构建过程和性能表现,为进一步的模型评估和优化提供参考。

2.png

第二部分:

根据第一部分的结果分成的两类城市来, 对第一类城市(空气好的城市):先根据城市发展指标(x8~x15)做因子分析,再将分出的因子和AQI值(y2)做对应分析,来分析它们的相关关系;

   
data1=data[data$Y1=="空气好",]  

对第一类城市(空气好的城市)进行因子分析和相关关系分析的步骤如下:

因子分析

画出协方差阵和相关系数矩阵

   
cov(data1[,-c(1,9:10)]  )

image.png

协方差阵展示了不同变量之间的协方差关系,可以帮助我们了解变量之间的线性关系。

   
cor(data1[,-c(1,9:10)]  )

image.png

相关系数矩阵显示了各个变量之间的相关性程度,可以帮助我们理解变量之间的相关关系。

采用斜交旋转提取因子

   
a1[ ,-c(1,9,10,11)]), nfactors=8, rotate=
 cor(data1$Y2 ,fm$scores)

image.png

在这一步中,我们采用斜交旋转提取因子的方法,将城市发展指标(x8~x15)进行因子分析,并提取8个因子。接着,我们将提取的因子与AQI值(Y2)进行对应分析,以探究它们之间的相关关系。

以上代码展示了AQI值(Y2)与提取的因子之间的相关系数,帮助我们分析城市发展指标与空气质量之间的关联关系。

对第二类城市(即空气质量较差的城市)的研究中,我们首先针对城市发展指标(x8~x15)进行了因子分析,以探究这些指标之间的潜在结构。随后,我们将因子分析得到的因子与空气质量指数(AQI值,即y2)进行了对应分析,以揭示它们之间的相关关系。

首先,我们从原始数据集中筛选出空气质量较差的城市数据  

   
data1=data[data$Y1=="空气差",]  

因子分析

接着,我们对筛选出的城市发展指标(x8~x15)进行了因子分析。为了初步了解这些指标之间的关联性,我们计算了它们的协方差矩阵。协方差矩阵能够展示各指标之间的变异程度以及它们之间的线性相关程度。

   
cov(data1[,-c(1,9:10)]  )



cor(data1[,-c(1,9:10)]  )

image.png

image.png

采用斜交旋转提取因子

对第二类城市(即空气质量较差的城市)进行深入研究时,我们首先采用因子分析方法来探究城市发展指标(x8~x15)之间的潜在结构。为了更清晰地解释因子并使其具有实际意义,我们使用了斜交旋转(特别是“varimax”旋转)来提取因子。这种方法有助于我们理解各个因子所代表的原始指标组合,以及这些因子在解释城市发展特征时的相对重要性。

在因子分析过程中,我们设定了提取8个因子的目标,这是因为我们希望找到能够代表原始指标中大部分信息的少数几个因子。通过斜交旋转,我们得到了旋转后的因子载荷矩阵,这有助于我们解释每个因子所代表的含义。

随后,为了探究这些因子与空气质量指数(AQI值,即y2)之间的相关关系,我们计算了因子得分与AQI值之间的相关系数。相关系数矩阵显示了每个因子与AQI值之间的线性相关程度。

   
ctors=8, rotate="varimax
cor(data1$Y2 ,fm$scores)
          

image.png

从相关系数矩阵中,我们可以看到MR5因子与AQI值之间存在较高的正相关关系(相关系数为0.8802801),这意味着该因子所代表的城市发展特征与空气质量较差有显著的正向关联。同时,MR6因子也与AQI值呈现出一定的正相关(相关系数为0.3007104),表明该因子同样与较差的空气质量有关。

其他因子与AQI值之间的相关系数虽然较低,但也可能存在某种关联。这些结果为我们提供了关于城市发展指标与空气质量之间关系的初步线索,有助于我们进一步理解和分析这些城市在发展过程中所面临的空气质量挑战。


2020_five-fifty-520x290.jpg 最受欢迎的见解

1.PYTHON用户流失数据挖掘:建立逻辑回归、XGBOOST、随机森林、决策树、支持向量机、朴素贝叶斯模型和KMEANS聚类用户画像

2.R语言基于树的方法:决策树,随机森林

3.python中使用scikit-learn和pandas决策树

4.机器学习:在SAS中运行随机森林数据分析报告

5.R语言用随机森林和文本挖掘提高航空公司客户满意度

6.机器学习助推快时尚精准销售时间序列

7.用机器学习识别不断变化的股市状况——隐马尔可夫模型的应用

8.python机器学习:推荐系统实现(以矩阵分解来协同过滤)

9.python中用pytorch机器学习分类预测银行客户流失

标签:SVM,模型,因子,cost,因子分析,空气质量,我们,决策树
From: https://www.cnblogs.com/tecdat/p/18060043

相关文章

  • 机器学习基础-线性回归,逻辑回归,SVM
    回归给定数据,回归就是用一个方程尽可能地拟合数据点的分布;线性回归假设数据中\(y\)与\(x\)呈线性关系;给定,线性回归就是要找一条线/面,并且让这条直线尽可能地拟合数据点的分布;二元线性回归:$\hat{y}=ax_1+bx_2+c$去拟合数据解法:最小二乘;$loss=\sum{(y_i-\hat{y_i}......
  • Python 机器学习 决策树 文本特征的处理
    ​Python机器学习中,决策树是一种常用的分类和回归模型。决策树可以处理数值型特征和类别型特征。对于文本特征,决策树通常使用词袋模型(BOW)或TF-IDF模型进行处理。在处理文本特征时,决策树(和机器学习算法通常)不能直接处理原始文本。文本必须首先转换成算法能理解的数值形式。......
  • R语言逻辑回归、决策树、随机森林、神经网络预测患者心脏病数据混淆矩阵可视化
    全文链接:https://tecdat.cn/?p=33760原文出处:拓端数据部落公众号概述:众所周知,心脏疾病是目前全球最主要的死因。开发一个能够预测患者心脏疾病存在的计算系统将显著降低死亡率并大幅降低医疗保健成本。机器学习在全球许多领域中被广泛应用,尤其在医疗行业中越来越受欢迎。机器......
  • 基于自适应支持向量机的matlab建模与仿真,不使用matlab的SVM工具箱函数
    1.算法运行效果图预览 2.算法运行软件版本matlab2022a 3.算法理论概述        支持向量机是一种二分类模型,它的基本思想是在特征空间中寻找一个超平面,使得该超平面能够最大化地将两类样本分隔开。这个超平面由支持向量确定,支持向量是离超平面最近的样本点。自适......
  • Python 机器学习 决策树 数值型特征的处理
    ​ Python机器学习中,特征提取是将原始数据转换为能够被模型有效利用的格式的过程。对于决策树模型而言,特征提取尤其重要,因为好的特征可以显著提升模型的预测性能。在实际应用中,需要根据具体情况选择合适的特征提取方法。数值型特征是机器学习中常见的一种特征类型,它指的是可以......
  • 基于乳腺癌的预测(SVM实战项目)
    2024.2.26今天,我在学习机器学习重要的知识点——SVM(支持向量机)首先,我利用sklearn库中自带的数据集练手点击查看代码importpandasaspdimportseabornassnsimportmatplotlib.pyplotaspltfromsklearn.datasetsimportload_breast_cancerfromsklearn.model_sele......
  • R语言逻辑回归(Logistic Regression)、回归决策树、随机森林信用卡违约分析信贷数据集
    原文链接:http://tecdat.cn/?p=23344最近我们被客户要求撰写关于信用卡违约分析的研究报告,包括一些图形和统计输出。本文中我们介绍了决策树和随机森林的概念,并在R语言中用逻辑回归、回归决策树、随机森林进行信用卡违约数据分析决策树是由节点和分支组成的简单树状结构。根据每......
  • R语言Apriori关联规则、kmeans聚类、决策树挖掘研究京东商城网络购物用户行为数据可视
    全文链接:http://tecdat.cn/?p=30360最近我们被客户要求撰写关于网络购物用户行为的研究报告,包括一些图形和统计输出。随着网络的迅速发展,依托于网络的购物作为一种新型的消费方式,在全国乃至全球范围内飞速发展电子商务成为越来越多消费者购物的重要途径。我们被客户要求撰写关......
  • svm算法
    支持向量机(supportvectormachines,SVM)是一种二分类模型,它的基本模型是定义在特征空间上的间隔最大的线性分类器,间隔最大使它有别于感知机;SVM还包括核技巧,这使它成为实质上的非线性分类器。SVM的的学习策略就是间隔最大化,可形式化为一个求解凸二次规划的问题,也等价于正则化的合......
  • R语言逻辑回归、决策树、随机森林、神经网络预测患者心脏病数据混淆矩阵可视化
    全文链接:https://tecdat.cn/?p=33760原文出处:拓端数据部落公众号概述:众所周知,心脏疾病是目前全球最主要的死因。开发一个能够预测患者心脏疾病存在的计算系统将显著降低死亡率并大幅降低医疗保健成本。机器学习在全球许多领域中被广泛应用,尤其在医疗行业中越来越受欢迎。机器......