Accueil > > > JEU DE LA VIE
JEU DE LA VIE
Information sur la source
Description
Le "Jeu de la Vie", conçu par le mathématicien John Horton Conway en 1970, correspondant à une simulation algorithmique d'une population de cellules "vivantes" représentées comme les cases d'une matrice (cf. la page correspondante sur Wikipedia pour plus d'infos). L'utilisateur fournit un état initial de la population de cellules sous la forme du nom d'un fichier texte. Dans ce fichier se trouve une série de lignes formées uniquement des caractères '1' (qui représente une case de la matrice occupée par une cellule) et '0' (qui représente une case vide). La taille de la matrice n'est donc pas explicitement fournie, mais peut être aisément déduite par analyse du nombre de lignes et de colonnes de ce fichier. Par exemple, voici le contenu du fichier life.txt utilisé plus loin, dans l'exemple d'exécution. Ce fichier définit une matrice de taille 9x3 dans laquelle seule la case centrale est occupée par une cellule : 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 Le but du programme est de simuler l'évolution de cette population en fonction des règles de naissance et de décès, en affichant à l'écran les états successifs de la population. Reprenant le principe qui avait été mis en oeuvre dans le programme fiboplus (cf. exercice B4), l'utilisateur peut ajuster le fonctionnement de la simulation en spécifiant trois autres paramètres optionnels : un entier n qui représente le nombre d'étapes de simulation à effectuer (n=10, par défaut), une chaîne de caractères birth qui représente les règles de naissance (birth='000100000', par défaut) et enfin, une chaine de caractères death qui représente les règles de décès (death='001100000', par défaut). A chaque étape de simulation, pour chaque case de la matrice, on compte le nombre de cases voisines occupées par une cellule, puis en fonction des règles de naissance et de décès, l'état de chaque case peut changer comme indiqué ci-dessous. Après avoir traité toutes les cases, l'étape de simulation est achevée et on recommence de manière itérative jusqu'à avoir effectué les n étapes de simulation demandées par l'utilisateur. Les règles de naissance s'appliquent uniquement aux cases vides. Elles sont spécifiées par le contenu de la variable birth, qui est une chaîne formée de 9 caractères pouvant prendre les valeurs '0' (i.e. "pas de naissance") ou '1' (i.e. "naissance"). Le premier caractère de birth s'applique aux cases qui ne possèdent pas de cases voisines occupées, le second à celles qui ont 1 case voisine occupée, et ainsi de suite, jusqu'à la dernière qui s'applique à celles qui ont 8 cases voisines occupées. Ainsi, la valeur par défaut de birth égale à '000100000', signifie que les naissances ne se produisent que sur les cases vides possédant exactement 3 voisines occupées. Cette valeur par défaut correspond à la règle initialement proposée par Conway. Les règles de décès s'appliquent uniquement aux cases occupées. Elles sont spécifiées de manière similaire, par le contenu de la variable death, qui est une chaîne formée de 9 caractères pouvant à nouveau prendre les valeurs '0' (i.e. "décès") ou de '1' (i.e. "survie"). Ainsi, la valeur par défaut de death égale à '001100000', signifie qu'un décès se produit aussi bien sur une case possédant moins de 2 voisines occupées (décès par isolement) que sur celles possédant plus de 3 voisines occupées (décès par étouffement). Là encore, la valeur par défaut correspond à la règle initialement proposée par Conway.
Source
- def main():
- while True:
- command= raw_input("<hello>enter command in \" \":")
- list = command.split()
- seting_step = int(list[1])
- file = list[0]
- birth= list[2]
- death= list[3]
- matrice = init_mat(file)
- matrice_of_len = []
- step = 0
- while(step <= seting_step):
- print 'Step', step
- print_mat(matrice)
- matrice_of_len = aux(matrice)
- birth_or_death(matrice,matrice_of_len,birth,True)
- birth_or_death(matrice,matrice_of_len,death,False)
- step = step + 1
-
- def aux(matrice):
- tmp =[]
- for i in range(len(matrice)):
- tmp1 =[]
- for j in range(len(matrice[0])):
- tmp1.append(oqp(matrice, i, j))
- tmp.append(tmp1)
- return tmp
-
- def birth_or_death(matrice, matrice_of_len,b_or_d,test):
- c ='0'
- if(test):
- c = '1'
- for i in range(len(matrice)):
- for j in range(len(matrice[0])):
- if(matrice[i][j] !=c):
- matrice[i][j] = b_or_d[matrice_of_len[i][j]]
-
- def print_mat(matrice):
- lig_len = len(matrice)
- col_len = len(matrice[0])
- for i in range(lig_len):
- for j in range(col_len):
- print matrice[i][j],
- print
-
- def init_mat(fic):
- matrice = []
- file = open(fic,'r')
- line = file.readlines()
- for i in range(len(line)):
- matrice.append(line[i].split())
- file.close();
- return matrice
-
- def oqp(matrice,lig, col):
- compt = 0
- ligne =len(matrice)
- colonne = len(matrice[0]) -1
- if(lig < ligne -1):
- if(col != 0):
- if(int(matrice[lig + 1][col -1]) == 1):
- compt = compt + 1
- if(int(matrice[lig + 1][col]) == 1):
- compt = compt + 1
- if(col != colonne):
- if(int(matrice[lig + 1][col +1]) == 1):
- compt = compt + 1
- if(col != colonne ):
- if(int(matrice[lig ][col +1]) == 1):
- compt = compt + 1
- if(col != 0):
- if(int(matrice[lig ][col - 1]) == 1):
- compt = compt + 1
- if(lig != 0):
- if(col != 0):
- if(int(matrice[lig-1][col-1]) == 1):
- compt = compt + 1
- if(col != colonne):
- if(int(matrice[lig - 1][col+1]) == 1):
- compt = compt + 1
- if(int(matrice[lig - 1][col]) == 1):
- compt = compt + 1
- return compt
def main():
while True:
command= raw_input("<hello>enter command in \" \":")
list = command.split()
seting_step = int(list[1])
file = list[0]
birth= list[2]
death= list[3]
matrice = init_mat(file)
matrice_of_len = []
step = 0
while(step <= seting_step):
print 'Step', step
print_mat(matrice)
matrice_of_len = aux(matrice)
birth_or_death(matrice,matrice_of_len,birth,True)
birth_or_death(matrice,matrice_of_len,death,False)
step = step + 1
def aux(matrice):
tmp =[]
for i in range(len(matrice)):
tmp1 =[]
for j in range(len(matrice[0])):
tmp1.append(oqp(matrice, i, j))
tmp.append(tmp1)
return tmp
def birth_or_death(matrice, matrice_of_len,b_or_d,test):
c ='0'
if(test):
c = '1'
for i in range(len(matrice)):
for j in range(len(matrice[0])):
if(matrice[i][j] !=c):
matrice[i][j] = b_or_d[matrice_of_len[i][j]]
def print_mat(matrice):
lig_len = len(matrice)
col_len = len(matrice[0])
for i in range(lig_len):
for j in range(col_len):
print matrice[i][j],
print
def init_mat(fic):
matrice = []
file = open(fic,'r')
line = file.readlines()
for i in range(len(line)):
matrice.append(line[i].split())
file.close();
return matrice
def oqp(matrice,lig, col):
compt = 0
ligne =len(matrice)
colonne = len(matrice[0]) -1
if(lig < ligne -1):
if(col != 0):
if(int(matrice[lig + 1][col -1]) == 1):
compt = compt + 1
if(int(matrice[lig + 1][col]) == 1):
compt = compt + 1
if(col != colonne):
if(int(matrice[lig + 1][col +1]) == 1):
compt = compt + 1
if(col != colonne ):
if(int(matrice[lig ][col +1]) == 1):
compt = compt + 1
if(col != 0):
if(int(matrice[lig ][col - 1]) == 1):
compt = compt + 1
if(lig != 0):
if(col != 0):
if(int(matrice[lig-1][col-1]) == 1):
compt = compt + 1
if(col != colonne):
if(int(matrice[lig - 1][col+1]) == 1):
compt = compt + 1
if(int(matrice[lig - 1][col]) == 1):
compt = compt + 1
return compt
Conclusion
Une evolution possible de ce code est de le mettre en mode graphique avec Tkinter. Je sais pas quand est ce que je commence mais ca va pas tarder.
Pour executer faire: >>>main() life.txt 4 010100000 111100000 (par exemple)
Historique
- 24 janvier 2009 18:16:38 :
- c'etait pour ajouter la maniere d'executer le progamme
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
jeu de la vie [ par dia100daly ]
je veux poster un code. Mais j'aimerai savoir si c'etait vraiment la peine car c'est la première fois. Pour plus de détail voir sur Wikipédia ( jeu de
modification de jeu morpion en python [ par apprenti2008 ]
salut a tous ! SVP j'ai vraiment besoin d'aide , je suis en première année MASS , le prof nous a demander de créer un jeu morpion en python , le princ
serveur local redirigé vers page web [ par alix20 ]
Bojour à tous,voilà, je suis complètement débutante en python (je découvre python grace à Swinnen) et j'ai une question qui semblera peut-être ridicul
Python et C++ [ par CoMpLeX ]
Voila je souhaiterai interfacer une appli python et c++ de la manière suivante : Un script python que je lance depuis un programe c++, et qui se comp
comparaison adresse reseau [ par carlito84 ]
Bonjour tout le monde, Voilà je dois écrire un script sur python qui me permette de comparer des adresses reseau entre elles du type: @1 = x1.x
python+bibliotheque [ par samuray07 ]
salam; à l'aide s'il vous plait:on me demande une application faisant la "gestion d'une bibliotheque" developpée en <font color="#ff00
Ouvrir une page web avec mozilla avec python [ par Shakan972 ]
Bonsoir tout le monde je souhaiterais savoir la manière d'ouvrir une page web à l'aide de python et cela sous mozilla.Je sais en effet que la commande
executer Python a distance [ par xeolin ]
J'ai installer python sur mon iTouch, et j'ai essayer de faire un petit script, mais je n'y arrive pas. (il n'y a aucune difference entre la version i
Problme d'intallation gadfly [ par Thomeux ]
Bonjour,Je n'arrive pas a installer le module gadfly sur mon pc(windows XP)J'ai effectué ce quio est écrit dans le livre de Swinnen, mais l'invite de
chargement d'une image [ par panthere007 ]
Hellohello je voudrai mettre une image de fond dans une fenêtre (caneva ?) pour ensuite placer mes control par dessus j'ai pas mal chercher mai on dir
|
Derniers Blogs
IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc REACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITERREACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITER par Groc
Une mauvaise utilisation de rx lors de l'écriture d'une couche d'accès à des services peut conduire à des cas embarassants avec des erreurs mal gérées, des appels qui ne partent lorsqu'ils le devraient, et même des résultats incorrects . le tout nuis...
Cliquez pour lire la suite de l'article par Groc SHAREPOINT BLOG SITE, PROBLèME D'ARCHIVESSHAREPOINT BLOG SITE, PROBLèME D'ARCHIVES par junarnoalg
Dernièrement, nous avons migré le site
myTIC
vers un nouveau serveur SharePoint 2010. Dans les contenus que nous vouloins récupérer, nous avions un certain nombre de blogs.
Nous avons utilisé les commandes Power...
Cliquez pour lire la suite de l'article par junarnoalg
Logiciels
974 Application Server (12.2.4.0)974 APPLICATION SERVER (12.2.4.0)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP mySongBook Player (1.0.0)MYSONGBOOK PLAYER (1.0.0)mySongBook Player est un logiciel gratuit permettant l'accès à une archive de tablatures/partitio... Cliquez pour télécharger mySongBook Player
|