首页 > 其他分享 >寒假生活指导06

寒假生活指导06

时间:2024-01-14 17:23:49浏览次数:22  
标签:06 fit pyspark ml 指导 label 寒假 import labelIndexer

实验报告

题目:

Spar机器学习库 MLlib 编程实践

姓名

 

日期2024.1.14

实验环境:操作系统:Ubuntu16.04

JDK 版本:1.7 或以上版本

Spark 版本:2.1.0

实验内容与完成情况:

1.数据导入

从文件中导入数据,并转化为 DataFrame。

代码:

from pyspark.ml.feature import PCA
from pyspark.shell import spark
from pyspark.sql import Row
from pyspark.ml.linalg import Vector, Vectors
from pyspark.ml.evaluation import MulticlassClassificationEvaluator
from pyspark.ml import Pipeline, PipelineModel
from pyspark.ml.feature import IndexToString, StringIndexer, VectorIndexer, HashingTF, Tokenizer
from pyspark.ml.classification import LogisticRegression
from pyspark.ml.classification import LogisticRegressionModel
from pyspark.ml.classification import BinaryLogisticRegressionSummary, LogisticRegression
from pyspark.sql import functions
from pyspark.ml.tuning import CrossValidator, ParamGridBuilder


def f(x):
    rel = {'features': Vectors.dense(float(x[0]), float(x[2]), float(x[4]), float(x[10]), float(x[11]), float(x[12])),
           'label': str(x[14])}
    return rel

df = spark.sparkContext.textFile("./data/adult.data")\
    .map(lambda line: line.split(',')).map(lambda p: Row(**f(p))).toDF()
test = spark.sparkContext.textFile("./data/adult.test")\
    .map(lambda line: line.split(',')).map(lambda p: Row(**f(p))).toDF()
df.show(5)  # 显示df前5条记录
test.show(5)  # 显示test前5条记录

 

运行结果:

 

 

2.进行主成分分析(PCA)

代码:

pca = PCA(k=3, inputCol="features", outputCol="pcaFeatures").fit(df)
result = pca.transform(df)
testdata = pca.transform(test)
result.show()

运行结果:

 

3.训练分类模型并预测居民收入

在主成分分析的基础上,采用逻辑斯蒂回归,或者决策树模型预测居民收入是否超过

50K;对 Test 数据集进行验证。

逻辑回归代码:

# 将标签列进行索引编码
labelIndexer = StringIndexer(inputCol="label", outputCol="indexedLabel").fit(result)
# 打印编码后的标签列表
for label in labelIndexer.labels:
    print(label)

# 自动检测数值型特征,并对特征向量进行索引编码
featureIndexer = VectorIndexer(inputCol="pcaFeatures", outputCol="indexedFeatures").fit(result)
print("索引后的特征数量为: ", featureIndexer.numFeatures)

# 创建IndexToString转换器以将预测结果从索引还原为原始标签
labelConverter = IndexToString(inputCol="prediction", outputCol="predictedLabel", labels=labelIndexer.labels)

# 重新定义labelIndexer变量
labelIndexer = StringIndexer(inputCol="label", outputCol="indexedLabel").fit(result)
# 再次打印编码后的标签列表
for label in labelIndexer.labels:
    print(label)

# 使用之前定义的featureIndexer对象获取特征数量
print("索引后特征的数量为: ", featureIndexer.numFeatures)

# 实例化逻辑回归模型并设置参数(逻辑回归模型)
lr = LogisticRegression().setLabelCol("indexedLabel").setFeaturesCol("indexedFeatures").setMaxIter(100)

# 构建机器学习管道,包括标签和特征索引、逻辑回归模型以及标签还原步骤
lrPipeline = Pipeline().setStages([labelIndexer, featureIndexer, lr, labelConverter])

# 训练整个管道模型
lrPipelineModel = lrPipeline.fit(result)
lrModel = lrPipelineModel.stages[2]  # 获取管道中逻辑回归模型的具体实例

# 输出逻辑回归模型的系数矩阵、截距向量和特征数量
print(f"系数: {lrModel.coefficientMatrix}\n截距: {lrModel.interceptVector}\n特征数量: {lrModel.numFeatures}")

