Différences entre les versions de « STIC:STIC III (2018)/Physicalisation de statistiques au hockey sur glace »

De EduTech Wiki
Aller à la navigation Aller à la recherche
m
m
Ligne 61 : Ligne 61 :
 
*Ensuite on crée un tableau (''multidimensional array'') que l'on rempli de 0.
 
*Ensuite on crée un tableau (''multidimensional array'') que l'on rempli de 0.
 
*Pour remplir les case correspondantes à chaque tir on récupère chaque paire de coordonnées (un x et un y), et ensuite on incrémente la case du tableau correspondant.
 
*Pour remplir les case correspondantes à chaque tir on récupère chaque paire de coordonnées (un x et un y), et ensuite on incrémente la case du tableau correspondant.
 +
*On répète l'opération pour tous les fichiers présents dans le dossier.
 +
*On exporte le tableau dans le dossier de travail.
 
*
 
*
 
===Ressources===
 
===Ressources===
 
* [https://www.ibm.com/developerworks/library/x-xpathphp/index.html Using XPath with PHP (IBM Developper)]
 
* [https://www.ibm.com/developerworks/library/x-xpathphp/index.html Using XPath with PHP (IBM Developper)]
 
* [[Tutoriel XPath]]
 
* [[Tutoriel XPath]]

Version du 31 août 2019 à 17:38

Physicalisation de données
Module: STIC:STIC III (2018)/Projets
brouillon débutant
2019/08/31

Description du projet

Le but de ce projet est de partir des données saisies par les statisticiens de la ligue pour proposer des visualisations parlantes.

Ce projet est en construction est sera terminé d'ici fin août 2019.

Objectifs

Il y a plusieurs objectifs dans ce projet.

  • En premier lieu il faudra récupérer les données saisies sous un format utilisable par l'ordinateur (actuellement elles sont sous une forme visuelle)
  • Dans un deuxième temps il faudra développer un algorithme d'interprétation des données.

Projet - Heatmap en 3D des tirs cadrés

Dans ce projet je vais imprimer en 3D une réplique de patinoire dont la topographie indiquera l'emplacement et la quantité de tirs cadrés.

Les données statistiques sont exportées au format XML. Le fichier obtenu ressemble à ce qui suit.

 1<GAMEACTION>
 2			<TEAM>Flaming Eagles HC</TEAM>
 3			<TIME>3756</TIME>
 4			<TYPE>SHOT</TYPE>
 5			<DETAIL>SOG</DETAIL>
 6			<SS>5-5</SS>
 7			<SCORER>24</SCORER>
 8			<PLUS1>3</PLUS1>
 9			<PLUS2>11</PLUS2>
10			<PLUS3>16</PLUS3>
11			<PLUS4>25</PLUS4>
12			<PLUS5>24</PLUS5>
13			<PLUS6>14</PLUS6>
14			<GK>14</GK>
15			<GK_OPPONENT>149</GK_OPPONENT>
16			<DATETIME>1541271623</DATETIME>
17			<PERIOD>1</PERIOD>
18			<POSITION_X>4.691489</POSITION_X>
19			<POSITION_Y>20.90425</POSITION_Y>
20			<POSITION>L-POINT</POSITION>
21			<ZONE>OFFENSIVE</ZONE>
22		</GAMEACTION>

Pour réaliser ma heatmap je vais avoir besoin des éléments suivants :

  • <DETAIL> pour identifier si il s'agi d'un tir cadré
  • <POSITION_X> et <POSITION_Y> pour pouvoir y situer sur la surface de jeu.

Il y a là un premier problème, je ne sais pas à quoi correspondent ces valeurs. Où se trouve le 0 ? Quel est le maximum ? Après avoir placé des données dans les coins de la patinoire j'ai pu déterminer que les positions vont de 0 à 30 sur l'axe des X (petit côté de la patinoire) et de 0 à 60 pour l'axe des Y (long côté). C'est assez logique puisque une patinoire européenne fait 30m*60m.

L'algorithme que je vais mettre en place devra donc extraire les positions X et Y de tous les tirs cadrés (SOG).

Démarche

La première étape est la collecte de données, ces données ayant déjà été collectées je peux passer à l'étape suivante qui consiste à extraire les données pertinentes. Pour ce faire je vais coder un algorithme utilisant XPath qui me permettra de cibler les GAMEACTION correspondant à un tir cadré, puis à en récupérer la position.

Description de l'algorithme

  • Scanner le dossier dans lequel se trouve les fichiers XML, placer leurs noms dans un array et les passer au parser.
  • Repérer tous les tirs cadrés d'une équipe dans le XML avec XPath et les placer dans un array (ces paramètres seront des arguments, utile si on veut travailler sur d'autres équipes ou d'autres actions de jeu).
  • L'array créé par SimpleXML contient des objets, il faut donc récupérer les valeurs contenues dans les objets les arrondir et les push dans un autre array.
  • Ensuite on crée un tableau (multidimensional array) que l'on rempli de 0.
  • Pour remplir les case correspondantes à chaque tir on récupère chaque paire de coordonnées (un x et un y), et ensuite on incrémente la case du tableau correspondant.
  • On répète l'opération pour tous les fichiers présents dans le dossier.
  • On exporte le tableau dans le dossier de travail.

Ressources