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

C Discussion :

OpenMp - matrice 1000000


Sujet :

C

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    65
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 65
    Points : 22
    Points
    22
    Par défaut OpenMp - matrice 1000000
    Bonsoir, voilà je suis embêté avec les tableaux 2D...
    Je dois faire une matrice 1000 000 X 1000 000....je sais qu'il faut que j'utilise les mallocs....

    J'ai déjà fait ça avec un tableau simple (390 000 entrées), mais là je cale,
    j'ai des erreurs de segmentations à 40000... bref quelqu'un connait il une version qui fonctionne...?

    Merci beaucoup.

  2. #2
    Rédacteur
    Avatar de Neitsa
    Homme Profil pro
    Chercheur sécurité informatique
    Inscrit en
    Octobre 2003
    Messages
    1 041
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chercheur sécurité informatique

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 041
    Points : 1 956
    Points
    1 956
    Par défaut
    Bonjour,

    Citation Envoyé par Warfdog Voir le message
    Bonsoir, voilà je suis embêté avec les tableaux 2D...
    Je dois faire une matrice 1000 000 X 1000 000....je sais qu'il faut que j'utilise les mallocs....

    J'ai déjà fait ça avec un tableau simple (390 000 entrées), mais là je cale,
    j'ai des erreurs de segmentations à 40000... bref quelqu'un connait il une version qui fonctionne...?

    Merci beaucoup.
    Un rapide calcul me dit que peu d’ordinateurs sur terre ont assez de mémoire pour traiter un tableau aussi gigantesque: (1 * 10^6) * (1 * 10^6) = 1 * 10^12 soit mille milliard d'entrées ! Pour peu que ce soit un tableau d'entiers (4 octets par entier), ça fait un gros paquet...

    Bref, 1000 Go minimum pour un tableau, ça fait beaucoup. Regarde si tu peux retravailler l'algo pour effectuer tes calculs sur moins d'entrées à la fois.

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    65
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 65
    Points : 22
    Points
    22
    Par défaut
    Citation Envoyé par Neitsa Voir le message
    Bonjour,



    Un rapide calcul me dit que peu d’ordinateurs sur terre ont assez de mémoire pour traiter un tableau aussi gigantesque: (1 * 10^6) * (1 * 10^6) = 1 * 10^12 soit mille milliard d'entrées ! Pour peu que ce soit un tableau d'entiers (4 octets par entier), ça fait un gros paquet...

    Bref, 1000 Go minimum pour un tableau, ça fait beaucoup. Regarde si tu peux retravailler l'algo pour effectuer tes calculs sur moins d'entrées à la fois.
    alors effectivement tableau d'entier....notre prof voit grand...trop peut être,
    il veut que l'on test une parrallelisation sur une boucle d'une multiplication matricielle mais sur une matrice tres grande, ....1000 000 je sais pas...mais sur il veut qu'on fasse un essai sur un tableau de 1 X 1000 0000 (tableau 1 quoi), à la rigueur ça peut peut être passer...

    Les tests sont sur un serveur Quad...

    Peut être pour ça qu'il plante trop lourd...

    sinon


    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    int main (int argc, char **argv)
    {
    	int i,j;
    	int nb_ligne,nb_colonne;
     
     
    	printf("Entrer un nombre de ligne : \n");
    	scanf("%d",&nb_ligne);
    	printf("Entrer un nombre de colonne : \n");
    	scanf("%d",&nb_colonne);
    	int **tab=(int**)malloc(nb_ligne*sizeof(int*));
     
    	for(i=0;i<nb_ligne;++i)
    	{
    		tab[i]=(int*)malloc(nb_colonne*sizeof(int));
    	}
     
     
     
     
     
     
    		printf("allocation ok");
    	for(i=0;i<nb_ligne;i++)
    	{
    		free(tab[i]);
    	}
    	free(tab);
    	return 0;
    }
    je pense que mon allocation est correcte du coup..

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    65
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 65
    Points : 22
    Points
    22
    Par défaut
    par contre je ne vois pas comment faire la multiplication matricielle avec cette méthode...

    d'habitude pour des tableaux 2D c'est plus t[i][j]...

  5. #5
    Membre émérite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    1 515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 515
    Points : 2 505
    Points
    2 505
    Par défaut
    Tu devrais commencer par savoir quelle taille de matrice tu veux tester, tu sembles avoir des problèmes avec les chiffres En général on met un espaces tout les 3 chiffres, pas tous les 4 chiffres. Quand tu écris "1000 0000" tu veux dire "10 000 000" ou "100 000" ? Excuses moi si je donne l'impression de te prendre pour un imbécile, mais ça parait bizarre ton histoire. D'autant que c'est des fois "1000 0000" et des fois "1000 000".

    Si tu as des grandes matrices il te faudra un programme 64 bits. Un programme 32 bits ne peut pas adresser plus de 4 GB de mémoire. Et tu n'aura jamais tout ça disponible pour ton heap, puisqu'il te faut aussi de la mémoire pour mapper le kernel, les lib, ton texte, ta stack...

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    65
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 65
    Points : 22
    Points
    22
    Par défaut
    Mes excuses, la fatigue et la fièvre... 1 000 000 oui mais bon j'ai résolu le problème, j'ai corrigé ma source pour faire de la multiplication matricielle, je cherche à le faire la parallélisation correctement.

  7. #7
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Points : 28 119
    Points
    28 119
    Par défaut
    Bonjour,

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    int main (int argc, char **argv)
    {
    	int i,j;
    	int nb_ligne,nb_colonne;
     
     
    	printf("Entrer un nombre de ligne : \n");
    	scanf("%d",&nb_ligne);
    	printf("Entrer un nombre de colonne : \n");
    	scanf("%d",&nb_colonne);
    	int **tab=(int**)malloc(nb_ligne*sizeof(int*));
     
    	for(i=0;i<nb_ligne;++i)
    	{
    		tab[i]=(int*)malloc(nb_colonne*sizeof(int));
    	}
     
    	printf("allocation ok");
    	for(i=0;i<nb_ligne;i++)
    	{
    		free(tab[i]);
    	}
    	free(tab);
    	return 0;
    }
    J'en profite pour glisser quelques remarques sur ton code :
    • Tes entrees ne sont pas securisees (il y a pas mal de posts ici sur les entrees securisees, par exemple avec fgets)
    • Tu declares des variables au milieu du code (tab).
    • Tu as une variable inutilisee (j).
    • Il faut que tu testes le code de retour de chacune de tes allocations, et que tu quittes proprement (c'est a dire en liberant la memoire deja allouee) en cas d'erreur. Tu peux utiliser j pour ce faire.
    • Une fois que tu as libere un espace memoire avec free(), il est de bon ton de faire pointer le pointeur sur NULL, ce qui te permettra d'eviter des soucis.
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

Discussions similaires

  1. matrices * vecteur
    Par delire8 dans le forum Algorithmes et structures de données
    Réponses: 15
    Dernier message: 07/09/2002, 14h15
  2. [CR] entête et pied sur page 1/B de matrice
    Par chloe.j3 dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 04/09/2002, 12h07
  3. Matrice de filtrage ?
    Par gimlithedwarf dans le forum Traitement d'images
    Réponses: 2
    Dernier message: 24/08/2002, 09h44
  4. Gestion de matrice
    Par bzd dans le forum C
    Réponses: 4
    Dernier message: 12/08/2002, 18h19
  5. Comment définir le type matrice ?
    Par charly dans le forum Langage
    Réponses: 7
    Dernier message: 15/06/2002, 21h01

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