Monte Carlo Simulations in Python
Izzy Weber
Curriculum Manager, DataCamp
Multinomial distribution
Example: simulating the results of flipping a biased coin
scipy.stats.multinomial.rvs()
Multivariate normal distribution
Example: simulating price and demand
scipy.stats.multivariate_normal.rvs()
Simulation:.rvs(n, p, size)
50 [0.2, 0.8]500 results = st.multinomial.rvs(50, [0.2, 0.8], size=500)df_results=pd.DataFrame( {"Head":results[:, 0], "Tail":results[:, 1]}) sns.pairplot(df_results)

Simulation: .rvs(mean, size)
[2, 6] 500 results=st.multivariate_normal.rvs( mean=[2, 6], size=500)df_results=pd.DataFrame( {"Price":results[:, 0], "Demand":results[:, 1]}) sns.pairplot(df_results)


Example:
df_historical.cov()
| | Price | Demand |
|--------|-----------|----------|
| Price | 0.920545 | -0.85578 |
| Demand | -0.855780 | 0.98417 |
Simulation: .rvs(mean, size)
[2, 6]500np.array([[1, -0.9], [-0.9, 1]])cov_mat = np.array([[1,-0.9], [-0.9,1]]) results = st.multivariate_normal.rvs( mean=[2,6], size=500, cov=cov_mat)df_results = pd.DataFrame( {"Price":results[:,0], "Demand":results[:,1]}) sns.pairplot(df_results)

Monte Carlo Simulations in Python