IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> LightGBM分类实战 -> 正文阅读

[人工智能]LightGBM分类实战

目录

??导入模块??

🌜数据处理🌛

1??加载数据集

2??字符变量编码

3??分离数据集和标签

4??超参数设置

5??保存特征重要性

🔞交叉验证训练模型🔞

1??可视化特征重要性

2??模型预测


??导入模块??

import joblib
import warnings
import numpy as np
import pandas as pd
import seaborn as sns
import lightgbm as lgb
import matplotlib.pyplot as plt

from tqdm import tqdm_notebook
from sklearn.preprocessing import LabelEncoder
from sklearn.model_selection import KFold, train_test_split
from sklearn.metrics import precision_recall_fscore_support, roc_auc_score

warnings.filterwarnings("ignore")

🌜数据处理🌛

1??加载数据集

%%time
# 加载数据集
train = pd.read_csv("historic customer behavior.csv")
test = pd.read_csv("target customer.csv")
print("train shape : ", train.shape)
print("test shape : ", test.shape)

2??字符变量编码

# 输出 object 类型的列
for col in train.columns:
    if train[col].dtype == "object":
        print(col)



# LabelEncoder
for col in tqdm_notebook(train.columns):
    if train[col].dtype == "object":
        encoder = LabelEncoder()
        encoder.fit(list(train[col].values) + list(test[col].values))
        train[col] = encoder.transform(list(train[col].values))
        test[col] = encoder.transform(list(test[col].values))

3??分离数据集和标签

X = train.drop(['Risk_Flag'], axis=1)
y = train['Risk_Flag']

4??超参数设置

# params 超参数设置
params = {'learning_rate':0.05, #  学习率,默认设置为0.1,一般设置在0.05-0.1之间
          'boosting_type': 'gbdt', # 'dart', 'goss', 'rf'
          'objective': 'binary', # 任务:二分类
          'metric': 'auc', # 衡量标准
          'max_depth': 8, # 默认-1 : 不限制深度
          'num_leaves': 63, # 叶节点数量
          'lambda_l1': 1,
          'lambda_l2': 1,
          'min_child_samples': 100,
          'min_child_weight': 1,
          'feature_fraction':1,
          'bagging_fraction':1,
          'bagging_freq':2,
          "verbose" : -1, # 不显示信息
          'seed': 66, # 随机种子
          'is_unbalance':'True'
         }

5??保存特征重要性

# 创建DataFrame保存特征重要性
feature_importances = pd.DataFrame(index=None)
feature_importances['features'] = X.columns

🔞交叉验证训练模型🔞

# 5折交叉验证
folds = KFold(n_splits=5,shuffle=True,random_state=10)
splits = folds.split(X, y) # 分割成5份,前4份是训练集索引,最后1份是验证集索引


best_auc = 0
best_model = None

for fold, (train_indices, val_indices) in enumerate(splits):
    print('fold ', fold + 1)
    X_train_data, X_val_data = X.iloc[train_indices], X.iloc[val_indices] # 训练集, 验证集
    y_train, y_val = y.iloc[train_indices], y.iloc[val_indices] # 训练标签,验证标签

    
    train_dataset = lgb.Dataset(X_train_data, label=y_train) # 训练集
    val_dataset = lgb.Dataset(X_val_data, label=y_val) # 验证集
    
    lgb_model = lgb.train(params=params, # 超参数设置
                          train_set=train_dataset, # 训练数据
                          num_boost_round=1000, # 循环的轮数
                          valid_sets=val_dataset, # 验证数据
                          valid_names='validation', # 验证集名称
                          early_stopping_rounds=200,# 如果200轮后没有提升,就停止循环
                          verbose_eval=False) 
    # 保存特征重要性
    feature_importances[f'fold_{fold+1}'] = lgb_model.feature_importance()
    
    # 对验证集进行预测
    y_val_pred = lgb_model.predict(X_val_data)
    
    # 计算roc_auc
    roc_auc = roc_auc_score(y_val, y_val_pred)
    print(f" Fold {fold + 1} | AUC_ROC : { roc_auc * 100}%")
    print(f"{'-'*50}\n")
    
    # 判断是否是最优模型
    if roc_auc > best_auc:
        best_auc = roc_auc
        best_model = lgb_model

1??可视化特征重要性

feature_importances['average'] = feature_importances[[f'fold_{fold+1}' for fold in range(folds.n_splits-1)]].mean(axis=1)


# 可视化显示特征
plt.figure(figsize=(10, 6))
sns.barplot(data=feature_importances.sort_values(by='average', ascending=False), 
            x='average', 
            y='features')
plt.title("top features importance over {} folds average.".format(folds.n_splits))

2??模型预测

print("The best roc_auc : ", roc_auc)


# 对与test进行预测
pred = best_model.predict(test)


from collections import Counter
labels = np.round(pred) # np.round() 四舍五入
Counter(labels)

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-04 15:33:38  更:2022-03-04 15:36:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 1:59:39-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码