Dans l'article introductif de l'événement, nous racontions comment tu as trouvé dans une brocante une console étrange avec deux cartouches.
La deuxième de ces cartouches contient un jeu qui s'appelle Synchro-donjon.
Le but de Synchro-donjon est de conquérir le plus rapidement possible le donjon du Cirque des Monts Pleureurs, un donjon situé au Nord-Ouest du royaume d'Alrys et que tu peux voir de l'extérieur en jouant à La geste d'Alrys, l'autre jeu de ce concours.
Dans ce jeu, il y a quatre joueurs qui commencent dans les coins : Jaune, Rouge, Bleu et Vert. Le but est de faire traverser le donjon aux joueurs pour les faire sortir par leurs sorties respectives (sur le côté opposé du plateau).
Il y a de nombreux étages au donjon, et chacun est différent et imprévisible - c'est pour ça que le donjon est difficile à conquérir.
Pour permettre au héros de continuer son aventure dans le monde d'Alrys, tu devras donc user d'ingéniosité et programmer ta calculatrice pour décider des actions à effectuer à chaque étage. En somme, ta tâche est d'écrire une IA pour Synchro-donjon !
Dans cet article je vais te présenter les règles du jeu. Mais je peux déjà te dire ce qui rend ce jeu intéressant : comme tu n'as qu'une calculatrice branchée, la console pense que tu veux contrôler les 4 joueurs d'un coup, et donc toutes tes actions s'appliquent à tous les joueurs en même temps ! Coordonner tout ce beau monde est la difficulté de ce donjon.
Bien sûr, tu ne seras pas tout seul dans cette tâche, et plusieurs IAs te seront présentées pour t'aider à prendre en main le jeu ainsi que le code Python nécessaire pour écrire ton IA. Tu peux aussi jouer au jeu directement sur ta calculatrice pour te familiariser.
Lis l'article explicatif de ia2_path.py : IA Synchro-donjon #2 : Recherche de chemin
Lis l'article explicatif de ia3greed.py : IA Synchro-donjon #3: Optimisations locales
Règles du jeu
Le donjon est un plateau de 8 lignes et 16 colonnes. Les bords sont constitués de murs et des sorties. Les 4 joueurs commencent dans les coins et chacun doit atteindre sa sortie. Sur leur chemin, on trouve :
- Des pics, qui font des dégâts si un des joueurs marche dessus.
- Des monstres, qui font aussi des dégâts si un joueur les croise, mais qui sont vaincus durant le combat. Il est aussi possible de les attaquer à distance et les vaincre sans prendre de dégâts.
- Des pièges, qui produisent des effets aléatoires et souvent imprévisibles : soit ils infligent des dégâts, soit ils font apparaître d'autres pics/pièges ailleurs dans le donjon.
À chaque tour, tu disposes de 5 actions possibles :
- Les 4 actions ALLER_GAUCHE, ALLER_DROITE, ALLER_HAUT et ALLER_BAS indiquent aux joueurs de se déplacer. Tout le monde effectue le même mouvement. Un joueur qui est bloqué par un mur ne se déplace pas. Si un joueur marche sur des pics, il prend des dégâts ; s'il marche sur un monstre, il tue le monstre mais prend des dégâts ; s'il marche sur un piège, le piège est activé.
- L'action ATTAQUER indique aux joueurs d'attaquer les objets autour d'eux sans se déplacer. Tous les monstres à côté des joueurs sont détruits, et le joueurs ne prennent pas de dégâts. Cependant, tous les pièges à côté des joueurs sont également activés !
Dans Synchro-donjon, ton IA jouera sur un grand nombre de plateaux et on fait la somme de chaque score obtenu sur chacun des plateaux pour obtenir ton score final.
Installation et utilisation du programme
Synchro-donjon peut être installé sur les modèles suivants et sur PC. Le jeu est compatible avec un nombre impressionnant de modèles, allant jusqu'à la TI-82 Advanced Édition Python ! Ce résultat est possible grâce à la bibliothèque polycal4.py ainsi que des heures de compression investies par Critor.
Les fichiers polycal4.py et polyfont.py sont identiques à ceux de La geste d'Alrys, l'autre jeu du concours. Tu n'as besoin de les transférer qu'une fois pour les deux problèmes.
Tu peux jouer toi-même interactivement en lançant synchrod.py. Quand tu auras une IA (un modèle est donné plus bas dans cet article), tu pourras faire jouer l'IA en lançant ton fichier Python.
Trois IAs sont fournies avec le programme : ia1_ask.py qui est le squelette présenté plus bas, mais aussi ia2_path.py et ia3greed.py qui sont deux IAs plus évoluées qui te seront présentées en détail plus tard durant le concours pour t'aider.
Il te suffit d'extraire l'ensemble des scripts dans le dossier de ton choix, puis de lancer le script synchrod.py pour jouer interactivement (au clavier) ou une IA.
Transfère synchrod.py, polycalc4.py et polyfont.py dans la mémoire de stockage. Dans le mode interactif, tu dois appuyer sur
AC/ONpour saisir tes actions dans la console.
Les performances des calculatrices et émulateurs sur ces scripts sont correctes. Cependant, si tu veux les améliorer, nous te conseillons :
- sur calculatrice, d'installer un utilitaire d'overclocking
- ou sinon d'opter pour le simulateur sur clé USB
Mises à jour conseillées :
- Système 3.60 pour Graph 90+E / fx-CG50 avec Windows / Mac
- Système 3.50 pour Graph 35+E II / fx-9750/9860GIII avec Windows
Overclocking :
Emulateurs :
- Graph 90+E / fx-CG50 version 3.50 pour Windows / Mac
- Graph 35+E II / fx-9750/9860GIII version 3.40 pour Windows
(période d'essai gratuite sans engagement de 90 jours)
Simulateurs :
- Graph 90+E version 3.60
- Graph 35+E II version 3.50
(nécessitent la clé USB officielle)
Transfert de données :
Il te suffit de transférer directement l'application SynchroD.hpappdir.zip téléchargée. Une fois lancée, tu auras 2 vues à utiliser :
- La vue
Symb
pour modifier ton IA - La vue
Num
pour la console Python.
Elle pourra sous certaines conditions te proposer de recharger les scripts, ce que tu auras juste à accepter pour lancer le jeu. Si ce n'est pas proposé, le menu de bas d'écran Effacer le permet également
Simulateur :
- logiciel HP Prime Virtual Calculator version 14592 pour Windows 64-bits / Windows 32-bits (gratuit)
(attention, à ce jour les dernières version Mac, Android et iOS ne supportent pas le Python)
Transfert de données et mises à jour conseillées :
- logiciel de connectivité version 2.1.14592 pour Windows 64-bits / Windows 32-bits
- logiciel de connectivité version 2.1.14425 pour Mac
- mise à jour 2.1.14588 pour HP Prime G1 G2
- Tutoriel
- chez Omega (avec simulateur + connectivité - connectivité incompatible versions 16.3.0+)
- chez NumWorks (avec simulateur + connectivité)
- Téléchargeable
Sur calculatrice, les performances sont très correctes, très supérieures au reste du milieu de gamme ainsi qu'à certains modèles haut de gamme, absolument remarquable. Toutefois, le heap de 32K du firmware officiel Epsilon risque très rapidement de te limiter dans la programmation de ton itinéraire. Dans ton intérêt nous te conseillons très fortement de passer sous les firmwares tiers Omega ou Khi pour 100K de heap.
Attention, l'installation de toute mise à jour officielle 16.3.0 ou supérieure empêche définitivement l'installation de firmwares tiers, et empêchera également le transfert de scripts depuis les sites Internet des firmwares Omega et Khi.
Le simulateur en ligne officiel de NumWorks a des performances absolument déplorables (et souffre en prime du même défaut de heap limité à 32K). Nous te conseillons très fortement le simulateur Omega qui est incomparable en performances dans le bon sens du terme comme illustré ci-contre, et t'offrira en prime 100K de heap.
Transfert de données :
- Transfert direct de scripts .py
(incompatible versions 16.3.0+)
Tu as juste à :
- le transférer dans le dossier de ton choix
- l'ouvrir
- te rendre avec
ctrl
→
sur l'onglet avec le script synchrod.py ou une IA - modifier l'IA comme tu voudras, puis l'exécuter via les menus de la touche
menu
ou directement via le raccourcictrl
R
Mises à jour conseillées :
- Système 5.3.0 pour TI-Nspire CX II CAS (également CX II-T CAS et CX II-C CAS)
- Système 5.3.0 pour TI-Nspire CX II-T
- Système 5.3.0 pour TI-Nspire CX II
Overclocking :
Simulateurs + transfert de données :
- TI-Nspire CX CAS + TI-Nspire CX version 5.3.2 édition enseignant pour Windows / Mac (période d'essai gratuite sans engagement de 90 jours)
- TI-Nspire CX CAS version 5.3.2 édition élève pour Windows / Mac (période d'essai gratuite sans engagement de 30 jours)
- TI-Nspire CX version 5.3.2 édition élève pour Windows / Mac (période d'essai gratuite sans engagement de 30 jours)
- TiLP-II version 1.18 pour Windows / Mac / Linux (gratuit)
Les scripts sont à transférer dans le dossier /Xcas/ créé au premier lancement de KhiCAS. Il suffit ensuite depuis KhiCAS comme illustré ci-contre :
- de passer le mode de fonctionnement en MicroPython (menu via la touche
doc
) - d'ouvrir et modifier le script synchrod.py (également via la touche
doc
) ou un script d'IA - d'exécuter le script en question (touche
enter
) - durant les interactions manuelles tu contrôles les déplacements avec les touches fléchées et peux quitter avec
esc
Les performances sur calculatrice sont correctes, même si cela ne fera pas de mal d'installer un utilitaire d'overclocking.
(l'illustration ci-contre est relative aux anciens modèles TI-Nspire CX beaucoup plus lents, faute d'émulateur TI-Nspire CX II à ce jour)
Mises à jour conseillées :
- Système 5.3.0 pour TI-Nspire CX II CAS (également CX II-T CAS et CX II-C CAS)
- Système 5.3.0 pour TI-Nspire CX II-T
- Système 5.3.0 pour TI-Nspire CX II
Ajouts relatifs au Python :
Overclocking :
Simulateurs + transfert de données :
- TI-Nspire CX CAS + TI-Nspire CX version 5.3.2 édition enseignant pour Windows / Mac (période d'essai gratuite sans engagement de 90 jours)
- TI-Nspire CX CAS version 5.3.2 édition élève pour Windows / Mac (période d'essai gratuite sans engagement de 30 jours)
- TI-Nspire CX version 5.3.2 édition élève pour Windows / Mac (période d'essai gratuite sans engagement de 30 jours)
- TiLP-II version 1.18 pour Windows / Mac / Linux (gratuit)
Les scripts sont à transférer dans le dossier /Xcas/ créé au premier lancement de KhiCAS. Il suffit ensuite depuis KhiCAS comme illustré ci-contre :
- de passer le mode de fonctionnement en MicroPython (menu via la touche
doc
) - d'ouvrir et modifier le script synchrod.py (également via la touche
doc
) ou un script d'IA - d'exécuter le script en question (touche
enter
) - durant les interactions manuelles tu contrôles les déplacements avec les touches fléchées et peux quitter avec
esc
Mises à jour conseillées :
- Système 4.5.4 pour TI-Nspire CX CAS
- Système 4.5.4 pour TI-Nspire CX
Ajouts relatifs au Python :
Overclocking :
Emulateur :
Transfert de données :
- TI-Nspire Computer Link version 3.9 pour Windows / Mac (gratuit)
- tutoriel TI-Nspire Computer Link (gratuit)
- TI-Nspire CX CAS + TI-Nspire CX version 5.3.2 édition enseignant pour Windows / Mac (période d'essai gratuite sans engagement de 90 jours)
- TI-Nspire CX CAS version 5.3.2 édition élève pour Windows / Mac (période d'essai gratuite sans engagement de 30 jours)
- TI-Nspire CX version 5.3.2 édition élève pour Windows / Mac (période d'essai gratuite sans engagement de 30 jours)
- TiLP-II version 1.18 pour Windows / Mac / Linux (gratuit)
Il te suffit de transférer l'ensemble des fichiers présents dans le sous dossier source/, puis de lancer l'IA de ton choix dans l'application Python.
Mise à jour conseillée :
- Système 5.6.3
Emulation / simulation :
- TI-SmartView 83 Premium CE version 5.5 pour Windows / Mac
- TI-SmartView 84 Plus CE-T version 5.6 pour Windows / Mac
(période d'essai gratuite sans engagement de 90 jours) - TI-SmartView 83 Premium CE version 5.5 (pour clé USB d'émulation officielle)
- CEmu pour Windows / Mac / Linux (gratuit)
Transfert de données :
Si tu es sur calculatrice, transfère SynchroD.b83 (TI-83 Premium CE) ou SynchroD.b84 (TI-84 Plus CE).
Si tu es sur émulateur, transfère l'ensemble des fichiers présents dans le sous dossier source/.
Ensuite lance l'application Python et lance le script synchrod.py ou ton IA.
Mises à jour conseillées :
- Système 5.6.1 (TI-83 Premium CE Edition Python)
- Système 5.6.1 (TI-84 Plus CE-T Python Edition / TI-84 Plus CE Python)
- Application Python 5.5.2 (TI-83 Premium CE Edition Python / TI-84 Plus CE-T Python Edition)
Emulation / simulation :
- TI-SmartView 83 Premium CE version 5.5 pour Windows / Mac
- TI-SmartView 84 Plus CE-T version 5.6 pour Windows / Mac
(période d'essai gratuite sans engagement de 90 jours) - TI-SmartView 83 Premium CE version 5.5 (pour clé USB d'émulation officielle)
- CEmu pour Windows / Mac / Linux (gratuit)
Transfert de données :
Si tu es sur calculatrice, transfère SynchroD.b83 (TI-83 Premium CE) ou SynchroD.b84 (TI-84 Plus CE).
Si tu es sur émulateur, transfère l'ensemble des fichiers présents dans le sous dossier source/.
Ensuite lance l'application PyAdaptr et lance le script synchrod.py ou ton IA.
Mises à jour conseillées :
- Système 5.6.1 (TI-83 Premium CE)
- Système 5.6.1 (TI-84 Plus CE(-T))
- Application PyAdaptr (TI-83 Premium CE / TI-84 Plus CE(-T))
Emulation / simulation :
- TI-SmartView 83 Premium CE version 5.5 pour Windows / Mac
- TI-SmartView 84 Plus CE-T version 5.6 pour Windows / Mac
(période d'essai gratuite sans engagement de 90 jours) - TI-SmartView 83 Premium CE version 5.5 (pour clé USB d'émulation officielle)
- CEmu pour Windows / Mac / Linux (gratuit)
Transfert de données :
Fonctionnement du plateau de jeu
Le plateau de jeu contient 8 lignes et 16 colonnes, et est codé dans une liste Python de 8×16 = 128 entiers. Chaque élément de la liste indique l'état d'une case du plateau, et ils sont arrangés dans cet ordre :
Si tu préfères numéroter les cases en lignes/colonnes, tu peux utiliser la méthode suivante.
- Les lignes sont numérotées de Y=0 (ligne du haut) à Y=7 (ligne du bas).
- Les colonnes sont numérotées de X=0 (colonne de gauche) à X=15 (colonne de droite).
- La case sur la ligne Y et la colonne X a pour valeur V=16*Y+X.
- La case de valeur V est sur la ligne Y=V//16 et sur la colonne X=V%16.
Le tableau ci-dessous résume les combinaisons :
Sur les calculatrices monochromes, les couleurs sont remplacées par les symboles ci-dessous :
Sur la TI-82 Advanced Édition Python, le jeu est entièrement en mode texte, et les caractères suivants sont utilisés :
- Les joueurs sont les symboles ¶
- Les pics sont les trois-points …
- Les monstres sont les symboles ¥
- Les pièges sont les symboles Ø
Fonctionnement de l'IA
L'IA de ton programme doit être un fichier Python avec une fonction pour décider ce qui doit se passer à chaque tour (ou, sur Numworks, une fonction Python intégrée à synchrod.py). Le squelette de base est le fichier ia1_ask.py :
- Code: Select all
from polycal4 import get_infos
from synchrod import *
def tour(plateau, joueurs, evenements):
# Demander une action avec input()
return demander_action()
play_game(tour)
Les deux premières lignes importent les fonctions de Synchro-donjon. Évidemment, il est interdit d'accéder aux variables internes du script ou de modifier les valeurs identifiant les éléments de la map.
La fonction tour() est ton IA. Elle est appelée à chaque tour du jeu avec trois paramètres et doit renvoyer une action à accomplir.
- plateau est la liste de 128 cases représentant le plateau de jeu (que tu ne dois pas modifier évidemment).
- joueurs est une liste de 4 éléments indiquant la position des 4 joueurs sur le plateau. Tu peux utiliser soit le style joueurs[ROUGE] soit le style joueurs[1] selon tes préférences. Pour les joueurs qui sont encore sur le plateau, la position est un entier entre 0 et 127. Pour ceux qui sont déjà sortis, la valeur spéciale -1 est utilisée.
- evenements est une liste d'événements qui se sont produits depuis le tour précédent.
-
(-1,-1,NOUVELLE_PARTIE,-1)
si une nouvelle partie vient de commencer.
-
(<x>,<y>,PIEGE_APPARU,<joueur>)
si <joueur> a activé un piège qui a fait apparaître un nouveau piège à la ligne <y>, colonne <x>.
-
(<x>,<y>,PICS_APPARU,<joueur>)
si <joueur> a activé un piège qui a fait apparaître des pics à la ligne <y>, colonne <x>.
Outils pour écrire ton IA
synchrod.py fournit plusieurs outils pour t'aider à écrire ton IA, spécifiquement 4 fonctions.
La fonction demander_action() donne la main au clavier de la calculatrice pour choisir la prochaine action. Sur les modèles où l'on peut saisir au clavier, les touches directionnelles, entrée et retour sont utilisées. Sur les autres (notamment CASIO), il faut appuyer sur AC/ON pour revenir à la console() et taper un chiffre.
La fonction est_un() permet d'identifier les pics, monstres, et pièges indépendamment de leur couleur. Par exemple un piège vert est un piège mais pas un monstre, donc
est_un(PIEGE+VERT, PIEGE)
vaut True mais est_un(PIEGE+VERT, MONSTRE)
vaut False.De façon similaire, la fonction affecte() permet de déterminer si des pics, monstres ou pièges affectent un joueur. Par exemple, les pics violets affectent Jaune mais pas les pics jaunes, donc
affecte(PICS+TOUS, JAUNE)
vaut True mais affecte(PICS+JAUNE, JAUNE)
vaut False.Enfin, il y a une fonction
calculer_chemin(<plateau>, <début>, <fin>)
qui calcule en chemin entre la case <début> et la case <fin> et renvoie une liste de directions (ALLER_*). C'est un outil très utile et assez puissant, qui sera expliqué plus en détail avec une des IAs d'exemple. Utilisation de play_game()
La fonction play_game() appelée à la fin du programme lance la simulation du jeu. Elle a plusieurs paramètres que tu peux modifier à loisir pour améliorer ton IA :
-
blind=True
peut être ajouté pour désactiver l'affichage du plateau de jeu et ne laisser que la console (ce qui va en général beaucoup plus vite).
-
seed=<nombre>
peut être ajouté pour tester un plateau particulier. La valeur indiquée permet en effet de contrôler le générateur aléatoire.
-
maxgames=<nombre>
permet de choisir le nombre de parties (par défaut 100).
- Code: Select all
#0: 12648430
Bravo! 39T 50D -> 61
#0 est le numéro de la partie (ça va jusqu'à maxgames). Le nombre à droite, 12648430, est la graine aléatoire. Si tu demandes seed=12648430 tu retomberas exactement sur ce plateau (ce qui est utile si ton programme a une erreur que tu veux retester).
Sur la ligne du bas, le nombre devant T est le nombre de tours passés sur le plateau, le nombre devant D est la quantité de dégâts que tu as subis, et le résultat est ton score (150-T-D). Si ton score est négatif il compte pour 0.
À la fin de la partie, play_game() affiche le nombre de parties jouées et ton score final. Par exemple :
- Code: Select all
Games solved: 100
Score: 2171
Pour participer au concours
Pour participer à l'épreuve de Synchro-donjon, envoie ton fichier .py d'IA (ou ton script synchrod.py modifié sur Numworks) par courriel à contact@planet-casio.com avant le Dimanche 7 Novembre à 23:59 avec :
- Pour sujet, Synchro-donjon ;
- Un moyen de te contacter rapidement en cas de gain ou de question (adresse courriel, téléphone, compte social, compte discord, etc.) ;
- Ton pseudonyme sur TI-Planet ou Planète Casio (optionnel) ;
- Pour pouvoir recevoir ton lot, ton adresse postale avec nom et prénom, et un numéro de téléphone personnel valide. (Tu peux les communiquer plus tard si tu souhaites.)
N'hésite pas à envoyer plusieurs participations, nous ne retiendrons que la meilleure.
Lots
Les lots pour cette épreuve sont les suivants. Les 5 participants ayant les meilleurs scores pourront choisir, par ordre de classement, un lot de leur choix.
- 1 lot Graph 90+E : 1 calculatrice Graph 90+E + 1 sac et stylo CASIO + 1 pack de goodies TI-Planète Casio
- 1 lot Graph 35+E II : 1 calculatrice Graph 35+E II + 1 sac et stylo CASIO + 1 pack de goodies TI-Planète Casio
- 1 lot Goodies n°1 : 1 clé USB TI-83 Premium CE (4 Go) + 1 batterie externe CASIO (2200 mAh) + 1 sac et stylo CASIO + 1 pack de goodies TI-Planète Casio
- 1 lot Goodies n°2 : 1 recueil d'activités SNT Numworks (65 pages) + 1 clé USB simulateurs CASIO (8 Go) + 1 sac et stylo CASIO + 1 pack de goodies TI-Planète Casio
- 1 lot Goodies n°3 : 1 cahier «Boss des maths» Numworks (80 pages) + 1 clé USB simulateurs CASIO (8 Go) + 1 sac et stylo Casio + 1 pack de goodies TI-Planète Casio
Tu peux voir l'article sur les batteries externes pour plus de détails.
Et voilà pour cette épreuve ! Je compte sur toi pour tester toutes tes idées de génie et conquérir ce Synchro-donjon en temps record !