# 使用训练好的管道模型对测试集进行预测
lrPredictions = lrPipelineModel.transform(testdata)

# 初始化多分类评估器
evaluator = MulticlassClassificationEvaluator().setLabelCol("indexedLabel").setPredictionCol("prediction")

# 计算测试集上的准确率
lrAccuracy = evaluator.evaluate(lrPredictions)
print("测试错误率 = %g " % (1.0 - lrAccuracy))

 

逻辑回归运行结果:

 

决策树参数代码

# 将标签列进行索引编码
labelIndexer = StringIndexer(inputCol="label", outputCol="indexedLabel").fit(result)

# 自动检测数值型特征,并对特征向量进行索引编码
featureIndexer = VectorIndexer(inputCol="pcaFeatures", outputCol="indexedFeatures").fit(result)

# 创建IndexToString转换器以将预测结果从索引还原为原始标签
labelConverter = IndexToString(inputCol="prediction", outputCol="predictedLabel", labels=labelIndexer.labels)

# 实例化决策树分类器模型并设置参数
dt = DecisionTreeClassifier(labelCol="indexedLabel", featuresCol="indexedFeatures")

# 构建机器学习管道,包括标签和特征索引、决策树模型以及标签还原步骤
dtPipeline = Pipeline().setStages([labelIndexer, featureIndexer, dt, labelConverter])

# 训练整个管道模型
dtPipelineModel = dtPipeline.fit(result)
dtModel = dtPipelineModel.stages[2]  # 获取管道中决策树模型的具体实例

# 使用训练好的管道模型对测试集进行预测
dtPredictions = dtPipelineModel.transform(testdata)

# 初始化多分类评估器
evaluator = MulticlassClassificationEvaluator().setLabelCol("indexedLabel").setPredictionCol("prediction")

# 计算测试集上的准确率
dtAccuracy = evaluator.evaluate(dtPredictions)
print("决策树模型在测试集上的错误率为: %g " % (1.0 - dtAccuracy))

 

运行结果

 

4.超参数调优

利用 CrossValidator 确定最优的参数,包括最优主成分 PCA 的维数、分类器自身的参数等。

运行结果:

 

代码:

# 导入所需的PySpark库和模块
from pyspark.ml import Pipeline, Transformer
from pyspark.ml.classification import LogisticRegression
from pyspark.ml.evaluation import MulticlassClassificationEvaluator
from pyspark.ml.feature import IndexToString, StringIndexer, VectorIndexer
from pyspark.ml.feature import PCA
from pyspark.ml.linalg import Vectors
from pyspark.ml.tuning import ParamGridBuilder, CrossValidator
from pyspark.shell import spark
from pyspark.sql import Row



# 定义一个函数f,用于提取特征和标签
def f(x):
    # 创建一个字典,其中'features'键存储选取的数值型特征构成的DenseVector,'label'键存储字符串类型的标签
   
rel = {'features': Vectors.dense(float(x[0]), float(x[2]), float(x[4]), float(x[10]), float(x[11]), float(x[12])),
           'label': str(x[14])}
    return rel

# 读取CSV数据并转换为DataFrame
df = spark.sparkContext.textFile("./data/adult.data")\
    .map(lambda line: line.split(','))\
    .map(lambda p: Row(**f(p)))\
    .toDF()
test = spark.sparkContext.textFile("./data/adult.test")\
    .map(lambda line: line.split(','))\
    .map(lambda p: Row(**f(p)))\
    .toDF()

显示部分原始数据
# df.show(5)
# test.show(5)


# 应用PCA降维
pca = PCA(k=3, inputCol="features", outputCol="pcaFeatures").fit(df)
result = pca.transform(df)
testdata = pca.transform(test)


# 显示PCA变换后的训练集数据
# result.show()

# 将标签列进行索引编码
labelIndexer = StringIndexer(inputCol="label", outputCol="indexedLabel").fit(result)
# 打印编码后的标签列表
for label in labelIndexer.labels:
    print(label)

