Python ile Kredi Riski Modellemesi
Michael Crabtree
Data Scientist, Ford Motor Company
# Test edilecek tüm kabul oranlarını ayarlayın
accept_rates = [1.0, 0.95, 0.9, 0.85, 0.8, 0.75, 0.7, 0.65, 0.6, 0.55,
0.5, 0.45, 0.4, 0.35, 0.3, 0.25, 0.2, 0.15, 0.1, 0.05]
# Eşikler ve kötü oranları saklamak için listeler oluşturun
thresholds = []
bad_rates = []
for rate in accept_rates:
# Eşiği hesaplayın
threshold = np.quantile(preds_df['prob_default'], rate).round(3)
# Eşik değerini listeye kaydedin
thresholds.append(np.quantile(preds_gbt['prob_default'], rate).round(3))
# Eşiği uygulayarak loan_status'u yeniden atayın
test_pred_df['pred_loan_status'] = \
test_pred_df['prob_default'].apply(lambda x: 1 if x > thresh else 0)
# Kabul edilen krediler: tahmini temerrütsüzler
accepted_loans = test_pred_df[test_pred_df['pred_loan_status'] == 0]
# Kötü oranı hesaplayıp kaydedin
bad_rates.append(np.sum((accepted_loans['true_loan_status'])
/ accepted_loans['true_loan_status'].count()).round(3))
strat_df = pd.DataFrame(zip(accept_rates, thresholds, bad_rates),
columns = ['Acceptance Rate','Threshold','Bad Rate'])
len() veya .count() kullanılabilirloan_amntloan_amnt kadar zarar olduğu varsayılır# Temerrüt olasılığı (PD)
test_pred_df['prob_default']
# Temerrütte maruziyet = kredi tutarı (EAD)
test_pred_df['loan_amnt']
# Temerrütte zarar = tam zarar için 1.0 (LGD)
test_pred_df['loss_given_default']
Python ile Kredi Riski Modellemesi