1.简单线性回归
读取case1.csv,其中wt列为病人体重,volume列为病人肾脏容积,试建立回归方程,用病人体重预测病人肾脏容积。
2.多元线性回归
读取case2.csv,其中crim列为城镇人均犯罪率,zn为住宅用地超过25,000平方英尺以上的比例,indus为城镇非零售商用土地的比例(即工业或农业等用地比例),chas为查尔斯河虚拟变量(边界是河,则为1;否则为0),nox为一氧化氮浓度(百万分之几),rm为每个住宅的平均房间数,age为1940 年之前建成的自用房屋比例,dis为到波士顿五个中心区域的加权距离(与繁华闹市的距离,区分郊区与市区),rad为高速公路通行能力指数(辐射性公路的靠近指数),tax为每10,000美元的全额财产税率,ptratio为按镇划分的城镇师生比例,b为1000(bk-0.63)^2其中bk是城镇黑人比例,lstat为人口中地位低下者的百分比,medv为自有住房的中位数价值(单位:千美元)。以medv为因变量(预测目标),建立回归方程,预测房价,并评价模型性能。
3.关联规则挖掘
读取case3.csv,试挖掘出支持度>=0.02,置信度>=0.35的关联规则。
4.梯度下降法实现多元线性回归(选做)
自行实现梯度下降法,实现多元线性回归中的参数计算。记录自己实现的梯度下降法的运算时间,与statsmodels中的方法进行比较。
5.apriori算法实现关联规则挖掘(选做)
自行实现apriori算法,实现关联规则挖掘。记录自己实现的apriori算法的运算时间,与mlxtend中的方法进行比较。
三、实验过程及步骤
1.一元线性回归&多元线性回归
1.0实现思路
一元线性回归近似于用一条直线来拟合数据和结果,y = a·x + b。我们会希望数据的分布和拟合曲线之间的误差越小而且符合正态分布。
1.1基于statsmodels.ols的一元线性回归
在进行多元回归的时候需要将excel中多列参数值读到stark中,然后再调用相关函数。
1.2 diy一元线性回归
定义矩阵乘法函数j(梯度下降函数)和对矩阵求导的函数dj,求导的结果决定了x的方向。
具体实现:使用numpy包中的dot函数实现点乘
2.相关分析
2.1将数据库中数据读成购物清单的格式
图二 格式转换
2.2遍历得到所有商品,放到c1中;
2.3假定支持度是0.2,计算每个商品的支持度(出现的频率),如果支持度超过0.2则放入l1层;
2.4将l1层中商品进行两两组合,得到c2,计算c2中每个组合的支持度,将支持度大于0.02的组合放入l2层;最终得到的l就类似是一个柜子,如下图所示,最后通过遍历可以得到支持度大于0.2的组合;
图三 实验结果效果图
四、实验结果及分析
1.出现的问题
·在使用自己写得多元线性回归递归的时候出现梯度越来越大的问题。
图四 每次迭代之后梯度反而上升
当我修改eta从0.01至0.000001后下降的数据恢复正常,在迭代后逐渐减小。
图五 在修改公式中的eta后数据恢复正常
2.结果时间对比
图六 结果时间对比
3.结果评估
在回归任务(对连续值的预测)中,常见的评估指标(metric)有:平均绝对误差(mean absolute error,mae)、均方误差(mean square error,mse)、均方根误差(root mean square error,rmse)和平均绝对百分比误差(mean absolute percentage error,mape),其中用得最为广泛的就是mae和mse。
图七 一元线性回归summary
从图中我们可以看出样本数量(no.observation)为24;
残差自由度 (df residuals,残差指的是实际观察值与估计值之间的差)为22,;
参数数量(df residuals)为1;
确定系数 (r-squared,说明估计的准确性“确定系数”是通过数据的变化来表征一个拟合的好坏。由上面的表达式可以知道“确定系数”的正常取值范围为[0 1],越接近1,表明方程的变量对y的解释能力越强,这个模型对数据拟合的也较好)为0.986,确定系数与ssr(sum of squares of the regression,即预测数据与原始数据均值之差的平方和)和sst(total sum of squares,即原始数据和均值之差的平方和)相关,r-squared = ssr/sst;
修正确定系数( adj.r-squared)为0.981,这里修正确定系数公式为,p为模型中变量的个数,当引入新的变量时可以提高确定系数,我们引入修正系数相当于给变量个数的增加添加惩罚项。
图八 使用statsmodels.ols的一元线性回归结果可视化
从图片中来看,const 和 wt 分别意味截距和斜率。
图九 diy一元线性回归结果
图十 多元线性回归summary
图十一 多元线性回归参数列表
图十二 根据diy多元数据模型预测出出来的房价(部分)
图十三 diy多元数据评估指标
对比来看,diy模型效果不是很好呀,这里的r2即左边多元线性回归summary中的r-squared,r2 是多元回归中的回归平方和占总平方和的比例,它是度量多元回归方程中拟合程度的一个统计量,反映了在因变量y的变差中被估计的回归方程所解释的比例。r2 越接近1,表明回归平方和占总平方和的比例越大,回归线与各观测点越接近,用x的变化来解释y值变差的部分就越多,回归的拟合程度就越好。
图十二 基于mlxtend.frequent_patterns的关联分析
图十三 diy关联分析(部分)
小米6手机年后发布:曲面,双镜头,超窄边框,首发骁龙835?
调教LLaMA类模型没那么难,LoRA将模型微调缩减到几小时
深度解析电容对ESD的影响
车载ECU嵌入式软件的测试入门
模仿自体移植.首个将双层皮肤直接“打印”在伤口的生物打印机
用Python进行线性回归 用Python中的mlxtend包实现关联规则挖掘
你知道Linux内核里的DebugFS?
一文读懂UART/RS232协议学习_串行和并行通信介绍
高通骁龙865芯片简介
传音控股旗下TECNO举办了AR线上发布会 推出TECNO CAMON 16 Premier
工业企业照明设计标准GB50034-92
GPR-H系列经济型单路开关直流电源的特点及应用范围
现代安防智能视频监控技术的发展方向
打破垄断 中国集成电路产业形成完整链条
中国工业机器人应用市场规模已数年居世界首位,三分之一制造业机器人需求来自中国
WiFi6有哪些优势?
OSAT成为国内半导体产业关键突破口
联发科人机接口到位 卡位物联网应用
安防监控系统中玻璃破碎报警系统成为了非常重要的组成部分
iQOO Pro全系产品已在各大旗舰店同步开售并拥有多种版本可供选择