# 自动检测数值型特征,并对特征向量进行索引编码
featureIndexer = VectorIndexer(inputCol="pcaFeatures", outputCol="indexedFeatures").fit(result)
print("索引后的特征数量为: ", featureIndexer.numFeatures)

# 创建IndexToString转换器以将预测结果从索引还原为原始标签
labelConverter = IndexToString(inputCol="prediction", outputCol="predictedLabel", labels=labelIndexer.labels)

# 重新定义labelIndexer变量
labelIndexer = StringIndexer(inputCol="label", outputCol="indexedLabel").fit(result)
# 再次打印编码后的标签列表
for label in labelIndexer.labels:
    print(label)

# 使用之前定义的featureIndexer对象获取特征数量
print("索引后特征的数量为: ", featureIndexer.numFeatures)

# 实例化逻辑回归模型并设置参数(逻辑回归模型)
lr = LogisticRegression().setLabelCol("indexedLabel").setFeaturesCol("indexedFeatures").setMaxIter(100)

# 构建机器学习管道,包括标签和特征索引、逻辑回归模型以及标签还原步骤
lrPipeline = Pipeline().setStages([labelIndexer, featureIndexer, lr, labelConverter])

# 训练整个管道模型
lrPipelineModel = lrPipeline.fit(result)
lrModel = lrPipelineModel.stages[2]  # 获取管道中逻辑回归模型的具体实例

# 输出逻辑回归模型的系数矩阵、截距向量和特征数量
print(f"系数: {lrModel.coefficientMatrix}\n截距: {lrModel.interceptVector}\n特征数量: {lrModel.numFeatures}")

# 使用训练好的管道模型对测试集进行预测
lrPredictions = lrPipelineModel.transform(testdata)

# 初始化多分类评估器
evaluator = MulticlassClassificationEvaluator().setLabelCol("indexedLabel").setPredictionCol("prediction")

# 计算测试集上的准确率
lrAccuracy = evaluator.evaluate(lrPredictions)
print("测试错误率 = %g " % (1.0 - lrAccuracy))

# PCA
pca = PCA().setInputCol("features").setOutputCol("pcaFeatures")

# String Indexer for Label
labelIndexer = StringIndexer().setInputCol("label").setOutputCol("indexedLabel").fit(df)

# Vector Indexer for PCA Features
featureIndexer = VectorIndexer().setInputCol("pcaFeatures").setOutputCol("indexedFeatures")

# Index to String Converter for Label
labelConverter = IndexToString().setInputCol("prediction").setOutputCol("predictedLabel").setLabels(labelIndexer.labels)

# Logistic Regression
lr = LogisticRegression().setLabelCol("indexedLabel").setFeaturesCol("indexedFeatures").setMaxIter(100)

# Create a Pipeline
lrPipeline = Pipeline().setStages([pca, labelIndexer, featureIndexer, lr, labelConverter])

# Parameter grid for CrossValidator
paramGrid = ParamGridBuilder() \
    .addGrid(pca.k, [1, 2, 3, 4, 5, 6]) \
    .addGrid(lr.elasticNetParam, [0.2, 0.8]) \
    .addGrid(lr.regParam, [0.01, 0.1, 0.5]) \
    .build()

# CrossValidator
cv = CrossValidator().setEstimator(lrPipeline) \
    .setEvaluator(MulticlassClassificationEvaluator().setLabelCol("indexedLabel").setPredictionCol("prediction")) \
    .setEstimatorParamMaps(paramGrid) \
    .setNumFolds(3)

# Fit the model
cvModel = cv.fit(df)

# Make predictions on the test set
lrPredictions = cvModel.transform(test)

# Evaluate the model
evaluator = MulticlassClassificationEvaluator().setLabelCol("indexedLabel").setPredictionCol("prediction")
lrAccuracy = evaluator.evaluate(lrPredictions)
print("Model Accuracy: " + str(lrAccuracy))

# Get the best model
bestModel = cvModel.bestModel
lrModel = bestModel.stages[3]
print("Coefficients: \n" + str(lrModel.coefficientMatrix) + "\nIntercept: " + str(lrModel.interceptVector)
      + "\nNum Classes: " + str(lrModel.numClasses) + "\nNum Features: " + str(lrModel.numFeatures))

