机器学习决策树

一、香农公式

熵:

信息增益:

信息增益=信息熵-条件熵

前者是初始信息熵大小,后者是因为条件加入后带来的确定性增加

信息增益表示得知特征X的信息而使得类Y的信息的不确定性减少的程度

信息增益越大说明影响越大

二、代码

python 复制代码
"""
决策树对泰坦尼克号进行预测生死
:return: None
"""
# 获取数据
titan = pd.read_csv("./data/titanic.txt")
titan.info() # info()查看数据信息,包括每列的类型,非空值个数,内存占用等
python 复制代码
# 处理数据,找出特征值和目标值
x = titan[['pclass', 'age', 'sex']]

y = titan['survived']
print(x.info())  # 用来判断是否有空值
x.describe(include='all') # 用来查看数据的描述性统计信息
python 复制代码
# 一定要进行缺失值处理,填为均值
mean=x['age'].mean()
print(mean)
x.loc[:,'age']=x.loc[:,'age'].fillna(mean)
python 复制代码
# 分割数据集到训练集合测试集
x_train, x_test, y_train, y_test = train_test_split(x, y, test_size=0.25, random_state=4)
print(x_train.head())
python 复制代码
x_train.to_dict(orient="records") #把df变为列表套字典,后面方便变成one_hot编码
python 复制代码
# 进行处理(特征工程)特征-》类别-》one_hot编码
dict = DictVectorizer(sparse=False) # sparse=False表示不用稀疏矩阵,用numpy数组

# 这一步是对字典进行特征抽取,to_dict可以把df变为字典,records代表列名变为键
x_train = dict.fit_transform(x_train.to_dict(orient="records"))
print(type(x_train))
print(dict.get_feature_names_out())
print('-' * 50)
x_test = dict.transform(x_test.to_dict(orient="records"))
print(x_train)
python 复制代码
# 用决策树进行预测,修改max_depth试试,修改criterion为entropy
#树过于复杂,就会产生过拟合
dec = DecisionTreeClassifier()

#训练
dec.fit(x_train, y_train)

# 预测准确率
print("预测的准确率:", dec.score(x_test, y_test))

# 导出决策树的结构
export_graphviz(dec, out_file="tree.dot",
                feature_names=['age', 'pclass=1st', 'pclass=2nd', 'pclass=3rd', 'female', 'male'])
相关推荐
金井PRATHAMA12 分钟前
分布内侧内嗅皮层的层Ⅱ或层Ⅲ的网格细胞(grid cells)对NLP中的深层语义分析的积极影响和启示
人工智能·深度学习·神经网络·机器学习·自然语言处理·知识图谱
朝朝又沐沐18 分钟前
算法竞赛阶段二-数据结构(38)数据结构动态链表list
数据结构·算法·链表
天天开心(∩_∩)1 小时前
代码随想录算法训练营第三十七天
java·开发语言·算法
大千AI助手1 小时前
掩码语言模型(MLM)技术解析:理论基础、演进脉络与应用创新
人工智能·神经网络·机器学习·语言模型·自然语言处理·mlm·掩码
Peter·Pan爱编程1 小时前
CUDA系列之常用Runtime API简介
c++·算法
过往入尘土2 小时前
机器学习鸢尾花案例
人工智能·机器学习
Shun_Tianyou2 小时前
Python Day20 os模块 和 文件操作 及 例题分析
开发语言·数据结构·python·算法
逸风尊者2 小时前
开发也能看懂的大模型:强化学习
java·算法·trae
hello 早上好2 小时前
负载均衡、算法/策略
运维·算法·负载均衡
冲帕Chompa2 小时前
今日矩阵系列
数据结构·算法·矩阵