begin process at 2012 05 24 01:00:32
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Jeux

 > JEU DE LA VIE

JEU DE LA VIE


 Information sur la source

Note :
Aucune note
Catégorie :Jeux Classé sous :jeu, de, la, vie, python Niveau :Débutant Date de création :24/01/2009 Date de mise à jour :24/01/2009 18:16:38 Vu / téléchargé :4 491 / 130

Auteur : dia100daly

Ecrire un message privé
Commentaire sur cette source (1)
Ajouter un commentaire et/ou une note

 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)


 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Historique

24 janvier 2009 18:16:38 :
c'etait pour ajouter la maniere d'executer le progamme

 Sources du même auteur

Source avec Zip JEU DE LA VIE AVEC TKINTER

 Sources de la même categorie

Source avec Zip Source avec une capture ISOLA - MON PREMIER PROGRAMME PYTHON 3 par Debiars
Source avec Zip Source avec une capture UN PUZZLE UN PEU TAQUIN. par lespinx
Source avec Zip QUESTIONNAIRE par darkanghel91
Source avec Zip Source avec une capture JEU DU PLUS OU MOINS par Iphonemax
TAQUIN 4*4 par fredericfabry

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture JEU DE LA VIE SIMPLE ET GRAPHIQUE (TKINTER) EN PYTHON 3 par sodawil
Source avec une capture JEU DU SERPENT (SNAKE) par zarash
THE GAME OF LIFE, AVEC IMPLÉMENTATION GRAPHIQUE par xeolin
Source avec Zip Source avec une capture UN CLASSIC SOKOBAN par blackgrimly
Source avec Zip JEU DE LA VIE AVEC TKINTER par dia100daly

Commentaires et avis

Commentaire de Julien39 le 07/03/2009 12:33:19 administrateur CS

Aucun commentaire, ca devient vite imcomprehensible, dommage, ce code me semblait une bonne idée mais il est tres dur a lire.
Je te mets 5 quand meme mais je te fais deux remarques
- aucun commentaire c'est dit
- les noms des variables ne sont pas assez explicites

 Ajouter un commentaire


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


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 1,201 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales