风险评分分数转换

# 评分卡刻度 A、B
def cal_scale(score,odds,PDO):
    '''
    参数:
        odds: 设定的坏好比
        score: 在这个odds下的分数
        PDO: 好坏翻倍比
        model: 逻辑回归模型
    return:
        A,B
    '''
    B = PDO/np.log(2)
    A = score + B*np.log(odds)
    # base_score = A+B*model.intercept_[0]
    print('B: {:.2f}'.format(B))
    print('A: {:.2f}'.format(A))
    # print('基础分为:{:.2f}'.format(base_score))
    return A,B

def Pre2Score(pre,A,B):
    y = np.log(pre/(1-pre))
    return round(A-B*y)

A,B = cal_scale(725,0.05,25) # 假设基础分为50,odds为5%,PDO为10
data['score'] = data['score'].map((lambda x:Pre2Score(x,A,B)))

你可能感兴趣的:(风险评分分数转换)