Python实现Catboost回归模型(CatBoostRegressor算法)项目实战

本文涉及的产品
模型在线服务 PAI-EAS,A10/V100等 500元 1个月
交互式建模 PAI-DSW,5000CU*H 3个月
模型训练 PAI-DLC,5000CU*H 3个月
简介: Python实现Catboost回归模型(CatBoostRegressor算法)项目实战

说明:这是一个机器学习实战项目(附带数据+代码+文档+视频讲解),如需数据+代码+文档+视频讲解可以直接到文章最后获取。

image.png

image.png

1.项目背景

CatBoost是一种基于对称决策树(oblivious trees)为基学习器实现的参数较少、支持类别型变量和高准确性的GBDT框架,主要解决的痛点是高效合理地处理类别型特征,这一点从它的名字中可以看出来,CatBoost是由Categorical和Boosting组成。此外,CatBoost还解决了梯度偏差(Gradient Bias)以及预测偏移(Prediction shift)的问题,从而减少过拟合的发生,进而提高算法的准确性和泛化能力。本文使用CatBoostRegressor来解决回归问题。

2.数据获取

本次建模数据来源于网络(本项目撰写人整理而成),数据项统计如下

编号 

变量名称

描述

1

id

 

2

spacegroup

 

3

number_of_total_atoms

 

4

percent_atom_al

 

5

percent_atom_ga

 

6

percent_atom_in

 

7

lattice_vector_1_ang

 

8

lattice_vector_2_ang

 

9

lattice_vector_3_ang

 

10

lattice_angle_alpha_degree

 

11

lattice_angle_beta_degree

 

12

lattice_angle_gamma_degree

 

13

formation_energy_ev_natom

 

14

bandgap_energy_ev

标签

数据详情如下(部分展示):

image.png

3.数据预处理

3.1 用Pandas工具查看数据

使用Pandas工具的head()方法查看前五行数据:

image.png

从上图可以看到,总共有14个字段:参与机器学习的变量13个,其中id只是一个编号,建模时我们要去掉它。

关键代码:

image.png

3.2缺失值统计

使用Pandas工具的info()方法统计每个特征缺失情况:

image.png

从上图可以看到,数据不存在缺失值,总数据量为2400条。

关键代码:

image.png

3.3变量描述性统计分析

通过Pandas工具的describe()方法来来统计变量的平均值、标准差、最大值、最小值、分位数等信息:

image.png

关键代码如下:

image.png

4.探索性数据分析

4.1 spacegroup特征分布分析

用Pandas工具的value_counts().plot()方法进行统计绘图,输出结果如下:

image.png

图形化展示如下:

image.png

从上面两个图中可以看到,分类为206的有490条,分类为33的有432条。

4.2 number_of_total_atoms特征分布分析

 

image.png

image.png

从上面两个图中可以看到,分类为80的有1410条,分类为40的有519条。

4.3 相关性分析

通过Pandas工具的corr()方法和seaborn工具的heatmap()方法绘制相关性热力图:

image.png

从图中可以看到,正数为正相关,负数为负相关,绝对值越大相关性越强。

4.4 变量的相关关系

image.png

从图中可以看到,变量percent_atom_al和变量bandgap_energy_ev呈线性关系。

4.5 bandgap_energy_ev变量直方图

通过Matplotlib工具的hist()方法绘制直方图:

image.png

从上图可以看到bandgap_energy_ev变量数据存在右偏现象。

5.特征工程

5.1 建立特征数据和标签数据

bandgap_energy_ev为标签数据,除 idbandgap_energy_ev之外的为特征数据。关键代码如下:

image.png

5.2 数据集拆分

数据集集拆分,分为训练集和测试集,80%训练集和20%测试。关键代码如下:

image.png

6.构建CatBoost回归模型

主要使用CatBoostRegressor算法,用于目标回归。 

6.1模型参数

编号

模型名称

参数

1

CatBoost回归模型

iterations=100

2

learning_rate=0.03

3

depth=4

4

loss_function='RMSE'

5

eval_metric='RMSE'

6

random_seed=99

7

od_type='Iter'

8

od_wait=50

关键代码如下:

image.png

7.模型评估 

7.1评估指标及结果

评估指标主要包括可解释方差值、平均绝对误差、均方误差、R方值等等。

模型名称

指标名称

指标值

测试集

CatBoost回归模型

可解释方差值

0.93

平均绝对误差

0.18

均方误差

0.06

R方

0.93

从上表可以看出,R方93%  可解释方差值93%,CatBoost回归模型比较优秀,效果非常好。

关键代码如下:

image.png

7.2 模型特征重要性

特征重要性绘图展示:

image.png

从上图可以看到特征变量对此模型的重要性依次为: 

columns

feature_importances

percent_atom_in

0.344317161

percent_atom_al

0.323864627

formation_energy_ev_natom

0.085339896

lattice_vector_3_ang

0.061193613

spacegroup

0.060865826

lattice_angle_alpha_degree

0.03502702

lattice_vector_2_ang

0.029488005

lattice_vector_1_ang

0.028583657

percent_atom_ga

0.01398625

lattice_angle_beta_degree

0.008160385

lattice_angle_gamma_degree

