Kwantitatief risicobeheer in Python
Jamsheed Shorish
Computational Economist
asset_returnsportfolio_returns met portefeuille-weightsportfolio_returns om naar lossesnp.quantile() voor losses op bijv. 95% betrouwbaarheidsniveau
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 uit scipy.statstotal_steps (1 dag = 1440 minuten)Nmu en standaardafwijking sigma van portfolio_lossesfrom scipy.stats import normtotal_steps = 1440N = 10000mu = portfolio_losses.mean() sigma = portfolio_losses.std()
daily_loss-vector voor N runsN runsloss-vectornorm.rvs() om herhaald te trekken uit de standaardnormaalverdelingmu en sigma geschaald door 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 voor elke run nnp.quantile() om de VaR te vinden op bijv. 95% betrouwbaarheidsniveau over 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_covKwantitatief risicobeheer in Python