人工智能知识分享第八天-机器学习_泰坦尼克生存预估&线性回归和决策树回归对比案例

泰坦尼克生存预估案例

python 复制代码
import pandas as pd
from sklearn.model_selection import train_test_split
from sklearn.tree import DecisionTreeClassifier
from sklearn.metrics import classification_report
import matplotlib.pyplot as plt
from sklearn.tree import plot_tree

titanic_df = pd.read_csv('./data/train.csv')
titanic_df.info()

x = titanic_df[['Pclass', 'Sex', 'Age']]
y = titanic_df['Survived']

# x['Age'].fillna(x['Age'].mean(), inplace=True)
x['Age'] = x['Age'].fillna(x['Age'].mean())
x.info()

print(len(x), len(y))
# titanic_df.info()

x = pd.get_dummies(x)
x_train, x_test, y_train, y_test = train_test_split(x, y, test_size=0.2, random_state=22)

estimator = DecisionTreeClassifier()
estimator.fit(x_train, y_train)

y_predict = estimator.predict(x_test)

print('预测结果为:\n', y_predict)
print('准确率: \n', estimator.score(x_test, y_test))
print(f'分类评估报告: \n {classification_report(y_test, y_predict, target_names=["Died", "Survivor"])}')
plt.figure(figsize=(70, 45))
plot_tree(estimator, filled=True, max_depth=10)
plt.savefig("./data/titanic_tree.png")
# 7.3 具体的绘制.
plt.show()

运行结果

线性回归和决策树回归对比案例

python 复制代码
"""
案例:
    演示线性回归 和 回归决策树对比.

结论:
    回归类问题, 既能用线性回归, 也能用决策树回归. 优先使用 线性回归, 因为 决策树回归可能会导致 过拟合.
"""

# 导包.
import numpy as np
import pandas as pd
from sklearn.tree import DecisionTreeRegressor      # 回归决策树
from sklearn.linear_model import LinearRegression   # 线性回归
import matplotlib.pyplot as plt                     # 绘图


# 1. 获取数据.
x = np.array(list(range(1,11))).reshape(-1, 1)
y = np.array([5.56, 5.70, 5.91, 6.40, 6.80, 7.05, 8.90, 8.70, 9.00, 9.05])
print(x)
print(y)

# 2. 创建线性回归 和 决策树回归模型.
estimator1 = LinearRegression()                    # 线性回归
estimator2 = DecisionTreeRegressor(max_depth=1)    # 回归决策树, 层数=1
estimator3 = DecisionTreeRegressor(max_depth=3)    # 回归决策树, 层数=3

# 3. 训练模型.
estimator1.fit(x, y)
estimator2.fit(x, y)
estimator3.fit(x, y)

# 4. 准备测试数据, 用于测试.
# 起始, 结束, 步长.
x_test = np.arange(0.0, 10.0, 0.1).reshape(-1, 1)
print(x_test)

# 5. 模型预测.
y_predict1 = estimator1.predict(x_test)
y_predict2 = estimator2.predict(x_test)
y_predict3 = estimator3.predict(x_test)

# 6. 绘图
plt.figure(figsize=(10, 5))

# 散点图(原始的坐标)
plt.scatter(x, y, color='gray', label='data')
# 线性回归的预测结果
plt.plot(x_test, y_predict1, color='r', label='liner regression')
# 回归决策树, 层数=1
plt.plot(x_test, y_predict2, color='b', label='max depth=1')
# 回归决策树, 层数=3
plt.plot(x_test, y_predict3, color='g', label='max depth=3')
# 显示图例.
plt.legend()
# 设置x轴标签.
plt.xlabel('data')
# 设置y轴标签.
plt.ylabel('target')
# 设置标题
plt.title('Decision Tree Regression')

# 显示图片
plt.show()

运行结果

坚持分享 共同进步

相关推荐
DX_水位流量监测5 分钟前
水库水位监测系统的自动化功能:减少人工干预,可实现实时监控
运维·前端·人工智能·自动化·制造·信息与通信·零售
TianXuan_Chain6 分钟前
web3与AI结合-Sahara AI 项目介绍
人工智能·web3·去中心化·区块链·数据标注
代码行者1237 分钟前
Gary Marcus 预测2025年AI发展的25项展望:深刻反思与前瞻
人工智能·深度学习·计算机视觉·百度·目标跟踪
中关村科金12 分钟前
中关村科金电销外呼机器人的智能调度算法与业务高峰应对策略
人工智能·电销外呼机器人
超自然祈祷23 分钟前
pyTorch笔记
人工智能·pytorch·笔记·神经网络
计算机科研之友(Friend)1 小时前
【图像处理】数据集合集!
图像处理·人工智能·机器学习·计算机视觉·数据挖掘·人机交互
AI探索家_星海算力1 小时前
如何配置【Docker镜像】加速器+【Docker镜像】的使用
运维·人工智能·docker·容器·gpu算力
Kai HVZ1 小时前
《OpenCV》——模版匹配
人工智能·opencv·计算机视觉
Ava的硅谷新视界2 小时前
DeepSeek重新定义“Open“AI
人工智能·语言模型