Simulazione a eventi discreti in Python
Diogo Costa (PhD, MSc)
Adjunct Professor, University of Saskatchewan, Canada & CEO of ImpactBLUE-Scientific
Questo aiuta a
Spazio dei parametri con l’aumento dei campioni



Esempio: esecuzione Monte Carlo per capire l’intervallo di output di un generatore di eventi basato su distribuzione normale (gaussiana)
import random as rd
import matplotlib.pyplot as plt
# Generating samples: Gaussian distribution
duration_sample = [rd.gauss(25, 5)
for i in range(5000)]
# Plotting
plt.scatter(duration_sample, np.r_[0:5000],
marker='.', c=duration_sample, cmap='CMRmap')
plt.xlabel("Duration [min]")
plt.ylabel("Monte Carlo Runs")
Visualizzazione dei risultati

Obiettivo principale

L'incertezza nella durata di ogni processo si propaga nel sistema
Produce traiettorie di modello diverse
Chiamata “Response Envelope”
Esempio:
n_trajectories = 50
process_1 = {"Name": "Raw_material",
"OperationTime": 20,
"MaxDelayTimePercent": 10}
process_2 = {"Name": "Unloading",
"OperationTime": 15,
"MaxDelayTimePercent": 5}

Simulazione a eventi discreti in Python