Gem-graph/readme.md

189 lines
13 KiB
Markdown
Raw Normal View History

# **GE**o-**M**etric-**GRAPH** (gem-graph)
2021-03-28 16:23:21 +02:00
### Un graphe géométrique est un graphe dont les nœuds ont des coordonnées dans un espace.
2021-03-28 16:23:21 +02:00
2021-08-30 20:32:27 +02:00
### Les graphes géométriques peuvent être utilisés pour représenter une grande variété d'états. Ces états sont dessinés dans l'espace au moyen de liens allant d'un point de l'espace à un autre.
### Les réécritures successives de ces états par un automate permettent de modéliser des phénomènes complexes.
### 'gem-graph' est un logiciel qui permet d'éditer ces états et ces réécritures (ou transitions) et d'exécuter l'automate ainsi créé pour l'observer.
##### Des flèches, éventuellement superposées, peuvent être utilisées comme liens. On parle alors de multigraphes dirigés.
2021-04-01 10:39:40 +02:00
---
2021-10-01 23:50:14 +02:00
### Les phénomènes complexes peuvent être définis comme ceux où un grand nombre d'objets de formes et de propriétés très diverses interagissent d'un grand nombre de façons différentes.
2021-08-30 20:32:27 +02:00
Même si les interactions particulières entre certains de ces objets ont pu être isolées, étudiées expérimentalement et décrites au moyen d'un modèle simple, le fonctionnement de l'ensemble est difficile à modéliser pour au moins deux raisons:
2021-04-02 16:44:15 +02:00
2021-08-30 20:32:27 +02:00
1) - Certains phénomènes sont rapides et d'autres lents. Certains sont localisés et d'autres globaux.
> En essayant de les représenter tous simultanément, avec la même précision et à la même échelle, on est limité :
2021-08-03 00:23:05 +02:00
> * soit par la puissance de calcul s'il faut tout décrire en détail,
2021-08-30 20:32:27 +02:00
> * soit par des approximations qui ne permettent pas de décrire avec une précision suffisante certains phénomènes qui, bien que très rapides ou très localisés, ont des conséquences majeures sur l'évolution de l'ensemble.
> Ce problème est celui de la 'granularité' (temporelle et spatiale).
2021-08-03 00:23:05 +02:00
2021-07-19 17:27:02 +02:00
2021-08-30 20:32:27 +02:00
2) - Toute description non spatiale doit nommer les entités sur lesquelles elle opère pour pouvoir établir des relations entre elles.
> Or, lorsque le nombre de ces entités augmente, le nombre de leurs relations ou interactions augmente plus rapidement encore.
> Ce problème est celui de l'explosion combinatoire.
2021-08-03 00:23:05 +02:00
> * Il peut suffire, par exemple, d'une équation pour représenter une relation entre un petit nombre d'objets, mais le nombre d'équations nécessaires pour décrire toutes les relations en jeu dans l'ensemble du système est tel qu'il n'est plus possible de les résoudre simultanément.
2021-08-30 20:32:27 +02:00
> * Si l'on utilise un modèle numérique, un grand nombre de règles sera nécessaire. Il sera alors difficile de les écrire de façon homogène, de veiller à ce qu'elles ne se contredisent pas ou ne s'appliquent pas à des situations ou des objets pour lesquels elles n'avaient pas été conçues.
2021-08-03 00:23:05 +02:00
2021-08-30 20:32:27 +02:00
- Dans tous les cas, si deux calculs successifs partant du même état donnent des résultats différents, le modèle devient inexploitable.
2021-04-02 16:44:15 +02:00
2021-08-03 00:23:05 +02:00
---
2021-07-19 17:27:02 +02:00
##### gem-graph permet d'aborder ces deux difficultés en dessinant les objets au lieu de les nommer:
2021-10-01 23:12:22 +02:00
* L'espace et le temps sont les axes d'un référentiel discret, uniforme et cartésien.
* La topologie, la dimension et la magnitude de l'espace ne sont pas prédéfinies.
Ce sont des paramètres choisis par le concepteur du modèle.
* Dans cet espace peuvent être dessinés une multitude d'états.
Ces états sont tous des graphes géométriques.
Leurs liens peuvent être pondérés et orientés.
* Les états peuvent être interprétés comme:
2021-07-19 17:27:02 +02:00
- des objets (parties connexes isolées du graphe),
2021-10-01 23:12:22 +02:00
- des situations (positions relatives des objets) ou
- des annotations (décrites plus loin) qui écrivent, dans l'espace même,
2021-08-30 20:32:27 +02:00
des informations relatives aux objets ou aux situations auxquels elles sont connectées.
2021-11-17 15:40:32 +01:00
---
##### Un ensemble de transitions permet de réécrire chacun de ces états:
2021-11-17 16:19:40 +01:00
* Les objets et les situations dessinés sont réécrits sans qu'il soit nécessaire de les nommer.
2021-11-17 15:40:32 +01:00
* Ces réécritures (ou transitions) peuvent être locales, asynchrones et aléatoires.
* Le passage obligatoire par un état intermédiaire peut permettre de représenter une cause et un effet.
* Toutes les règles de réécriture, parcequ'elles n'opèrent que sur un seul symbole, ont le même format.
* L'ensemble des réécritures (ou versions) successives constitue l'histoire de la simulation.
2021-08-03 00:23:05 +02:00
---
2021-11-17 15:40:32 +01:00
2021-11-17 16:19:40 +01:00
##### Les informations statiques (états) et les informations dynamiques (transitions) sont toujours strictement séparées:
2021-11-17 15:40:32 +01:00
* Cette séparation permet d'écrire les règles de transition exclusivement comme des associations de transitions élémentaires.
2021-07-19 17:27:02 +02:00
* Une transition élémentaire associe:
- une seule condition (combien de liens y a-t-il à cet endroit? à comparer à un nombre prédéfini)
- une seule assignation (écrire un nombre 'n' de liens à cet endroit)
2021-08-03 00:40:38 +02:00
* Les règles de transition, ainsi écrites, peuvent ainsi être automatiquement évaluées, comparées, représentées, éditées et regroupées sous des formes diverses.
* Cette homogéneité d'écriture n'exclut cependant pas l'utilisation d'autres types de conditions et d'assignations élémentaires en cas d'association à d'autres modèles ou pour l'envoi de résultats de mesure (voir plus loin).
2021-08-03 00:23:05 +02:00
---
2021-11-17 15:40:32 +01:00
2021-11-17 16:19:40 +01:00
##### Les objets sont tous dessinés à la même échelle mais avec un niveau de détail variable:
* La réécriture de graphes géométriques permet donc d'associer dans un même espace des descriptions de granularité différente:
* Ces descriptions peuvent éventuellement être approchées par des représentations vectorielles. Des annotations sont possibles et facilitées.
* Les propriétés d'intérêt peuvent être détaillées sans qu'il soit nécessaire pour cela de détailler la totalité du reste.
* Il est donc possible de décrire simultanément des états et des phénomènes de complexité différente.
2021-12-24 16:19:12 +01:00
De nouvelles propriétés d'intérêt peuvent être ajoutées ou retranchées du modèle à tout moment.
* Les bords des objets peuvent être représentés (dessinés) par leur probabilité de présence.
2021-11-17 16:19:40 +01:00
---
##### Parceque le référentiel privilégie certaines directions, la symétrie de rotation est perdue:
* L'utilisation d'un référentiel introduit nécéssairement des directions privilégiées qui brisent la symétrie de rotation. Le dessin d'un objet n'est alors conservé que lorsqu'il est tourné d'un angle égal à celui qui sépare ces directions. Des approximations sont donc nécessaires pour restaurer l'isotropie.
* Elle peuvent être réalisées en associant à chaque objet un ensemble de dessins 'ad hoc' différemment orientés et/ou en produisant ces dessins à partir de représentations vectorielles.
* Elles nécéssitent qu'il y ait autant de règles de transition qu'il y a de dessins d'un même objet.
2021-08-03 00:23:05 +02:00
---
2021-11-17 15:40:32 +01:00
##### Des annotations peuvent être associés aux dessins des objets ou des situations:
* Elles sont écrites dans l'espace au moyen des mêmes symboles que les dessins qu'elles commentent ou précisent.
* Leur forme, leur étendue, le nombre de liens superposées utilisées pour les dessiner sont des paramètres choisis par le concepteur du modèle.
* Ces paramètres sont indépendants et peuvent donc être combinés de diverses manières. Le nombre d'annotations possibles est ainsi théoriquement illimité.
* Ces annotations peuvent donner accès à des informations difficiles à encoder par la simple description des formes:
identités, noms, adresses, pointeurs, liens, quantités, poids ou valeurs diverses concernant des propriétés d'intérêt.
* Le point important, ici, est que ces annotations sont écrites dans les états au moyen des mêmes symboles que les dessins.
2021-08-03 00:40:38 +02:00
Leur lecture et leur réécriture ne portent donc pas atteinte à l'homogénéité des règles.
2021-08-03 00:23:05 +02:00
---
2021-11-17 15:40:32 +01:00
##### Chaque réécriture est un cycle de calcul élémentaire effectué par un thread opérant indépendemment des autres dans un espace local préalablement préempté:
* Tous les espaces locaux ont la même étendue telle que toutes les règles de transition puissent y être exécutées.
* L'emplacement et l'orientation de chaque nouvel espace local sont choisis par le scheduler (au hasard ou par un autre algorithme) dans l'espace global.
Puis le scheduler crée le thread qui va effectuer le calcul.
* Chaque thread compare alors l'état de l'espace local où il opère aux conditions énoncées par les diverses règles de transition.
2021-11-17 16:19:40 +01:00
- Si toutes les conditions d'une règle sont satisfaites, elle s'applique.
- Si plusieurs règles partagent le même ensemble de conditions, l'une d'entre elles est choisie (au hasard ou par un autre algorithme).
- Si les conditions d'une règle sont satisfaites mais que les conditions d'une autre règle, qui en comporte davantage, sont également satisfaites, la règle la plus complète s'applique.
- Une fois la règle choisie, ses prescriptions s'appliquent à l'état global.
- Le thread qui a achevé l'ensemble de ce calcul est alors détruit et la préemption sur cet espace local est levée.
2021-08-03 00:23:05 +02:00
---
2021-11-17 15:40:32 +01:00
2021-11-17 16:19:40 +01:00
##### Les règles de transition peuvent être regroupées en arbres:
2021-11-17 15:40:32 +01:00
* La structure de ces arbres diffère selon leur fonction (exécution du calcul, classification choisie par l'utilisateur,...).
2021-11-17 16:19:40 +01:00
* Ils peuvent être édités.
* Ils peuvent servir à activer / désactiver des règles ou groupes de règles lors de la recherche d'erreurs durant la fabrication d'un modèle.
* Ils servent à représenter l'ensemble des conditions des règles dans le fichier XML où est enregistré un modèle.
* Ils permettent de transmettre au serveur un ordre de parcours optimisé des sites de l'espace local (ou espace des conditions).
2021-04-01 10:39:40 +02:00
---
2021-11-17 15:40:32 +01:00
2021-11-17 16:19:40 +01:00
##### Un gem-graph peut être associé à d'autres modèles représentant des bosons et/ou de fermions dans un espace en fonction du temps:
2021-11-17 15:40:32 +01:00
2021-11-17 16:19:40 +01:00
* Après superposition des temps et espaces de ces modèles à ceux du gem-graph, leurs variables locales intensives (températures, pressions, concentrations, débits, flux, section efficace, etc ...) peuvent être lues et écrites par le gem-graph au moyen de conditions et d'actions spécifiques. Ces lectures / écritures permettent la cohérence de l'ensemble des modèles pendant la durée du calcul.
2021-07-19 17:27:02 +02:00
2021-04-02 16:44:15 +02:00
---
2021-11-17 15:40:32 +01:00
2021-11-17 16:19:40 +01:00
##### Plusieurs modèles de gem-graph peuvent être additionnés (états et transitions) si leurs paramètres d'espace et de temps sont compatibles:
* L'addition de leurs états et celle de leurs règles sont des processus distincts qui peuvent être assistés par des algorithmes de merging spécifiques.
---
###### Des graphes non géométriques peuvent être extraits des gem-graph afin de faciliter leurs comparaisons et optimisations.
* Possible application de l'IA.
2021-04-06 10:19:44 +02:00
2021-07-19 17:27:02 +02:00
---
2021-11-17 15:40:32 +01:00
##### Opérations sur les gem-graph:
2021-04-06 12:26:28 +02:00
> addition - soustraction (les états et transitions changent; les propriétés qui définissent le graphe demeurent inchangées)
> expansion: par association / combinaison à d'autres modèles (la nature des états et des transitions change)
> réduction: par extraction d'un sous-ensemble de propriétés (ex: > graphes non géométriques)
2021-11-17 16:19:40 +01:00
---
"""Locos, formas modumque cohérentiae omium rerum status depingit. Nihil Aliud comprend.
Eas res praecepta movet aut transformat. Nihil aliud facit. Quaedam transforme en sua potestate sunt.
Aliae transforme alii succedere debent.
Interpositus status inter illas et istas jacet.
Ab antecedente statu primarum ad sequentem statum secundarum iter nullius est nisi per suorum interpositum statum."""
2021-12-24 16:13:31 +01:00
---
##### Les automates spatiaux sont les automates dont les états sont des états d'un espace.
Leurs règles de transition transforment donc un état d'un espace en un autre état d'un espace.
Plusieurs types de restrictions permettent de différencier et de classer les automates spatiaux.
- L'espace de départ et celui d'arrivée peuvent être semblables (avoir des propriétés identiques) ou non.
- Les espaces peuvent être discrets ou non, finis ou non.
- Dans le cas des espaces discrets et finis, chaque transition peut concerner une ou plusieurs unités de l'espace.
- Les unités de l'espace peuvent 'contenir' un booléen, un entier ou une approximation d'un nombre réel.
NB Si elle ne contiennent rien, seule la forme de l'espace peut être modifiée.
- ... (liste non limitative)
##### Equivalence des automates cellulaires et des gem-graph.
Les règles des automates cellulaires (CA) ne modifient qu'une case à la fois et ces cases contiennent des booléens.
Les règles des gem-graph (GG) modifient l'état de plusieurs cases à la fois et ces cases contiennent des entiers.
Comme il est possible de coder n'importe quel entier par des booléens, tout GG peut être simulé par un CA.
Comme il est possible de coder n'importe quel booléen par un entier, tout CA peut être simulé par un GG.
Il est plus facile de simuler un CA par un GG que l'inverse.
---
A chaque espace peut être associé un nombre entier unique. Cet entier contient toute l'information nécéssaire et suffisante pour reconstituer cet espace.
Toutes les règles de transition d'un état d'un espace à un autre état consistent donc en l'association de deux nombres entiers codant l'un pour l'état de l'espace de départ et l'autre pour celui de l'arrivée. A chaque règle de transition peut donc être associée un entier unique codant pour cette association.
---
2021-11-17 16:19:40 +01:00
2021-04-06 12:26:28 +02:00