0.007168071

number_of_total_atoms

0.002005489

 

 

7.3 真实值与预测值对比图

image.png

从上图可以看出真实值和预测值波动基本一致,模型拟合效果非常棒。

8.结论与展望

综上所述,本文采用了CatBoost回归模型,最终证明了我们提出的模型效果良好。


# 本次机器学习项目实战所需的资料,项目资源如下:
 
# 项目说明:
 
# 获取方式一:
 
# 项目实战合集导航:
 
https://docs.qq.com/sheet/DTVd0Y2NNQUlWcmd6?tab=BB08J2
 
# 获取方式二:
 
链接:https://pan.baidu.com/s/1w__eUlVe8X_z0ZKOuPC8Sw 
提取码:rj25
相关实践学习
使用PAI-EAS一键部署ChatGLM及LangChain应用
本场景中主要介绍如何使用模型在线服务(PAI-EAS)部署ChatGLM的AI-Web应用以及启动WebUI进行模型推理,并通过LangChain集成自己的业务数据。
机器学习概览及常见算法
机器学习(Machine Learning, ML)是人工智能的核心,专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能,它是使计算机具有智能的根本途径,其应用遍及人工智能的各个领域。 本课程将带你入门机器学习,掌握机器学习的概念和常用的算法。
相关文章
|
4天前
|
机器学习/深度学习 算法 搜索推荐
从理论到实践,Python算法复杂度分析一站式教程,助你轻松驾驭大数据挑战!
【10月更文挑战第4天】在大数据时代,算法效率至关重要。本文从理论入手,介绍时间复杂度和空间复杂度两个核心概念,并通过冒泡排序和快速排序的Python实现详细分析其复杂度。冒泡排序的时间复杂度为O(n^2),空间复杂度为O(1);快速排序平均时间复杂度为O(n log n),空间复杂度为O(log n)。文章还介绍了算法选择、分而治之及空间换时间等优化策略,帮助你在大数据挑战中游刃有余。
19 4
|
4天前
|
机器学习/深度学习 缓存 算法
Python算法设计中的时间复杂度与空间复杂度,你真的理解对了吗?
【10月更文挑战第4天】在Python编程中,算法的设计与优化至关重要,尤其在数据处理、科学计算及机器学习领域。本文探讨了评估算法性能的核心指标——时间复杂度和空间复杂度。通过详细解释两者的概念,并提供快速排序和字符串反转的示例代码,帮助读者深入理解这些概念。同时,文章还讨论了如何在实际应用中平衡时间和空间复杂度,以实现最优性能。
19 6
|
1天前
|
存储 机器学习/深度学习 算法
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
蓝桥杯Python编程练习题的集合,涵盖了从基础到提高的多个算法题目及其解答。
10 3
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
|
1天前
|
机器学习/深度学习 数据可视化 Python
Python实用记录(三):通过netron可视化模型
使用Netron工具在Python中可视化神经网络模型,包括安装Netron、创建文件和运行文件的步骤。
7 2
Python实用记录(三):通过netron可视化模型
|
2天前
|
机器学习/深度学习 数据采集 供应链
Python实现深度学习模型:智能库存管理系统
【10月更文挑战第5天】 Python实现深度学习模型:智能库存管理系统
21 9
|
4天前
|
机器学习/深度学习 自然语言处理 语音技术
使用Python实现深度学习模型:智能产品设计与开发
【10月更文挑战第2天】 使用Python实现深度学习模型:智能产品设计与开发
20 4
|
3天前
|
机器学习/深度学习 供应链 Python
使用Python实现深度学习模型:智能供应链管理与优化
使用Python实现深度学习模型:智能供应链管理与优化 【10月更文挑战第4天】
15 0
使用Python实现深度学习模型:智能供应链管理与优化
|
1天前
|
机器学习/深度学习 TensorFlow 算法框架/工具
使用Python实现深度学习模型:智能数据隐私保护
使用Python实现深度学习模型:智能数据隐私保护 【10月更文挑战第3天】
10 0
|
7天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于MSER和HOG特征提取的SVM交通标志检测和识别算法matlab仿真
### 算法简介 1. **算法运行效果图预览**:展示算法效果,完整程序运行后无水印。 2. **算法运行软件版本**:Matlab 2017b。 3. **部分核心程序**:完整版代码包含中文注释及操作步骤视频。 4. **算法理论概述**: - **MSER**:用于检测显著区域,提取图像中稳定区域,适用于光照变化下的交通标志检测。 - **HOG特征提取**:通过计算图像小区域的梯度直方图捕捉局部纹理信息,用于物体检测。 - **SVM**:寻找最大化间隔的超平面以分类样本。 整个算法流程图见下图。
|
2天前
|
算法
基于粒子群算法的分布式电源配电网重构优化matlab仿真
本研究利用粒子群算法(PSO)优化分布式电源配电网重构,通过Matlab仿真验证优化效果,对比重构前后的节点电压、网损、负荷均衡度、电压偏离及线路传输功率,并记录开关状态变化。PSO算法通过迭代更新粒子位置寻找最优解,旨在最小化网络损耗并提升供电可靠性。仿真结果显示优化后各项指标均有显著改善。