Discussion: Calcul d'une moyenne

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    octobre 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : octobre 2017
    Messages : 4
    Points : 1
    Points
    1

    Par défaut Calcul d'une moyenne

    Bonjour,
    j'ai un petit soucis avec le calcul d'une moyenne. je m'explique,
    pour une colonne contenant 38520 lignes, j'aimerais faire le calcul de la moyenne pour chaque 360 lignes mais j'y arrive pas. j'ai essayer plusieurs code avec le boucle for mais les résultats obtenus ne me satisfont pas.
    Quelqu'un pourrai me tendre la perche.

    Merci d'avance

  2. #2
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Ingénieur R&D freelance
    Inscrit en
    novembre 2006
    Messages
    19 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur R&D freelance

    Informations forums :
    Inscription : novembre 2006
    Messages : 19 456
    Points : 52 611
    Points
    52 611

    Par défaut

    Voici l'idée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    M = rand(38520,1);
    M = reshape(M, 360, []);
    m = mean(M);
    Mes compétences :
    • conception mécanique 3D (Autodesk Fusion 360)
    • développement informatique (MATLAB, Python, C, VBA)
    • impression 3D (Ultimaker)
    • programmation de microcontrôleur (Microchip PIC et Arduino)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    octobre 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : octobre 2017
    Messages : 4
    Points : 1
    Points
    1

    Par défaut

    Citation Envoyé par Jerome Briot Voir le message
    Voici l'idée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    M = rand(38520,1);
    M = reshape(M, 360, []);
    m = mean(M);
    Bonsoir Jerome
    merci pour ta réponse
    j'ai un peu de mal à bien le comprendre. je t'envoi le code que j'ai réaliser avec le boucle for pour que sa soit plus claire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    load moyennes_variables.txt
    m1=moyennes_variables(:,1);
    m2=moyennes_variables(:,2);
    m3=moyennes_variables(:,3); 
    m4=moyennes_variables(:,4);
    i=0;
    M=[];
    for i=1:360:38520;
       moy1=mean(m1(i));
        moy2=mean(m2(i));
        moy3=mean(m3(i));
        moy4=mean(m4(i));
        i=i+1;
        M=[M;moy1 moy2 moy3 moy4];
    end

  4. #4
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    mars 2005
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : mars 2005
    Messages : 1 563
    Points : 2 760
    Points
    2 760

    Par défaut

    salut

    la fonction mean renvoie pour une matrice un vecteur ligne contenant la moyenne de chaque colonne
    la solution proposée par Jérome consiste à transformer ton vecteur colonne de 38520 éléments en une matrice de 107 colonnes contenant 320 éléments chacune
    ainsi la fonction mean appliquée à cette matrice te renvoie un vecteur ligne de 107 éléments étant égaux aux moyennes des 107 colonnes de 320 éléments

    du coup pas besoin de boucle

    Fabien

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    octobre 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : octobre 2017
    Messages : 4
    Points : 1
    Points
    1

    Par défaut

    Citation Envoyé par le fab Voir le message
    salut

    la fonction mean renvoie pour une matrice un vecteur ligne contenant la moyenne de chaque colonne
    la solution proposée par Jérome consiste à transformer ton vecteur colonne de 38520 éléments en une matrice de 107 colonnes contenant 320 éléments chacune
    ainsi la fonction mean appliquée à cette matrice te renvoie un vecteur ligne de 107 éléments étant égaux aux moyennes des 107 colonnes de 320 éléments

    du coup pas besoin de boucle

    Fabien
    Bonjour Fabien
    j'ai à peu compris votre explication de la solution de Jérôme. mais comme j'ai jamais travailler avec les fonctions rand et reshape (les explications que j'ai pu dénicher ne sont pas trop claire à mon gout) mon problème est que comment faire pour inclure mes données dans la matrice. j'ai un fichier texte nommé moyennes_variables qui contient 4 colonnes de 38520 lignes chacun.

    Merci d'avance

  6. #6
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    mars 2005
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : mars 2005
    Messages : 1 563
    Points : 2 760
    Points
    2 760

    Par défaut

    la fonction rand ne sert qu'à générer un vecteur de 38520 ligne
    tu n'en a pas besoin puisque tu as ce vecteur

    la fonction reshape sert quand à elle à transformer le vecteur en matrice, en le découpant en n colonnes de 360 éléments, de manière à utiliser intelligemment la fonction mean

  7. #7
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    octobre 2017
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : octobre 2017
    Messages : 4
    Points : 1
    Points
    1

    Par défaut

    Citation Envoyé par le fab Voir le message
    la fonction rand ne sert qu'à générer un vecteur de 38520 ligne
    tu n'en a pas besoin puisque tu as ce vecteur

    la fonction reshape sert quand à elle à transformer le vecteur en matrice, en le découpant en n colonnes de 360 éléments, de manière à utiliser intelligemment la fonction mean
    Ha je viens de comprendre. merci beaucoup pour votre aide.

Discussions similaires

  1. Calcul d'une moyenne
    Par Doobi dans le forum Excel
    Réponses: 3
    Dernier message: 07/06/2007, 12h30
  2. Calcul d'une moyenne pondérée
    Par BertMont dans le forum PHP & MySQL
    Réponses: 1
    Dernier message: 04/06/2007, 10h49
  3. Calcul d'une moyenne pondérée
    Par solorac dans le forum Excel
    Réponses: 1
    Dernier message: 21/05/2007, 17h54
  4. [Tableaux] Calcul d'une moyenne à partir d'un tableau
    Par Mordanus dans le forum Fonctions
    Réponses: 13
    Dernier message: 09/05/2007, 19h03
  5. requete sql : calcul d'une moyenne
    Par timide94 dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 16/01/2007, 20h12

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