# Get PCA Model from the best model
pcaModel = bestModel.stages[0]

 

出现的问题:

解决方案(列出遇到的问题和解决办法,列出没有解决的问题):

标签:06,fit,pyspark,ml,指导,label,寒假,import,labelIndexer
From: https://www.cnblogs.com/syhxx/p/17963923

相关文章

  • 吴师兄学算法day06 双指针 27. 移除元素
    题目:27. 移除元素易错点:差点猛住了,可以用pass顺着逻辑来识别代码示例:classSolution:defremoveElement(self,nums:List[int],val:int)->int:slow=0forfastinrange(len(nums)):ifnums[fast]==val:#删除......
  • 吴师兄学算法day06 双指针 283. 移动零
    题目:283. 移动零注意点:可以交换,也可以最后补零代码示例:classSolution:defmoveZeroes(self,nums:List[int])->None:"""Donotreturnanything,modifynumsin-placeinstead."""slow=0forfa......
  • 吴师兄学算法day06 485. 最大连续 1 的个数
    题目:485. 最大连续1的个数易错点:第一眼想到从队尾开始交换,后来发现不行。 代码示例:classSolution:defmoveZeroes(self,nums:List[int])->None:"""Donotreturnanything,modifynumsin-placeinstead."""slow=......
  • 吴师兄学算法day06 双指针 485. 最大连续 1 的个数
    题目:485. 最大连续1的个数易错点:考察双指的距离注意设置lastzero=-1虚拟坐标为-1,方便做减法。注意,防止最后的1位越界。对应的处理方案就是每轮结束都有统计结果。其实减法,是左闭右右开的区间,比如,3-2是1,      写成区间是 [2,3),减法算的是距离而几到几,......
  • JavaImprove--Lesson06--正则表达式
    一.正则表达式的入门正则表达式是一些特定支付组成的,代表一个规则,简化代码,以字符的形式体现规则正则表达式,又称规则表达式,(RegularExpression,在代码中常简写为regex、regexp或RE),是一种文本模式,包括普通字符(例如,a到z之间的字母)和特殊字符(称为"元字符"),是计算机科学的一个概念。......
  • 寒假生活
    什么是Spark?   Spark是大数据的调度,监控和分配引擎。它是一个快速通用的集群计算平台.Spark扩展了流行的MapReduce模型.Spark提供的主要功能之一就是能够在内存中运行计算,但对于在磁盘上运行的复杂应用程序,系统也比MapReduce更有效2、Spark部署模式2.1、独立模式 在......
  • 大三寒假学习进度笔记4
    今日学习时间两小时,开始学习RDD的内容,学习了RDD的创建和RDD算子的定义分类RDD学习:RDD五大特征:RDD是有分区的分区是RDD数据存储的最小单位计算方法会作用到每一个分区上RDD之间是由相互依赖的关系的KV型RDD可以有分区器KV型RDD:存储的数据是二元元组RDD分区数据的读取会尽......
  • 1.13寒假每日总结4
    今天,主要尝试了在java中调用已有的python脚本并输出相关信息。 参考:百度文心一言的回复。 packagetest0113;importjava.io.*;publicclasstest{publicstaticvoidmain(String[]args){try{//指定Python解释器的路径......
  • 寒假生活指导05
    今天继续完成实验4.实验报告题目:SparkStreaming编程初级实践姓名 日期2024.1.13实验环境:操作系统:Ubuntu16.04Spark版本:2.1.0Flume版本:1.7.0实验内容与完成情况:Flum安装(1)解压安装包tar-zxvfapache-flume-1.7.0-bin.tar.gz-C/export/s......
  • Linux下的gcc/g++编译器的使用 [补档-2023-06-13]
    gcc编译器​这东西是Linux上的c/c++编译器。5-1gcc的工作流程5-2gcc的常用参数-v查看gcc版本号,--version也可以-E生成预处理文件-S生成汇编文件-c只编译,生成.o文件,通常称为目标文件-I指定头文件所在的路径-L指定库文件所在的路径-l指定库的名......