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

MATLAB Discussion :

Forcer le calcul en simple précision


Sujet :

MATLAB

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2013
    Messages : 3
    Par défaut Forcer le calcul en simple précision
    Bonjour,

    Je suis en train de bosser sur un petit algo et je me heurte un petit soucis (je suis limité en mémoire) et je cherche à regarder si en faisant les calculs en simple précision, la résolution de mes résultats sera toujours bonne.
    J'avais développé un mex qui faisait ça pour moi, mais là je bosse sur une autre fonction qui est assez compliquée à passer en mex, du coup je cherchais à voir comment forcer le calcul en simple précision (notamment à l'intérieur des fonctions prédéfinies).

    J'ai déjà regardé en passant les données d'entrée en single et en faisant tourner l'algo, mais à bien regarder, tous les calculs se font en double.

    Une idée de comment je pourrai procéder ?

    Merci d'avance

  2. #2
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 317
    Par défaut
    Sans plus d'information, je pense malheureusement que seuls les MEX peuvent répondre rapidement à ton besoin.

    Ou alors il faudrait que tu nous montres ton code pour que nous puissions t'aider à l'optimiser.

    Si tu possèdes la Parallel Computing Toolbox, et si l'algorithme répond aux contraintes requises, tu peux peut être aussi envisager de subdiviser ton problème en sous-problème moins gourmands ?

    Bref, donne nous plus d'informations… et de surtout de code

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2013
    Messages : 3
    Par défaut
    Alors en fait j'ai quelques contraintes justement et l'une d'elles est de devoir diminuer substantiellement l'utilisation RAM et les temps de calcul pour pour, à terme, implémenter ça en C.

    Pour donner un exemple de ce que je cherche à faire : J'ai un traitement qui consiste à interpoler mon signal sur une base de temps différente en utilisant simplement la fonction spline :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    samplingData = spline(timeData,Data,newTime);
    J'ai joué sur le type en modifiant les entrées avant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Data = single(Data);
    timeData = single(timeData);
    newTime = single(newTime);
    samplingData = spline(timeData,Data,newTime);
    En procédant comme ça je ne fais rentrer que des variables en simple précision dans la fonction, et donc il me sort un output en simple précision, mais en regardant ce qui se passe à l'intérieur, j'ai constaté que dès le premier calcul intermédiaire, il repasse en double précision et ce jusqu'à la sortie qu'il converti en simple précision.

    Mon idée serait de dupliquer la fonction et de la modifier pour que les calculs soient faits en simple précision (intégralement ou en en laissant certains en double pour conserver de la marge).

    Est ce que c'est un peu plus clair comme ça ?

  4. #4
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 317
    Par défaut
    Que renvoi ceci ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    whos timeData Data newTime
    Sinon, as-tu cherché sur le File Exchange pour des contributions d'interpolation faites avec des fichiers MEX ?
    Il serait sans doute plus simple d'y faire les modifications…

Discussions similaires

  1. Simple précision et nombre de chiffres significatifs
    Par michubuntu dans le forum Fortran
    Réponses: 3
    Dernier message: 11/03/2008, 18h49
  2. Un drôle de résultat pour un calcul si simple . . .
    Par ok07 dans le forum ActionScript 3
    Réponses: 4
    Dernier message: 22/01/2008, 11h46
  3. Forcer le calcul d'une fonction sur des cellules masquées
    Par AAZRO dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/07/2007, 16h34
  4. Faire un calcul trés simple !
    Par nimois3O dans le forum ASP.NET
    Réponses: 9
    Dernier message: 25/05/2007, 14h34
  5. [SQL] calcul tout simple
    Par bibi28 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 30/01/2007, 07h55

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