Simulação de um problema de lucro
Você trabalha para uma empresa que fabrica equipamentos industriais. O preço de venda de cada equipamento é de US$ 100.000. Você também sabe que há uma forte correlação negativa entre o inflation_rate
e as vendas volume
. Essa relação é capturada pela matriz de covariância cov_matrix
, que está disponível no console para você.
A função profit_next_year_mc()
executa uma simulação de Monte Carlo que retorna o lucro esperado (em milhares de dólares), considerando a taxa média de inflação e o volume médio de vendas como argumentos. Você também precisará passar n
, o número de vezes que a simulação deve ser executada. A função foi carregada para você, e a definição está abaixo.
def profit_next_year_mc(mean_inflation, mean_volume, n):
profits = []
for i in range(n):
# Generate inputs by sampling from the multivariate normal distribution
rate_sales_volume = st.multivariate_normal.rvs(mean=[mean_inflation,mean_volume], cov=cov_matrix,size=1000)
# Deterministic calculation of company profit
price = 100 * (100 + rate_sales_volume[:,0])/100
volume = rate_sales_volume[:,1]
loan_and_cost = 50 * volume + 45 * (100 + 3 * rate_sales_volume[:,0]) * (volume/100)
profit = (np.mean(price * volume - loan_and_cost))
profits.append(profit)
return profits
Os seguintes pacotes foram importados para você: pandas
como pd
, numpy
como np
, scipy.stats
como st
, matplotlib.pyplot
como plt
, e seaborn
como sns
.
Este exercício faz parte do curso
Simulações de Monte Carlo em Python
Instruções do exercício
- Faça uma simulação de Monte Carlo executando
profit_next_year_mc()
500 vezes usando ummean_inflation
de2
e ummean_volume
de500
. - Visualize os resultados da simulação usando o site
displot
.
Exercício interativo prático
Experimente este exercício completando este código de exemplo.
# Run a Monte Carlo simulation 500 times using a mean_inflation of 2 and a mean_volume of 500
profits = profit_next_year_mc(____)
# Create a displot of the results
____
plt.show()