10.项目实战-交易数据异常检测

https://www.bilibili.com/video/av29439387

项目背景:信贷数据,是否是一笔正常、合理的贷款

方案:本case采用LR来作检测

1、样本不均衡解决方案:

主要有过采样、下采样

代码示例(下采样):

number_records_fraud = len(data[data.Class==1])
fraud_indeces = np.array(data[data.Class==1].index)

normal_indices = data[data.Class == 0].index

random_normal_indices = np.random.choice(normal_indices,number_records_fraud,replace=True)
random_normal_indices = np.array(random_normal_indices)

under_sample_indices = np.concatenate([fraud_indeces,random_normal_indices])

under_sample_dfata = data.iloc[under_sample_indices,:]

2、交叉验证和模型评估

train_test_split(),注意设置random_state

3、召回率和阈值:可以通过混淆矩阵来观察分布的变化

4、正则化:L1(权重系数的绝对值之和)和L2(权重系数的平方之和),可以遍历可能的C值来调整惩罚力度

5、过采样和SMOTE采样

from imblearn.over_sampling import SMOTE

oversample = SMOTE(random_state=0)

os_features,os_labels =  oversample.fit_sample(feature_train,label_train)

生成后的label为1的与label为0的数量一致

与下采样相比,过采样后得出的模型整体精度会高些,召回率会低点。建议采用过采样,数据越多越准确嘛

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值