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

SL & STL C++ Discussion :

std::complex / ISO C++ / C99 / C++Ox ?


Sujet :

SL & STL C++

  1. #1
    Membre averti
    Inscrit en
    Avril 2008
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 39
    Par défaut std::complex / ISO C++ / C99 / C++Ox ?
    Bonjour,

    La question que je pose porte sur l'éventuelle spécification dans la norme du c++ (et surtout la prochaine norme) de l'implémentation des nombres .

    En effet, beaucoup de codes numériques issus du fortran pré-supposent que un nombre complexe est implémenté en mémoire comme étant la suite de deux nombres de type T, le premier représentant la partie réelle et l'autre la partie imaginaire.

    Une interprétation "objet" de std::complex, qui serait défini par son interface laisserait la possibilité de le représenter d'une manière quelconque. (par exemple module et angle ou encore autre chose).

    En revanche le type complex du C99 spécifie lui aussi une représentation en mémoire comme la succession de la partie réelle et imaginaire.

    Un intérêt d'une telle représentation est qu'un tableau de double de taille 2*n peut être utilisé comme un container n éléments de type complex à l'aide d'un . Une référence sur un type complexe peut donc facilement être obtenue en changeant les parties imaginaires et réelles "en place". Par exemple, c'est l'hypothèse qui est faite par dans l'ouvrage numerical recipes, dans le chapitre sur la FFT.

    Ce problème fait l'objet d'un post de Grosse-Kunstleveet David Abrahams ici:

    http://www.open-std.org/jtc1/sc22/wg...002/n1356.html


    A la connaissance des auteurs du posts, même si celà n'est pas spécifié dans la norme de 98, tous le compilateurs font une représentation des std::complex autorisant cette confusion.

    D'autres liens à ce propos:

    http://www.open-std.org/jtc1/sc22/wg...004/n1589.html

    http://anubis.dkuug.dk/jtc1/sc22/wg2...ctive.html#387

    Si vous savez ce qu'il en est pour la prochaine norme du c++ finalement, ça m'intéresse beaucoup.

    Par ailleurs, que pensez-vous d'un code C++ qui ferait déjà cette supposition sur la représentation du std::complex, au sens ou ça fonctionne sous C99 et sur les compilateurs connus ?

    S.

  2. #2
    Membre chevronné Avatar de Lavock
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    560
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 560
    Par défaut
    Rien de tout ça, en tout cas dans le n3000. Apparemment, on ne pourra pas construire un conteneur de complex avec un tableau de dimension. Pas plus qu'il n'existe un opérateur de conversion pour faire l'inverse.

  3. #3
    Membre averti
    Inscrit en
    Avril 2008
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 39
    Par défaut
    En fait, ce qui est intéressant surtout c'est la validité du reinterpret_cast entre un std::complex<double> et en tableau double[2], et inversement.
    (Pour le problème de la fft en particulier...)

  4. #4
    Alp
    Alp est déconnecté
    Expert confirmé

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Par défaut
    Le std::complex ne "transporte", niveau données, que les deux floats/doubles, rien d'autre. Après c'est que des fonctions. Ce n'est donc pas *si* étonnant que ça.

  5. #5
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Par défaut
    On peut lire dans le n3000 (26.4/4) :
    If z is an lvalue expression of type cv std::complex<T> then:
    — the expression reinterpret_cast<cv T(&)[2]>(z) shall be well-formed,
    — reinterpret_cast<cv T(&)[2]>(z)[0] shall designate the real part of z, and
    — reinterpret_cast<cv T(&)[2]>(z)[1] shall designate the imaginary part of z.
    Moreover, if a is an expression of type cv std::complex<T>* and the expression a[i] is well-defined for an
    integer expression i, then:
    — reinterpret_cast<cv T*>(a)[2*i] shall designate the real part of a[i], and
    — reinterpret_cast<cv T*>(a)[2*i + 1] shall designate the imaginary part of a[i].
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

  6. #6
    Membre averti
    Inscrit en
    Avril 2008
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 39
    Par défaut
    Yes, merci JolyLoic ! C'est exactement ce que je cherchais.

  7. #7
    Membre chevronné Avatar de Lavock
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    560
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 560
    Par défaut
    Citation Envoyé par nikopol82 Voir le message
    ... et inversement.
    Apparemment non pour le "inversement" par contre.

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

Discussions similaires

  1. ISO on TCP (RFC1006)
    Par jfrousval dans le forum Développement
    Réponses: 3
    Dernier message: 27/01/2009, 15h58
  2. std::complex lent ?
    Par yan dans le forum SL & STL
    Réponses: 18
    Dernier message: 03/07/2008, 09h05
  3. Réponses: 5
    Dernier message: 04/08/2003, 21h50
  4. Réponses: 7
    Dernier message: 07/04/2003, 09h35
  5. Réponses: 2
    Dernier message: 21/05/2002, 10h25

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