机器学习-Random Forest实例

下面是一个使用随机森林(Random Forest)进行分类的示例,使用 Python 中的 scikit-learn 库。我们将继续使用经典的鸢尾花(Iris)数据集进行演示。

代码实现:

# 导入库
from sklearn.ensemble import RandomForestClassifier
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.metrics import accuracy_score, classification_report

# 加载数据集
iris = load_iris()
X = iris.data  # 特征
y = iris.target  # 标签

# 将数据集划分为训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 创建 Random Forest 分类器
rf_classifier = RandomForestClassifier(n_estimators=100, max_depth=3, random_state=42)

# 训练 Random Forest 模型
rf_classifier.fit(X_train, y_train)

# 进行预测
y_pred = rf_classifier.predict(X_test)

# 评估模型
accuracy = accuracy_score(y_test, y_pred)
print(f"Random Forest 模型的准确率: {accuracy:.2f}")

# 打印分类报告
report = classification_report(y_test, y_pred, target_names=iris.target_names)
print("分类报告:\n", report)

代码说明:

  1. 数据集加载

    • 使用 load_iris() 函数加载鸢尾花数据集,这是一个经典的分类数据集,包含 150 个样本,4 个特征和 3 个类别。
  2. 数据集划分

    • 使用 train_test_split 将数据集划分为训练集(80%)和测试集(20%)。
  3. 创建 Random Forest 分类器

    • RandomForestClassifierscikit-learn 中实现的随机森林分类器。
    • n_estimators=100:设置使用 100 棵决策树。
    • max_depth=3:限制每棵决策树的最大深度,控制模型的复杂度以防止过拟合。
  4. 训练和预测

    • 通过 fit 方法训练随机森林模型。
    • 使用 predict 方法对测试集进行预测。
  5. 模型评估

    • 使用 accuracy_score 计算模型的准确率。
    • 使用 classification_report 打印更详细的分类报告,包括精确度(Precision)、召回率(Recall)、F1 分数等指标。

结果:

最终会输出模型在测试集上的准确率和分类报告。例如:

Random Forest 模型的准确率: 0.97
分类报告:
               precision    recall  f1-score   support

    setosa       1.00      1.00      1.00         10
    versicolor   0.94      1.00      0.97         11
    virginica    1.00      0.89      0.94         9

    accuracy                           0.97         30
   macro avg       0.98      0.96      0.97         30
weighted avg       0.97      0.97      0.97         30

在这个例子中,随机森林模型在鸢尾花数据集上表现良好。随机森林通过集成多个决策树并通过投票或平均来提升整体分类性能,同时能够处理高维数据并提供特征重要性评估。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值