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 :

4*PI*r*r = 1.0000 ? ? ?


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de _SamSoft_
    Profil pro
    Étudiant
    Inscrit en
    Février 2007
    Messages
    798
    Détails du profil
    Informations personnelles :
    Âge : 33
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2007
    Messages : 798
    Par défaut 4*PI*r*r = 1.0000 ? ? ?
    Bonjour, je crée une DLL mathématique et j'ai une fonction qui ne "fonctionne" pas '(quel jeux de mot : "oh il est fort" .... ) :

    voilà la fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    double SAMSOFT_MATHSDLL_API ss_aire_sphere(double r)//r étant le rayon de la sphère//
    {
        return 4*PI*r*r;
    }
    voilà le programme :
    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
    #include <stdio.h>
    #include <stdlib.h>
    #include "samsoft_maths.h" //Contient les prototypes des fonctions de la Dll
     
    int main()
    {
        double x; //rayon//
        double aire;
     
                printf("\nTapez votre nombre x : ");
                fflush(stdout); 
                scanf("%lf", &x);
                aire = ss_aire_sphere(x);//Appel de la fonction ss_aire_sphere
                printf("l'aire de la sphere vaut %lf\n", aire);
    	system("PAUSE");
    	return EXIT_SUCCESS;
    }
    Quelle est la solution à mon problème ?

    Merci,

  2. #2
    Membre Expert
    Avatar de Gruik
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2003
    Messages
    1 566
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 566
    Par défaut
    Salux,

    J'essairai :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    printf("l'aire de la sphere vaut %lf\n", 4*PI*x*x);
    pour voir

  3. #3
    Membre extrêmement actif

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Par défaut
    En même temps on ne sait pas ce que tu as rentré comme valeur dans x...

  4. #4
    Membre éclairé Avatar de _SamSoft_
    Profil pro
    Étudiant
    Inscrit en
    Février 2007
    Messages
    798
    Détails du profil
    Informations personnelles :
    Âge : 33
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2007
    Messages : 798
    Par défaut
    x = 5 (j'ai testé avec ca )
    Oui mais mes fichiers sont séparés :

    fichier .c de la DLL
    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
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    /*
    Fichier : samsoft_maths.c
    Auteur : Samy Hocine (SamSoft) http://www.samsoft.ift.fr ; samyhocine@hotmail.fr
    Date du commencement: Mercredi 4 fervrier 2007
    Description : Dll incluant divers fonctions mathématiques
    Licence : GNU/GPL
    Information : ss ou SS veut dire SamSoft
    Remarque : la fonction int racine à été prise sur http://c.developpez.com/sources/c/?page=VII
    Remerciements : www.developpez.com et aux membres du forum sur le C http://www.developpez.net/forums/forumdisplay.php?f=18
    */
     
    #include <string.h>
    #include <math.h>
    #include "samsoft_maths.h"
     
    #define LONGUEUR_BUFFER (12+20+20)
    #define TAILLE_BUFFER (LONGUEUR_BUFFER+1)
     
    const double PI = 3.1415926535897932384626433832795;
     
    double ss_racine_carree(double nbr)//Par Anomaly, http://c.developpez.com/sources/c/?page=VII
    {
        return sqrt(nbr);
    }
     
    double SAMSOFT_MATHSDLL_API ss_carre(double a)
    {
        return a*a;
    }
     
    double SAMSOFT_MATHSDLL_API ss_cube(double a)
    {
        return a*a*a;
    }
     
    double SAMSOFT_MATHSDLL_API ss_perimetre_cercle(double r)
    {
        return 2*PI*r;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_cercle(double r) //r = rayon//
    {
        return PI*r*r;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_triangle(double b, double h) //triangle quelconque, b = base et h = hauteur//
    {
        return (b*h)/2;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_triangle_equi(double a) //triangle équilateral, a est la longeur d'un côté//
    {
        double racine_3;
        racine_3 = sqrt(3);
        return (a*a*racine_3)/4;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_triangle_rect(double b, double c) //triangle rectangle, b et c sont les longeurs de deux côtés autres que l'hypothénuse//
    {
        return (b*c)/2;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_rectangle(double l, double m)//l = longeur ; m = largeur/
    {
        return l*m;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_carre(double a)//a étant la longeur d'un côté//
    {
        return a*a;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_parallelogramme(double b, double h)//b étant la base et h la hauteur//
    {
        return b*h;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_losange(double b, double h)//b étant la base et h la hauteur//
    {
        return (b*h)/2;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_trapeze(double a, double b, double h)//b étant la base et h la hauteur et a la longeur du côté du dessus//
    {
        return 0.5*(a+b)*h;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_sphere(double r)//r étant le rayon de la sphère//
    {
        return 4*PI*r*r;
    }
     
    double SAMSOFT_MATHSDLL_API ss_volume_sphere(double r)//r étant le rayon de la sphère//
    {
        return 1.3333333333*PI*r*r*r;
    }
     
    double SAMSOFT_MATHSDLL_API ss_volume_pyramide(double b, double h)//b est la base d'aire et h la hauteur//
    {
        return 0.3333333333*b*h;
    }
     
    double SAMSOFT_MATHSDLL_API ss_volume_tetraedre(double b, double h)//b est la base d'aire et h la hauteur//
    {
        return 0.3333333333*b*h;
    }
     
    double SAMSOFT_MATHSDLL_API ss_volume_cone_revolution(double r, double h)//r est le rayon de la base qui est un cercle et h la hauteur//
    {
        return 0.3333333333*PI*r*r*h;
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_pave_droit(double a, double b, double c)//a, b et c sont des longeurs//
    {
        return 2*(a*b+b*c+a*c);
    }
     
    double SAMSOFT_MATHSDLL_API ss_volume_pave_droit(double a, double b, double c)//a, b et c sont des longeurs//
    {
        return (a*b*c);
    }
     
    double SAMSOFT_MATHSDLL_API ss_aire_cube(double a)//a étant la longeur d'un côté//
    {
        return 6*a*a;
    }
     
    double SAMSOFT_MATHSDLL_API ss_volume_cube(double a)//a étant la longeur d'un côté//
    {
        return a*a*a;
    }
     
    double SAMSOFT_MATHSDLL_API ss_volume_cylindre_revolution(double r, double h)//r est le rayon de la base (qui est un cercle) et h la hauteur entre la base et la surface du dessus//
    {
        return PI*r*r*h;
    }
     
    double SAMSOFT_MATHSDLL_API ss_addition(double a, double b)
    {
        return a+b;
    }
     
    double SAMSOFT_MATHSDLL_API ss_soustraction(double a, double b)
    {
        return a-b;
    }
     
    double SAMSOFT_MATHSDLL_API ss_multiplication(double a, double b)
    {
        return a*b;
    }
     
    double SAMSOFT_MATHSDLL_API ss_division(double a, double b)
    {
        return a/b;
    }
     
    char* SAMSOFT_MATHSDLL_API ss_calc_a_b_fct_lineaire(double y1, double y2, double x1, double x2)
    {
        //fonction permettant de trouver a et b d'une fonction linéaire de manière algébrique//
        //fonction exemple : f(x) = ax + b
        double a;
        double b;
        char* pBuffer = malloc(TAILLE_BUFFER * sizeof(*pBuffer));
     
        a = (y1 - y2)/(x1 - x2);
        b = y1 - a*x1;
     
        if(pBuffer != NULL)
        {
            sprintf(pBuffer, "f(x) = %fx + %f", a, b);
        }
     
        return pBuffer;
    }
    fichier .c du programme :

    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
    #include <stdio.h>
    #include <stdlib.h>
    #include "samsoft_maths.h" //Contient les prototypes des fonctions de la Dll
     
    int main()
    {
        double x; //rayon//
        double aire;
     
                printf("\nTapez votre nombre x : ");
                fflush(stdout); 
                scanf("%lf", &x);
                aire = ss_aire_sphere(x);//Appel de la fonction ss_aire_sphere
                printf("l'aire de la sphere vaut %lf\n", aire);
    	system("PAUSE");
    	return EXIT_SUCCESS;
    }
    fichier .h :
    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
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    /*
    Fichier : samsoft_maths.h
    Auteur : Samy Hocine (SamSoft) http://www.samsoft.ift.fr ; samyhocine@hotmail.fr
    Date du commencement: Mercredi 4 fervrier 2007
    Description : None
    Licence : GNU/GPL
    Information : ss ou SS veut dire SamSoft
    */
     
    #ifndef H_SAMSOFT_MATHSDLL_20070214181222
    #define H_SAMSOFT_MATHSDLL_20070214181222
     
    #ifdef SAMSOFT_MATHSDLL_BUILD
    #define SAMSOFT_MATHSDLL_API __declspec(dllexport)
    #else
    #define SAMSOFT_MATHSDLL_API __declspec(dllimport)
    #endif
     
    extern const double PI;
     
    double SAMSOFT_MATHSDLL_API ss_racine_carree(double nbr);
    double SAMSOFT_MATHSDLL_API ss_carre(double a);
    double SAMSOFT_MATHSDLL_API ss_cube(double a);
    double SAMSOFT_MATHSDLL_API ss_perimetre_cercle(double r);
    double SAMSOFT_MATHSDLL_API ss_aire_cercle(double r);
    double SAMSOFT_MATHSDLL_API ss_aire_triangle(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_triangle_equi(double a);
    double SAMSOFT_MATHSDLL_API ss_aire_triangle_rect(double b, double c);
    double SAMSOFT_MATHSDLL_API ss_aire_rectangle(double l, double m);
    double SAMSOFT_MATHSDLL_API ss_aire_carre(double a);
    double SAMSOFT_MATHSDLL_API ss_aire_parallelogramme(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_losange(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_trapeze(double a, double b, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_sphere(double r);
    double SAMSOFT_MATHSDLL_API ss_volume_sphere(double r);
    double SAMSOFT_MATHSDLL_API ss_volume_pyramide(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_volume_tetraedre(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_volume_cone_revolution(double r, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_pave_droit(double a, double b, double c);
    double SAMSOFT_MATHSDLL_API ss_volume_pave_droit(double a, double b, double c);
    double SAMSOFT_MATHSDLL_API ss_aire_cube(double a);
    double SAMSOFT_MATHSDLL_API ss_volume_cube(double a);
    double SAMSOFT_MATHSDLL_API ss_volume_cylindre_revolution(double r, double h);
    double SAMSOFT_MATHSDLL_API ss_addition(double a, double b);
    double SAMSOFT_MATHSDLL_API ss_soustraction(double a, double b);
    double SAMSOFT_MATHSDLL_API ss_multiplication(double a, double b);
    double SAMSOFT_MATHSDLL_API ss_division(double a, double b);
    char* SAMSOFT_MATHSDLL_API ss_calc_a_b_fct_lineaire(double y1, double y2, double x1, double x2);
     
    #endif

  5. #5
    Membre éclairé Avatar de _SamSoft_
    Profil pro
    Étudiant
    Inscrit en
    Février 2007
    Messages
    798
    Détails du profil
    Informations personnelles :
    Âge : 33
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2007
    Messages : 798
    Par défaut
    Quelqu'un aurait-il une idée ?

  6. #6
    Expert confirmé

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    4.0*PI*r*r

    et dans le .h

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    #ifndef PI
    #define PI 3.1416
    #endif

  7. #7
    Membre éclairé Avatar de _SamSoft_
    Profil pro
    Étudiant
    Inscrit en
    Février 2007
    Messages
    798
    Détails du profil
    Informations personnelles :
    Âge : 33
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2007
    Messages : 798
    Par défaut
    Mon programme m'affiche 78.3 (et des chiffres après la virgules) et ma calculettre m'affirme que c'est : 314,1592654 pour

    4.0*PI*r*r avec r = 5

    Quel est le problème ? :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    double SAMSOFT_MATHSDLL_API ss_aire_sphere(double r)//r étant le rayon de la sphère//
    {
        return 4.0*PI*r*r;
    }
    fichier .h :

    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
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    /*
    Fichier : samsoft_maths.h
    Auteur : Samy Hocine (SamSoft) http://www.samsoft.ift.fr ; samyhocine@hotmail.fr
    Date du commencement: Mercredi 4 fervrier 2007
    Description : None
    Licence : GNU/GPL
    Information : ss ou SS veut dire SamSoft
    */
     
    #ifndef H_SAMSOFT_MATHSDLL_20070214181222
    #define H_SAMSOFT_MATHSDLL_20070214181222
     
    #ifdef SAMSOFT_MATHSDLL_BUILD
    #define SAMSOFT_MATHSDLL_API __declspec(dllexport)
    #else
    #define SAMSOFT_MATHSDLL_API __declspec(dllimport)
    #endif
     
    #ifndef PI
    #define PI 3,1415926535
    #endif
     
    double SAMSOFT_MATHSDLL_API ss_racine_carree(double nbr);
    double SAMSOFT_MATHSDLL_API ss_carre(double a);
    double SAMSOFT_MATHSDLL_API ss_cube(double a);
    double SAMSOFT_MATHSDLL_API ss_perimetre_cercle(double r);
    double SAMSOFT_MATHSDLL_API ss_aire_cercle(double r);
    double SAMSOFT_MATHSDLL_API ss_aire_triangle(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_triangle_equi(double a);
    double SAMSOFT_MATHSDLL_API ss_aire_triangle_rect(double b, double c);
    double SAMSOFT_MATHSDLL_API ss_aire_rectangle(double l, double m);
    double SAMSOFT_MATHSDLL_API ss_aire_carre(double a);
    double SAMSOFT_MATHSDLL_API ss_aire_parallelogramme(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_losange(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_trapeze(double a, double b, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_sphere(double r);
    double SAMSOFT_MATHSDLL_API ss_volume_sphere(double r);
    double SAMSOFT_MATHSDLL_API ss_volume_pyramide(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_volume_tetraedre(double b, double h);
    double SAMSOFT_MATHSDLL_API ss_volume_cone_revolution(double r, double h);
    double SAMSOFT_MATHSDLL_API ss_aire_pave_droit(double a, double b, double c);
    double SAMSOFT_MATHSDLL_API ss_volume_pave_droit(double a, double b, double c);
    double SAMSOFT_MATHSDLL_API ss_aire_cube(double a);
    double SAMSOFT_MATHSDLL_API ss_volume_cube(double a);
    double SAMSOFT_MATHSDLL_API ss_volume_cylindre_revolution(double r, double h);
    double SAMSOFT_MATHSDLL_API ss_addition(double a, double b);
    double SAMSOFT_MATHSDLL_API ss_soustraction(double a, double b);
    double SAMSOFT_MATHSDLL_API ss_multiplication(double a, double b);
    double SAMSOFT_MATHSDLL_API ss_division(double a, double b);
    char* SAMSOFT_MATHSDLL_API ss_calc_a_b_fct_lineaire(double y1, double y2, double x1, double x2);
    char* SAMSOFT_MATHSDLL_API ss_calc_a_fct_affine(double y1, double y2, double x1, double x2);
     
    #endif
    mon programme :

    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
    #include <stdio.h>
    #include <stdlib.h>
    #include "samsoft_maths.h" //Contient les prototypes des fonctions de la Dll
     
    int main()
    {
        double x; //x est le rayon//
        double aire;
     
                printf("\nTapez votre nombre : ");
                fflush(stdout);
                scanf("%lf", &x);
                aire = ss_aire_cercle(x);//Appel de la fonction ss_aire_cercle
                printf("l'air du cercle vaut %lf\n", aire);
    	system("PAUSE");
    	return EXIT_SUCCESS;
    }

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

Discussions similaires

  1. Date Du jour au format 00/00/0000
    Par Meunier dans le forum Collection et Stream
    Réponses: 5
    Dernier message: 05/09/2006, 23h05
  2. [sql] [débutant] vraifaux =forme 00/00/0000?
    Par Christophe93250 dans le forum Access
    Réponses: 3
    Dernier message: 03/02/2006, 14h30
  3. Affiche de la date 0000-00-00 par défaut !
    Par Zebulonn dans le forum Requêtes
    Réponses: 13
    Dernier message: 01/07/2005, 11h36

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