Manajemen Risiko Kuantitatif dengan Python
Jamsheed Shorish
Computational Economist
asset_returnsportfolio_returns menggunakan weights portofolioportfolio_returns menjadi lossesnp.quantile() untuk losses pada mis. 95%
weights = [0.25, 0.25, 0.25, 0.25]portfolio_returns = asset_returns.dot(weights)losses = - portfolio_returnsVaR_95 = np.quantile(losses, 0.95)
norm dari scipy.statstotal_steps (1 hari = 1440 menit)Nmu dan simpangan baku sigma dari data portfolio_lossesfrom scipy.stats import normtotal_steps = 1440N = 10000mu = portfolio_losses.mean() sigma = portfolio_losses.std()
daily_loss untuk N runN runloss hasil simulasi Monte Carlonorm.rvs() untuk mengambil berulang dari distribusi Normal standarmu dan sigma diskalakan 1/total_stepsdaily_loss = np.zeros(N)for n in range(N):loss = ( mu * (1/total_steps) + norm.rvs(size=total_steps) * sigma * np.sqrt(1/total_steps) )
daily_loss kumulatif untuk setiap run nnp.quantile() untuk VaR pada mis. tingkat keyakinan 95% atas daily_loss
daily_loss = np.zeros(N) for n in range(N):loss = mu * (1/total_steps) + ... norm.rvs(size=total_steps) * sigma * np.sqrt(1/total_steps)daily_loss[n] = sum(loss)VaR_95 = np.quantile(daily_loss, 0.95)
e_covManajemen Risiko Kuantitatif dengan Python