+
+ ### Tracé pour de bon
+ if l_jours != []:
+ ax.plot(l_jours_conv,l_poids,label=conf["nom"],color=conf["couleurs"]["cadretxt"],marker='o')
+ debug("Tracé de la courbe enfant, avec les jours "+str(l_jours_conv),liste_err)
+
+ #### extrapolatios éventuelles
+ # a-t-on demndé des calculs ?
+ jextrapole = conf["non_sauve"]["prolongercourbes"] == "oui"
+ # Est-ce qu'on a demandé un calcul sur cette donnée ?
+ print()
+ for calextra in CONFIG["extradata"]:
+ jextrapole = jextrapole or conf["non_sauve"][calextra+"_type"] == typedonnee
+
+ #print(jextrapole)
+ if jextrapole:
+ try:
+ debug("Il faut extrapoler les courbes !", liste_err)
+ # Prendre l'ensemble des dates "source"
+ # print(conf["non_sauve"]["nbdataextra"])
+ if conf["non_sauve"]["nbextradata"] == 0:
+ sources_extrap = l_jours
+ sources_extrap_data = l_poids
+ else:
+ sources_extrap = l_jours[-conf["non_sauve"]["nbextradata"]:] # les derniers jours
+ sources_extrap_data = l_poids[-conf["non_sauve"]["nbextradata"]:]
+
+ debug("On extrapole sur les jours : "+str(sources_extrap), liste_err)
+
+ dates_extrapole, donnees_extrapole = prolongecourbe(t, sources_extrap, sources_extrap_data, conf["typecourbe"], liste_err)
+ debug("données extrapolées !", liste_err)
+ #debug(str(dates_extrapole[0:10])+str(donnees_extrapole[0:10]), liste_err)
+
+ # QUe veut-on maintenant sur ces données extrapolées ?
+ # Afficher la courbe
+ if conf["non_sauve"]["prolongercourbes"] == "oui":
+ # On va prendre les extrapolations de la dernière donnée jusqu'à l fin du graphe
+ debut_extr = int(l_jours[-conf["non_sauve"]["nbextradata"]])
+ i_debut_extr = dates_extrapole.index(debut_extr)
+ i_fin_extr = dates_extrapole.index(jour_maxi)
+ # Voilà ce qu'on veut tracer
+ dates_extrapole_trace = dates_extrapole[i_debut_extr:i_fin_extr+1]
+ donnees_extrapole_trace = donnees_extrapole[i_debut_extr:i_fin_extr+1]
+ dates_extrapole_trace = u.convertit_tableau(dates_extrapole_trace,unite,liste_err)
+
+ # tracé des données extrapolées
+ plt.plot(dates_extrapole_trace, donnees_extrapole_trace,color=conf["couleurs"]["cadretxt"], linestyle=(0, (5,7)), marker=None)
+ debug("Tracé de la courbe extrapolée ok", liste_err)
+
+ # Calculer une donnée à l'âge x
+ if conf["non_sauve"]["calculextradata_type"] == typedonnee:
+ r = calcule_donnee_extrapolee(dates_extrapole, donnees_extrapole, conf["non_sauve"]["calculextradata_age"], typedonnee, liste_err)
+ if r!="":
+ liste_extracalculs.append(r)
+ print(liste_extracalculs)
+
+ # Calculer un âge où on atteint cette donnée
+ if conf["non_sauve"]["calculextratemps_type"] == typedonnee:
+ r = calcule_age_extrapole(dates_extrapole, donnees_extrapole, conf["non_sauve"]["calculextratemps_val"], typedonnee, liste_err)
+ if r!="":
+ liste_extracalculs.append(r)
+ print(liste_extracalculs)
+
+ except:
+ warning("Des problèmes pour extrapoler...", liste_err)
+
+ else:
+ debug("On ne trace pas de courbe enfant", liste_err)
+
+ ###################" Gestion de l'échelle #####################
+ debug("Courbes tracées. Il n'y a plus qu'à gérer l'échelle", liste_err)
+ ### échelle à régler
+
+ # On extrait la valeur min et la valeur max des poids des courbes OMS et des données