Discrete Event Simulation in Python
Diogo Costa (PhD, MSc)
Adjunct Professor, University of Saskatchewan, Canada & CEO of ImpactBLUE-Scientific
Histogram
Matplotlib-package
import matplotlib.pyplot as plt
Gebruik: Maak een histogram van dataset data met 50 bins
plt.hist(data, bins=50)


Machine learning

In discrete-eventmodellen
Onze focus
Observaties en clustercentra

SciPy-methode
scipy.cluster.vq.kmeans()
Implementatie
import scipy
scipy.cluster.vq.kmeans(
obs, k_or_guess, iter=20, thresh=1e-05,
check_finite=True, *, seed=None)
obs is een numpy-arrayVoor k-means: Data whitening
obsobs met z'n std-dev
In SciPy
scipy.cluster.vq.whiten(
obs, check_finite=True)
obs is een numpy-arrayProcess 1
Package importeren
import scipy.cluster.vq as scvq
Whiten modelresultaten
white_data = scvq.whiten(model_results)
Vind 2 clusters (blauwe punten)
cluster_centroids, distortion =
scvq.kmeans(white_data, 2)
Technieken
Simpele methode
nobs = aantal observatiesnum_clusters =
int((model_results.shape[0]/2)**0.5)
22
from sklearn.metrics import silhouette_score
Bereken silhouette-scores voor k clusters
for k in range(2, 6):
model = KMeans(n_clusters=k)
model.fit(model_results)
pred = model.predict(model_results)
score = silhouette_score(model_results, pred)
Console-uitvoer
Silhouette Score for k = 2: 0.591
Silhouette Score for k = 3: 0.472
Silhouette Score for k = 4: 0.381
Silhouette Score for k = 5: 0.364
Silhouette Score for k = 6: 0.373
Resultaten interpreteren
score = 1score = -1score rond 0Discrete Event Simulation in Python