Télécharger la présentation
La présentation est en train de télécharger. S'il vous plaît, attendez
Publié parAloys Hardy Modifié depuis plus de 9 années
1
Simulation Ramon Puigjaner Universitat de les Illes Balears Palma, Espagne Université Paul Sabatier. Toulouse
2
Université Paul Sabatier. Toulouse. 2 INDICE YIntroduction YGénération de nombres aléatoires YOrganisation d’un simulateur YApproches pour l’obtention de résultats YConstruction des modèles
3
Université Paul Sabatier. Toulouse. 3 SIMULATION YIntroduction YGénération de nombres aléatoires YOrganisation d’un simulateur YApproches pour l’obtention de résultats YConstruction des modèles
4
Université Paul Sabatier. Toulouse. 4 SIMULATION YLa simulation est essentiellement une technique d’échantillonnage statistique contrôlé à partir d’un programme que représente le comportement dynamique de système à étudier. YLes contreparties de la libération des contraintes de modélisation sont: l un coût plus grand de préparation du modèle l un temps machine plus grand pour l’obtention des résultats.
5
Université Paul Sabatier. Toulouse. 5 SIMULATION YPuisqu’un système informatique est un automate à états discrets, la simulation sera à événements discrets mais avec des changements d’état à des instants aléatoires. YLes nouveaux problèmes sont: l la génération de nombres aléatoires l la gestion du temps simulé et des événements bloqués l l’extraction de résultats statistiques et estimation de ses intervalles de confiance
6
Université Paul Sabatier. Toulouse. 6 SIMULATION Les phases à suivre sont: l Formulation du modèle de simulation l Construction du modèle l Conception des expériences de simulation l Validation du modèle de simulation l Exécution des expériences de simulation et analyse des résultats.
7
Université Paul Sabatier. Toulouse. 7 INDICE YIntroduction YGénération de nombres aléatoires YOrganisation d’un simulateur YApproches pour l’obtention de résultats YConstruction des modèles
8
Université Paul Sabatier. Toulouse. 8 SIMULATION: Nombres aléatoires Trois sont les problèmes fondamentales à résoudre: l Génération de séquences uniformes l Vérification de l’aléatorieté des séquences uniformes l Génération de nombres aléatoires avec d’autres distributions.
9
Université Paul Sabatier. Toulouse. 9 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l Un générateur de nombres aléatoires (ou plus précisément de nombres pseudoaléatoires) est un algorithme que produit des séquences de nombres que suivent une distribution de probabilité uniforme et qu’ont un aspect aléatoire. l La génération se fait sur l’intervalle ]0, 1[.
10
Université Paul Sabatier. Toulouse. 10 SIMULATION: Nombres aléatoires YGénération de séquences uniformes Il peut être surprenant que les algorithmes de génération de nombres aléatoires soient basés sur une récurrence déterministe où chaque nombre est fonction du précédant. La vraie aléatorieté exige l’indépendance des successifs nombres générés; néanmoins le choix soigneux des paramètres de génération, permet obtenir des séquences avec une apparence tout à fait aléatoire.
11
Université Paul Sabatier. Toulouse. 11 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l La plupart des générateurs de nombres aléatoires uniformes sont du type congruentiel linéaire: X n + 1 = aX n + c (mod m) l m, le modulo, m > 0; a, le multiplicateur, 0 a < m; c, l’incrément, 0 c < m; X 0, la valeur initiale, 0 X 0 < m.
12
Université Paul Sabatier. Toulouse. 12 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l L’application de la récurrence produit une séquence de nombres entiers {X n } = X 1, X 2,... considérée comme de nombres aléatoires uniformes distribués entre 0 et m - 1. Les nombres aléatoires uniformes distribués dans l’intervalle ]0, 1[s’obtiennent par la division par m, U n = X n /m
13
Université Paul Sabatier. Toulouse. 13 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l Par exemple, la séquence obtenue pour m = 10 et X 0 = a = c = 7, est 7, 6, 9, 0, 7, 6, 9, 0,.... l Cet exemple met en évidence que la séquence congruentielle arrive toujours à une boucle. Afin que la séquence soit utile il faut que la période soit longue.
14
Université Paul Sabatier. Toulouse. 14 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l Le cas spécial de c = 0 mérite une attention spéciale permettant un processus de génération plus rapide. Cependant le choix de c = 0 raccourcit la période.
15
Université Paul Sabatier. Toulouse. 15 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l Le choix du modulo m doit se faire en tenant compte des caractéristiques suivantes: m doit être assez grand afin de permettre que la période le soit aussi. Le besoin que l’opération (aX n + c) mod m soit rapide. Donc, m doit être 2 puissance la longueur du mot en bits e; le calcul du reste devient une troncature. w = 2 e
16
Université Paul Sabatier. Toulouse. 16 SIMULATION: Nombres aléatoires YGénération de séquences uniformes Une autre technique est choisir comme modulo m = w ± 1, avec c = 0. Après le produit aX, le résultat est dans deux registres; le premier q (quotient de la division par w) et le deuxième r (reste de la division par w). Si m = w + 1 aX = q(w + 1) + (r - q) et (aX) mod(w + 1) serait égal à r - q ou à r - q + (w + 1) selon que r - q 0 ou r - q < 0, respectivement.
17
Université Paul Sabatier. Toulouse. 17 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l Le choix du multiplicateur et du modulo déterminent la longueur de la période et l’aspect aléatoire des nombres. l Ce choix doit être fait d ’accord avec une série de théorèmes que permettent une longue période. l Une longue période s’obtient si le modulo est une puissance d ’un nombre premier ou, encore mieux, s ’il est un nombre premier.
18
Université Paul Sabatier. Toulouse. 18 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l Dans les machines avec un mot de 32 bits, le choix évident serait m = 2 31. l Un générateur multiplicatif (c = 0) avec m = 2 31 a une période maximale de longueur m/4 =. 2 31 /4 = 2 29 et la longueur de la période peut dépendre aussi de la valeur initiale. l Si le modulo est premier, la période maximale possible est m - 1. Par chance, le plus grand premier plus petit que 2 31 est 2 31 - 1 = 2147483647.
19
Université Paul Sabatier. Toulouse. 19 SIMULATION: Nombres aléatoires YGénération de séquences uniformes l Cependant, les conditions qu’assurent une période maximale ne le font pas simultanément avec les bonnes caractéristiques d’aleatorieté. l Dans ce cas le choix du multiplicateur a = 7 5 satisfait les deux conditions. X n + 1 = 7 5 X n mod ( 2 31 - 1) = = 16807 X n mod (2147483647)
20
Université Paul Sabatier. Toulouse. 20 SIMULATION: Nombres aléatoires Vérification nombres aléatoires l Puisque les résultats d’une simulation dépendent d’une apparence d’aléatorieté, il faut vérifier le générateur à l’aide de plusieurs tests statistiques. l Chaque séquence doit être vérifiée avec soin. Il y a deux types de tests: tests empiriques pour un séquence de quelques nombres consécutifs. tests théoriques pour la totalité de la séquence.
21
Université Paul Sabatier. Toulouse. 21 SIMULATION: Nombres aléatoires Tests empiriques de vérification l Tests généraux employés: HChi 2 pour des distributions discrètes HKolmogorov-Smirnov pour des distributions continues
22
Université Paul Sabatier. Toulouse. 22 SIMULATION: Nombres aléatoires YTests empiriques de vérification l Il s ’agît d ’une batterie de tests, chacun décrivant une condition nécessaire d’aléatorieté. l On accepte par convention que si le générateur passe toute la batterie cela représente une condition suffisante d ’aléatorieté. l Chaque test est basé sur la description d ’une caractéristique intuitive d ’aléatorieté.
23
Université Paul Sabatier. Toulouse. 23 SIMULATION: Nombres aléatoires YTests empiriques de vérification l Le test d’équidistribution contrôle que la distribution uniforme de la séquence entre 0 et 1. l Le test serial consiste à vérifier que les paires de nombres consécutifs sont uniformément distribuées. On peut généraliser ce test à des triples, quadruples, etc., mais alors de nombre d’échantillons croit très rapidement.
24
Université Paul Sabatier. Toulouse. 24 SIMULATION: Nombres aléatoires YTests empiriques de vérification Le test des lacunes prétend examiner la longueur des "lacunes" entre apparitions de U j dans le domaine entre a et b, avec 0 a, b 1. On considère les longueurs des sous-séquences consécutives U j, U j + 1,..., U j + r où U j + r se trouve entre a et b mais non les autres U. Cette sous- séquence est une lacune de longueur r. Si p = b - a la distribution des longueurs doit suivre la distribution: p 0 = p, p 1 = p(1 - p), p 2 = p(1 - p) 2,..., p t - 1 = p(1 - p) t - 1,p t = (1 - p) t
25
Université Paul Sabatier. Toulouse. 25 SIMULATION: Nombres aléatoires YTests empiriques de vérification l Le test du poker considère groupes de cinq entiers successifs (Y 5j, Y 5j + 1,..., Y 5j + 4 ) et on observe lequel de ces sept possibilités coïncide avec le quintuple: Toutes différentes : abcde Paire: aabcd Double paire: aabbc Trio: aaabc Fool: aaabb Poker: aaaab Repoker: aaaaa
26
Université Paul Sabatier. Toulouse. 26 SIMULATION: Nombres aléatoires Tests empiriques de vérification l Le test du collectionneur observe la longueur des séquences Y j + 1, Y j + 2,..., Y j + r nécessaire pour obtenir un ensemble complet d’entiers (un élément dans chaque classe) entre 0 et d - 1.
27
Université Paul Sabatier. Toulouse. 27 SIMULATION: Nombres aléatoires Tests empiriques de vérification l Le test de la permutation découpe la séquence en n groupes de t éléments chacun, (U jt, U jt + 1,..., U jt + t - 1 ). Les éléments de chaque groupe peuvent avoir t! permutations relatives possibles toutes équiprobables. Par exemple, si t = 3, nous avons six permutations possibles U 3j < U 3j + 1 < U 3j + 2, ou U 3j < U 3j + 2 < U 3j + 1, ou U 3j + 1 < U 3j < U 3j + 2, ou U 3j + 1 < U 3j + 2 < U 3j, ou U 3j + 2 < U 3j < U 3j + 1, ou U 3j + 2 < U 3j + 1 < U 3j.
28
Université Paul Sabatier. Toulouse. 28 SIMULATION: Nombres aléatoires Tests empiriques de vérification l Test des monotonies ascendantes ou descendantes dans lesquelles on mesure sa distribution de longueurs. | 1 2 9 | 8 | 5 | 3 6 7 | 0 4 | Test du maximum de t: V j = max(U tj, U tj + 1,..., U tj + t - 1 ) suit la fonction de distribution F(x) = x t, avec 0 x 1.
29
Université Paul Sabatier. Toulouse. 29 SIMULATION: Nombres aléatoires Tests empiriques de vérification l Test des collisions: nous avons m urnes et nous lançons n balles au hasard, m etant beaucoup plus grand que n. La plupart des balles tombera dans des urnes vides, mais si une balle tombe dans une urne où il y a au moins une balle, alors nous disons que se produit une collision. Le test des collisions en compte le nombre l Test d ’autocorrélation effectué par calcul du coefficient d’autocorrélation.
30
Université Paul Sabatier. Toulouse. 30 SIMULATION: Nombres aléatoires Tests théoriques de vérification l Le test spectral est une façon théorique de tester les générateurs de nombres aléatoires. l Il considère la totalité de la séquence. l Si nous représentons sur un axe une séquence de nombres réellement aléatoires uniformément répartis entre 0 et 1, dans sa représentation dans un ordinateur, nous découvrirons qu’il y a des trous entre deux points consécutifs à cause de la représentation discrète des nombres.
31
Université Paul Sabatier. Toulouse. 31 SIMULATION: Nombres aléatoires Tests théoriques de vérification l Si nous représentons sur un plan des paires de valeurs d’un séquence de nombres réellement aléatoires dans sa représentation dans un ordinateur, nous découvrirons qu’ils se distribuent uniformément sur le carré unitaire et que la plus petite distance entre points est la même que celle qu’il y avait entre les points sur l’axe. l Le même arrive pour des triplets, quadruples, etc.
32
Université Paul Sabatier. Toulouse. 32 SIMULATION: Nombres aléatoires Tests théoriques de vérification l Si nous représentons tous les nombres d ’une séquence pseudo-aléatoire sur un axe, nous retrouverons la même structure qu’avec les nombres réellement aléatoires. l Si nous représentons tous les paires de valeurs pseudo- aléatoires dans le carré unitaire, nous découvrons que nous pouvons recouvrir tous les points avec un nombre réduit de lignes droites parallèles équidistantes; en outre, il y a plusieurs ensembles de droites recouvrant tous les points. La distance minimale entre droites est plus grande que dans le cas aléatoire pur.
33
Université Paul Sabatier. Toulouse. 33 SIMULATION: Nombres aléatoires Tests théoriques de vérification l Si nous considérons le même générateur en trois dimensions nous pouvons découvrir aussi des familles de plans équidistants recouvrant la totalité des points, dont la distance minimale est encore plus grande. l Le même arrive si on augmente la taille des groupes.
34
Université Paul Sabatier. Toulouse. 34 SIMULATION: Nombres aléatoires Tests théoriques de vérification l La différence essentielle entre les séquences périodiques et les vraiment aléatoires est que, puisque nous avons fait une troncature des nombres, la distance est la même dans toutes les dimensions, tandis que dans les séquences périodiques la augmente diminue quand la dimension fait aussi. l Le taux de croissance des distances nous donne une idée de la qualité du générateur.
35
Université Paul Sabatier. Toulouse. 35 SIMULATION: Nombres aléatoires Génération des lois non uniformes l La génération des nombres aléatoires selon une loi de distribution non uniforme peut être résolu par la distribution inverse. l Cependant cette fonction inverse n’est pas toujours calculable ou son calcul peut être difficile. Il faut disposer de méthodes pour générer des valeurs distribuées selon une loi de façon exacte, rapide, facile de programmer et économique en mémoire.
36
Université Paul Sabatier. Toulouse. 36 SIMULATION: Nombres aléatoires Génération des lois non uniformes l Ces méthodes peuvent être groupées en six classes non totalement disjointes: Hfonction inverse Hcomposition Hrefus-acceptation Hdécomposition Hcaractérisation Hcomparaison
37
Université Paul Sabatier. Toulouse. 37 SIMULATION: Nombres aléatoires YFonction inverse
38
Université Paul Sabatier. Toulouse. 38 SIMULATION: Nombres aléatoires YRefus-acceptation
39
Université Paul Sabatier. Toulouse. 39 SIMULATION: Nombres aléatoires YDécomposition l On représente la distribution de X par un mélange linéaire convexe de distributions d’une variable et faciles à générer. f X (x) = p 1 f 1 (x) +... + p k f k (x) l {p i } sont non négatives et sa somme est l’unité l {f i (x)} sont fonctions de densité de probabilité.
40
Université Paul Sabatier. Toulouse. 40 INDICE YIntroduction YGénération de nombres aléatoires YOrganisation d’un simulateur YApproches pour l’obtention de résultats YConstruction des modèles
41
Université Paul Sabatier. Toulouse. 41 SIMULATION: Organisation d’un simulateur YContrôle du temps dans un simulateur l Pour établir la temporisation et la synchronisation des événements simulés nous pouvons employer deux méthodes: temporisation synchrone ou avancement par des temps unitaires temporisation asynchrone ou avancement par des événements
42
Université Paul Sabatier. Toulouse. 42 SIMULATION: Organisation d’un simulateur YStructures de données dans un simulateur l Dans une simulation les changements d’état se produisent comme conséquence des événements. l L’état du système est représenté par un ensemble d’objets décrivant des entités (clients, serveurs, etc.) l Les rapports entre objets sont décrits à l’aide des structures de données telles que listes, files FIFO, piles, tableaux, etc.
43
Université Paul Sabatier. Toulouse. 43 INDICE YIntroduction YGénération de nombres aléatoires YOrganisation d’un simulateur YApproches pour l’obtention de résultats YConstruction des modèles
44
Université Paul Sabatier. Toulouse. 44 SIMULATION: Obtention de résultats Conditions initiales, transitoires et équilibre Choix de la dimension de l’échantillon Méthodes pour des échantillons indépendants
45
Université Paul Sabatier. Toulouse. 45 SIMULATION: Obtention de résultats Conditions initiales, transitoires et équilibre l L’objectif d’une simulation est la recherche de la performance du système en régime stationnaire ou permanent. l Il faut choisir les conditions initiales et détecter régimes transitoires. l Pour l ’étude d ’un régime stationnaire on doit initier la simulation dans un état qui soit, si possible, représentatif des conditions du régime permanent afin de réduire au maximum la durée du transitoire.
46
Université Paul Sabatier. Toulouse. 46 SIMULATION: Obtention de résultats Conditions initiales, transitoires et équilibre l Déterminer si le système a atteint le régime permanent n’es pas toujours simple, puisque ce régime permanent est défini par les probabilités des états et non par une simple valeur. l Le régime permanent étant une condition limite, il n’y a pas un instant précis à partir duquel on puisse considérer le système en équilibre. l La durée de la période transitoire dépend des conditions initiales.
47
Université Paul Sabatier. Toulouse. 47 SIMULATION: Obtention de résultats Conditions initiales, transitoires et équilibre l Initier la simulation dans un des états typiques accélère l’arrivée au régime permanent. l Il faut estimer sa durée afin d’éviter que les données collectées pendant cette période nuisent les résultats. l Idéalement il faut sélectionner les conditions initiales d’après la distribution en régime permanent (inconnue).
48
Université Paul Sabatier. Toulouse. 48 SIMULATION: Obtention de résultats Conditions initiales, transitoires et équilibre l Dans la pratique la recherche des conditions initiales se base dans Hou quelque connaissance préalable Hou les résultats de simulations pilote Hou des études préalables avec des modèles analytiques Hou par facilité de définition.
49
Université Paul Sabatier. Toulouse. 49 SIMULATION: Obtention de résultats Conditions initiales, transitoires et équilibre l Pour estimer sa durée il faut faire un certain nombre d’exécutions pilote à partir des mêmes conditions initiales et comparer les distributions observées à des instants différents de la simulation. l Pour ce faire il n’y a qu’à choisir pour chaque exécution pilote une valeur initiale différente X 0 du générateur des nombres aléatoires.
50
Université Paul Sabatier. Toulouse. 50 SIMULATION: Obtention de résultats Echantillons indépendants l Méthode des répétitions l Méthode des moyennes des lots l Méthode régénération Echantillons corrélés Méthode spectrale
51
Université Paul Sabatier. Toulouse. 51 SIMULATION: Obtention de résultats YMéthode des répétitions l On fait m exécutions indépendantes du modèle avec n observations dans chacune. l L’indépendance est atteinte par l’utilisation de différentes successions de nombres aléatoires dans chaque exécution à partir du même état initial. On peut considérer qu’on a obtenu un ensemble d’observations {Y i (j) } pour 1 i n et 1 j m; au total N = mn observations.
52
Université Paul Sabatier. Toulouse. 52 SIMULATION: Obtention de résultats YMéthode des répétitions l La moyenne des échantillons de la j-ième répétition sera
53
Université Paul Sabatier. Toulouse. 53 SIMULATION: Obtention de résultats YMéthode des répétitions La meilleure estimation de la moyenne de la population sera alors et la variance de l’échantillon
54
Université Paul Sabatier. Toulouse. 54 SIMULATION: Obtention de résultats YMéthode des répétitions l Si n est assez grand, la distribution des moyennes de chaque répétition tend vers la normale. Alors la distribution de la variable peut être approchée par une distribution t de Student avec m - 1 degrés de liberté.
55
Université Paul Sabatier. Toulouse. 55 SIMULATION: Obtention de résultats YMéthode des répétitions l L’intervalle de confiance est donné par Si m est grand, on peut remplacer la loi de Student par la normale; l’intervalle de confiance sera alors
56
Université Paul Sabatier. Toulouse. 56 SIMULATION: Obtention de résultats YMéthode des moyennes des lots (batch means) l Elle consiste à faire une exécution assez longue du modèle tout en partageant l’ensemble des observations de l’exécution en m lots de n observations. l Si m est assez grande les observations successives ne seront pas pratiquement pas corrélées. l Les formules sont identiques a celles de la méthode précédente.
57
Université Paul Sabatier. Toulouse. 57 SIMULATION: Obtention de résultats YMéthode des régénérations l On peut utiliser cette méthode régénérative si le système a une succession de points de régénération l Dans un point de régénération, le système se trouve dans les mêmes conditions d’état et dont tout ce qui s’est passé avant cet instant n’influence pas le futur. l Dans ce type de systèmes il n’y a pas de régime transitoire et la simulation est divisée en une séquence de blocs indépendants et également distribués.
58
Université Paul Sabatier. Toulouse. 58 SIMULATION: Obtention de résultats YMéthode des régénérations l Les problèmes de la méthode régénérative sont: Hdéterminer s’il y a des points de régénération Hs’il y en a, il faut que le système y retourne assez fréquemment l Les avantages de cette méthode sont: Hla certitude d’avoir des observations indépendantes, ce qui permet des meilleurs estimateurs. Hla non-existence de transitoires.
59
Université Paul Sabatier. Toulouse. 59 SIMULATION: Obtention de résultats YMéthode des régénérations l Trouver des points de régénération est très facile dans les réseaux ouverts, où le réseau vide l’est. l Dans les réseaux fermés la détermination de ces points est difficile et, en général, on ne connaît que des approches que n’incluent pas normalement les réseaux résultant de la modélisation des systèmes informatiques et téléinformatiques.
60
Université Paul Sabatier. Toulouse. 60 SIMULATION: Obtention de résultats YMéthode des régénérations l On veut estimer la valeur de quelque fonction r = E[f(X)]. l Chaque cycle génère une paire (Y i, d i ), où HY i est l’intégrale de f(X(t)) au long de l’i-ième cycle Hd i est la longueur de ce cycle. l Alors les paires de variables aléatoires (Y 1, d 1 ), (Y 2, d 2 ),..., (Y i, d i ),... sont indépendantes et identiquement distribuées
61
Université Paul Sabatier. Toulouse. 61 SIMULATION: Obtention de résultats YMéthode des régénérations l Si le simulateur passe par n points de régénération et on calcule les moyennes et les variances des Y et des d, et la covariance des deux séquences l Alors nous pouvons utiliser comme estimateur de r le quotient entre les moyennes des deux séquences
62
Université Paul Sabatier. Toulouse. 62 SIMULATION: Obtention de résultats YMéthode des régénérations l Une expression approchée de l’intervalle de confiance peut se déduire de la normalité asymptotique de la variable Y i - rd i : où
63
Université Paul Sabatier. Toulouse. 63 SIMULATION: Obtention de résultats YMéthode spectrale Pour l’étude de modèles de ce type il est conseillé de consulter un ouvrage spécialisé
64
Université Paul Sabatier. Toulouse. 64 INDICE YIntroduction YGénération de nombres aléatoires YOrganisation d’un simulateur YApproches pour l’obtention de résultats YConstruction des modèles
65
Université Paul Sabatier. Toulouse. 65 SIMULATION: Construction de modèles YLangages de simulation langages de programmation avec des extensions comme GASP (FORTRAN), SIMULA (ALGOL) ou SMPL (C). langages de simulation comme GPSS et SIMSCRIPT. paquets de simulation fermés orientés à des systèmes informatiques ou téléinformatiques comme MODARCH, NETWORK, OPNET, etc.
66
Université Paul Sabatier. Toulouse. 66 SIMULATION: Construction de modèles YLangages de modélisation l Langages de programmation structurés pour construire et traiter des modèles de réseaux de files d’attente par des: méthodes analytiques exactes et/ou approchées méthodes de simulation méthodes numériques markoviennes l Entre autres nous pouvons trouver QNAP2, RESQ, BEST-1, LQNS, etc.
Présentations similaires
© 2025 SlidePlayer.fr Inc.
All rights reserved.