IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Algorithmes et structures de données Discussion :

Graphique : algorithme graduations sur les axes


Sujet :

Algorithmes et structures de données

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2008
    Messages : 42
    Points : 35
    Points
    35
    Par défaut Graphique : algorithme graduations sur les axes
    Bonjour à tous !!!

    Je suis entrain de réfléchir à un moyen de créer des graphiques.

    Je suis parti d'un exemple simple : la répartition des ventes d'un produit par mois.
    En x : Janvier, Février, Mars,...
    En y : 70, 100, 150, ...

    Premier problème, les graduations : je ne peux pas toujours mettre 0 comme valeur initiale pour l'axe y. Car pour certains graphiques le 0 n'est pas significatif.
    Une solution serait d'utiliser les fonctions donnant le minimum et le maximum dans une liste de données comme valeur initiale et finale pour l'axe.
    C'est déjà un peu mieux, mais le graphique n'est pas très agréable à regarder. Il faut un espace minimum en dessous de la valeur minimale et au dessus de la valeur maximale.

    Je commence à imaginer mon algorithme :
    Il y a entre 6 et 10 graduations.
    Les graduations s'espacent de 1, 2, 5, 10 puis 20 (je peux encore continuer)
    Si la valeur maximale dans mes données est comprise entre [153 et 171] par exemple, la valeur maximale de ma graduation est 180


    Graduations | Pas | Max Graphe|Max Valeur >=
    10 20 200 172
    9 20 180 153
    8 20 160 134
    7 20 140 115
    6 20 120 96
    10 10 100 86
    9 10 90 77
    8 10 80 67
    7 10 70 58
    6 10 60 48
    10 5 50 43
    9 5 45 39
    8 5 40 34
    7 5 35 29
    6 5 30 24
    5 5 25 20
    10 2 20 18
    9 2 18 16
    8 2 16 14
    7 2 14 12
    6 2 12 10
    10 1 10 9
    9 1 9 8
    8 1 8 7
    7 1 7 6
    6 1 6 5

    Ca commence à prendre forme, mais je fais face à un autre problème. Si les valeurs dans ma base de données sont proches du style 150 152 148. Même en connaissant la valeur maximale : 152 dans ce cas ci, le graphique ne ressemble toujours à rien. Je dois aussi prendre en considération la valeur minimale…

    Ce n'est qu'un début évidemment et j'attends vos remarques avec la plus grande attention.

    PS : Quand l'algorithme sera correct, je le ferai en vb.net

  2. #2
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    En général, ce qu'on fait dans ces cas-là est :

    • écart = max - min
    • espaces entre grandes marques (mark) : à déterminer par l'utilisateur/ou le programme (par exemple suivant l'écart, 1/10 ième (en valeurs "entières").
    • espaces entre petites marques (tic) : espace entre grande marques divisé par 2, 5, 10, ...
    • Point de départ : arrondi vers le bas (règle de 3) de min/mark
    • Point max : point de départ + arrondi vers le haut de écart/mark


    Prenons ton exemple :

    153 - 171

    Ecart = 18

    Si tu veux quelque chose avec des graduations entières, il te faudra prendre un écart 150 - 180 (tous les 10 (mark)), ou un écart 150-175 (tous les 5 (mark)). Si tu veux un écart au plus court (153-171), il te faudra prendre une marque à 6 par exemple (que l'intervalle soit divisé de manière entière).

    Maintenant, pour les tics, dans le cas où mark est 10, par exemple tu peux visier en 5 (tous les 2), si c'est 5 tous les 1, si c'est 6 tout les 1 ou tout les 2.

    Tu as donc le choix , mais c'est facile de faire un algo ..
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2008
    Messages : 42
    Points : 35
    Points
    35
    Par défaut
    Merci beaucoup souviron34. C'était le coup de pouce dont j'avais besoin.

    Je n'avais pas pensé à créé des 'petites marques' (tic) qui rajoute plus de précision au graphique.

    Maintenant ça va aller pour créer l'algorithme.

    Je tenais aussi à dire que j'attache une certaine importance à cette algorithme pour que les graphiques proposés représente une image fidèle de la réalité.

    Problème résolu

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Débutant] Chiffre en format scientifique sur les axes du graphique
    Par Vincent32 dans le forum VB.NET
    Réponses: 1
    Dernier message: 06/04/2012, 14h27
  2. Réponses: 1
    Dernier message: 23/12/2008, 11h20
  3. [CR XI] format numérique sur les axes d'un graphique
    Par kikidrome dans le forum SAP Crystal Reports
    Réponses: 5
    Dernier message: 23/03/2007, 15h20
  4. [jpgraph]erreur sur les axe y
    Par scorpking dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 28/07/2006, 15h41
  5. Mettre des données string sur les axes d'un graphique
    Par Aurore_atmo dans le forum MATLAB
    Réponses: 2
    Dernier message: 06/07/2006, 11h57

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo