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

Algorithmes et structures de données Discussion :

MSD calcul d'erreur


Sujet :

Algorithmes et structures de données

  1. #1
    Membre à l'essai
    Inscrit en
    Juin 2008
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 11
    Points : 19
    Points
    19
    Par défaut MSD calcul d'erreur
    Bonjour,

    J'aimerais calculer des MSD de mouvement Brownien et afficher les barres d'erreur. Le code que j'utilise est ci dessous.

    . ma premiere question est la suivante: pour un signal Brownien, je suis censee avoir une MSD lineaire. Pourtant les MSD que j'obtiends ne sont pas vraiment lineairem pourquoi ? ci joint, 2 exemples de MSD calculee par le programme.


    . ma 2eme question concerne les barres d'erreurs: est ce que la formule utilisee set juste ? Pour plus de clarete, les formules utilisees sont dans le fichier "MSD error bar.jpg" ci joint.

    Merci d'avance poru votre aide !
    Naomie


    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
    clc 
    clear all
    close all
     
    %% Generate 1D Brownian motion
    % Set the parameter H and the sample length
    H = 0.3; lg = 100;
    % Generate and plot wavelet-based d for H = 0.3
    d = wfbm(H,lg);
    t=1:1:lg;
     
    %% Calculate the MSD
    GN=size(t);
    GN=GN(2);
     
    for n=1:GN
        temp = 0;
        for i=1:GN-n
            temp = temp+(d(i+n)-d(i))^2;
        end
        msd(n) = 1/(GN-n)*temp;
    end
     
    % Calculate the error bar
    deltad=1; % experimental error bar on d
    for n=1:GN
        timp=0;
        for i=1:GN-n
            timp = timp + 4*(d(i+n)-d(i));
        end
        DMSD(n)=timp*deltad/(GN-n);
    end
     
    %% Plot and fit
    subplot(2,1,1)
    plot(t,d)
    title('Brownien motion')
    xlabel('time')
    ylabel('distance')
     
    % FIT on the first 10% of the msd
    debut=GN/10;
    x=t(2:debut); 
    y=msd(2:debut); 
    f=fittype('c*x');
    fopt=(fitoptions(f));
    fopt.startpoint=[1];
    myfit=fit(x',y',f,fopt)
    myfit=myfit(1:GN/2);
    subplot(2,1,2)
    errorbar(t,msd,DMSD)
    hold on
    plot(myfit,'r')
    title('MSD');
    xlabel('time')
    ylabel('MSD')
    hold off
    Images attachées Images attachées    

Discussions similaires

  1. Réponses: 8
    Dernier message: 22/07/2011, 16h33
  2. [Débutant] Calcul d'erreur entre deux courbes
    Par louftansa dans le forum MATLAB
    Réponses: 14
    Dernier message: 03/06/2009, 15h10
  3. Réponses: 6
    Dernier message: 26/02/2009, 09h41
  4. calculer une erreur d'un transformation matricielle
    Par zerocoolyoussef dans le forum Moteurs 3D
    Réponses: 0
    Dernier message: 24/11/2007, 13h11
  5. calcul d'erreur pour difference finie
    Par rahmani01 dans le forum Algorithmes et structures de données
    Réponses: 1
    Dernier message: 19/05/2007, 04h16

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