wiki:Recette BilanLot

Version 42 (modified by cedric, 12 years ago) (diff)

--

Bilan des caractéristiques de lots : densités de taille des aloses en migration

Retour à Recette StacomiR Dernière mise à jour décembre 2012 adaptation stacomir v0.4.1


  • Lancez un Bilan -> Parm. de Lot .
  • Je choisis de faire un bilan de la taille des aloses en vidéo comptage.
  • Dans le menu déroulant apparaissent l'ensemble des taxons existant sur le dispositif (quel que soit la date), puis les stades de ce taxon, et les caractéristiques existant pour ce taxon. Ces onglets permettent de vérifier que vous n'avez pas rentré de stades incohérents (ex : à la fois géniteur et indéterminé alors que vous n'avez que des géniteurs).

source:stacomi/trunk/docs/trac/Bilan_lot_recette.jpg

  • Cliquez sur un des boutons graphiques, par exemple dotplot.
  • Vous pouvez cliquer sur >utilitaire>newgraph pour faire apparaitre le graphique dans une nouvelle fenêtre graphique.

source:stacomi/trunk/docs/trac/Bilan_lot_recette1.jpg

 # voici ci dessous les codes ayant conduit à produire les graphiques proposés : density
	g<-ggplot(bilan_lot@data,aes(x=val_quant))
	g<-g+stat_density(aes(ymax = ..density..,  ymin = -..density..),
					fill = "grey50", colour = "grey10",
					geom = "ribbon", position = "identity") +
			facet_grid(. ~ annee) +
			coord_flip()
	print(g) 
	assign("g",p,envir_stacomi)
# points
	g<-ggplot(bilan_lot@data)
	g<-g+geom_point(aes(x=date,y=val_quant))
	print(g) 
# boxplot par quinzaine
	g<-ggplot(bilan_lot@data)
	g<-g+geom_boxplot(aes(x=quinzaine,y=val_quant))
	print(g) 

Evidemment les possibilités de ces graphiques sont assez limitées, essayons de produire quelques exemples de graphiques

densityplot

#Il est nécessaire de lancer un premier graphique pour charger et traiter les données
# l'objet bilan_lot est "rangé" dans une zone particulière,
bilan_lot<-get("bilan_lot",envir_stacomi)
# les données résultant du calcul sont rangées dans le slot data, on y accède en écrivant bilan_lot@data
g<-ggplot(bilan_lot@data)
# ci dessous on écrit une densité en fonction des années, position 'stack' correspond à empiler les données des différentes années
g+stat_density(aes(x=val_quant,fill=annee),position='stack')

source:stacomi/trunk/docs/trac/Bilan_lot_recette2.jpg source:stacomi/trunk/docs/trac/Bilan_lot_recette3.jpg source:stacomi/trunk/docs/trac/Bilan_lot_recette4.jpg

  • Ajoutons un titre et des légendes (attention requiert ggplot version 0.9.3) :
    g+stat_density(aes(x=val_quant,fill=annee),position='stack')+
    		ggtitle("Structure en taille des Aloses")+
    		xlab("Tailles (mm)")+
    		ylab("Densite")+
    		annotate("text",x = 300, y = 0.07, label = "essai == 1",  parse = T, vjust = 0, hjust = 0)
    

source:stacomi/trunk/docs/trac/Bilan_lot_recette5.jpg source:stacomi/trunk/docs/trac/Bilan_lot_recette6.jpgsource:stacomi/trunk/docs/trac/Bilan_lot_recette7.jpg

  • essai =2
    display.brewer.all()
    # affiche les palettes disponibles
    
    p+stat_density(aes(x=val_quant,fill=annee),position='stack')+facet_grid(. ~ .)+
    		opts(title="Structure en taille des Aloses",labels = c(x = "Tailles (mm)", y = "Densite",annee="Annees"))+
    		annotate("text",x = 300, y = 0.07, label = "essai == 2",  parse = T, vjust = 0, hjust = 0)+
    		scale_fill_brewer(palette = "Set3")
    
  • essai = 3
    p+stat_density(aes(x=val_quant,fill=annee),position='stack')+facet_grid(. ~ .)+
    		opts(title="Structure en taille des Aloses",labels = c(x = "Tailles (mm)", y = "Densite",annee="Annees"))+
    		annotate("text",x = 300, y = 0.07, label = "essai == 3",  size=10, parse = T, vjust = 0, hjust = 0,col="red")+
    		scale_fill_brewer(palette = "Spectral")
    
  • essai = 4
    couleurs=rainbow(12)
    p+stat_density(aes(x=val_quant,fill=annee),position='stack')+facet_grid(. ~ .)+
    		opts(title="Structure en taille des Aloses",labels = c(x = "Tailles (mm)", y = "Densite",annee="Annees"))+
    		annotate("text",x = 300, y = 0.07, label = "essai == 4",   parse = T, vjust = 0, hjust = 0,col="darkblue")+
    		scale_fill_manual(values = couleurs)
    


Utilisation du facettage

  • J'ai relancé l'application (pour effacer les objets en mémoire) à l'aide de stacomi(), puis j'ai choisi un nombre plus réduit d'années (2005-2008),
    • choix geom > histogram
    • x = val_quant
    • couleur > annee (la bordure)
    • fill > annee (le fond)
    • alpha > 0.2 (la transparence)
      # La console écrit :
      [1] "p+geom_histogram(aes(x=val_quant,colour=annee,fill=annee),,alpha='0.2'position='identity')+facet_grid(. ~ .) \n"
      stat_bin: binwidth defaulted to range/30. Use 'binwidth = x' to adjust this.
      
  • essai =5
    p+geom_histogram(aes(x=val_quant,colour=annee,fill=annee),alpha='0.2',position='identity')+
    opts(title="Structure en taille des Aloses Essai 5",labels = c(x = "Tailles (mm)", y = "Effectif",annee="Annees"))
    

source:stacomi/trunk/docs/trac/Bilan_lot_recette8.jpg source:stacomi/trunk/docs/trac/Bilan_lot_recette9.jpg source:stacomi/trunk/docs/trac/Bilan_lot_recette10.jpg

  • essai=6 (note la conversion pixel taille se traduit par une discontinuité en choisissant un intervalle de 5 mm (binwidth=5), on voit des trous dans les intervalles qui sont lié à l'utilisation du logiciel de vidéocomptage... )
    p+geom_histogram(aes(x=val_quant,fill=mois),binwidth=5,position='stack')+
    opts(title="Structure en taille des Aloses Essai 6",labels = c(x = "Tailles (mm)", y = "Effectif",mois="mois"))+
    facet_grid(annee ~ .,scales = "free", space="free")+scale_fill_brewer(palette="Set1")
    
  • essai=7
    p+geom_point(aes(x=annee,y=val_quant),alpha=1,position="jitter")+stat_boxplot(aes(x=annee,y=val_quant),colour="red",fill="blue",outlier.colour="red",alpha=0.4)+
    		opts(title="Structure en taille des Aloses Essai 7",
    				labels = c(x = "Annee", y = "Taille"))
    
    source:stacomi/trunk/docs/trac/Bilan_lot_recette11.jpg

script pour Brice pour avoir la structure en taille + un bilan interannuel dans la même fenêtre

On reprend l'exemple de tout à l'heure avec la formule suivante

p+stat_density(aes(x=val_quant,fill=annee),position='stack')+facet_grid(annee ~ .) +
		opts(title="Structure en taille des Aloses essai 8",labels = c(x = "Tailles (mm)", y = "Densite",annee="Annees"))+
		scale_fill_brewer(palette = "Spectral")
  • essai =8

Brice veut le détail des années + un graphique qui fait le bilan de toutes les années. Pour faire ça il faut récupérer le jeu de données qui se trouve à l'intérieur de p, le modififier et le repasser à l'objet p.

donnees<-p[["data"]] # on récupère les données.
donnees$annee1<-donnees$annee # on crée une nouvelle variable annee1.
copie_de_donnees<-donnees # on copie le jeu de données.
copie_de_donnees$annee1<-"all" #dans ce nouveau jeu, on remplace les valeurs des annees par "all"
p<-p%+%rbind(donnees,copie_de_donnees) # on raboute le nouveau et l'anciens jeu (fonction rbind = row bind, coller les lignes)
# la formule %+% permet de remplacer le jeu de données dans un objet de type ggplot.
p+stat_density(aes(x=val_quant,fill=annee),position='stack')+facet_grid(annee1 ~ .,scales="free") +
		opts(title="Structure en taille des Aloses essai 8",labels = c(x = "Tailles (mm)", y = "Densite",annee="Annees"))+
		scale_fill_brewer(palette = "Spectral")

source:stacomi/trunk/docs/trac/Bilan_lot_recette12.jpg