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

R Discussion :

Fonction _ nls _ courbe


Sujet :

R

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Inscrit en
    Juin 2010
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 3
    Par défaut Fonction _ nls _ courbe
    Bonjour,

    Je suis confronté à un blocage, je veux faire une courbe d’exponentielle de décroissance. J’utilise le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    tab<-read.table("C:\\Users\\Momadou\\Desktop\\TEST R\\regression.csv",header=TRUE,sep=";",dec=",") 
    tab 
    plot (tab$ROS~tab$FMC) 
    test <- seq(0,200,1) 
    c <- -0.05; b<- 0; a <- 5 
    lines(b+a*exp(c*test),col=4) 
    nlsreg <- nls(ROS ~ b+a*exp(c*test),data=Table,start=list(b=0,a=5,c=-0.05),trace=T)
    Mais comme résultat j’ai ceci en dessous avec le message erreur à la fin:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    550.1471 : 0.00 5.00 -0.05 
    266.0114 : 1.13846736 0.10412358 -0.05087402 
    265.9792 : 1.13828708 0.10449806 -0.09271866 
    265.9161 : 1.1378039 0.1476209 -0.1870380 
    265.6392 : 1.1456370 0.4906249 -1.1208783 
    265.5984 : 1.1359695 0.6315808 -1.2541616 
    265.4990 : 1.1370413 0.6784515 -2.0325196 
    265.2979 : 1.1405639 0.8240748 -10.3728936 
    Erreur dans nls (ROS ~ b + a * exp(c * test), data = tab, start = list(b = 0, : 
    gradient singulier 
    De plus : Il y a eu 27 avis (utilisez warnings() pour les visionner)
    Si je fais warnings(), j’obtiens :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Messages d'avis : 
    1: In lhs - rhs : 
    la taille d'un objet plus long n'est pas multiple de la taille d'un objet plus court 
    2: In .swts * (lhs - rhs) : 
    la taille d'un objet plus long n'est pas multiple de la taille d'un objet plus court 
    3: In .swts * attr(rhs, "gradient") :
    ………… …………………. …………………… ……………………
    Merci pour votre aide

  2. #2
    Membre Expert
    Avatar de pitipoisson
    Homme Profil pro
    Chercheur
    Inscrit en
    Septembre 2006
    Messages
    1 942
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Chercheur
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 942
    Par défaut
    Bonjour et bienvenue,

    Pour commencer, il y a une incohérence dans le nom de la data.frame utilisée
    Citation Envoyé par Komine Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    tab<-read.table("C:\\Users\\Momadou\\Desktop\\TEST R\\regression.csv",header=TRUE,sep=";",dec=",") 
    tab 
    ...
    nlsreg <- nls(ROS ~ b+a*exp(c*test),data=Table,start=list(b=0,a=5,c=-0.05),trace=T)
    Ensuite, si tu as toujours des problèmes de gradient singulier, joue sur les valeurs de départ : e.g. b=0.001, a=16/3,...

  3. #3
    Futur Membre du Club
    Inscrit en
    Juin 2010
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 3
    Par défaut Problème avec nls
    Merci Yves pour ta réponse, j'ai réglé le problème de la cohérance du dataframe mais le problème avec le message d'erreur reste le meme malgré le changement apporté sur les valeurs de a, b, et c.
    Encore en attente d'un coup de pousse.
    Merci

  4. #4
    Invité de passage
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Décembre 2014
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Enseignant Chercheur

    Informations forums :
    Inscription : Décembre 2014
    Messages : 1
    Par défaut modelisation avec nls
    Bonjour,
    Je suis un nouvel utilisateur de nls R. Je travaille sur des données. En fait, c'est sur l'évolution d'une mesure -(pc, pj, py) en fonction du temps.
    Au tracé, on voit bien que les mesures baissent en fonction du temps. Les courbes ont des allures exponentielles decroissantes f(pc)<f(pj)<f(py).
    J'ai choisi le modèle nls(pc~a*exp(-b*(pi/0.01)^2*temps)+c, start=list(a=1, b=10e-10,c=1). J’ai ainsi déterminé les paramètres a,b, et c des différents modèles.
    Contrairement à ce qu'on observe, b de pc> à b de pj et b de py> à b de pj et pc.
    Comment cela est-il possible?

Discussions similaires

  1. courbe des fonctions numériques réelles
    Par alainnoel dans le forum VB.NET
    Réponses: 1
    Dernier message: 14/05/2007, 11h10
  2. Expression d'une fonction à partir d'une courbe
    Par ramrouma dans le forum MATLAB
    Réponses: 2
    Dernier message: 08/01/2007, 17h52
  3. Réponses: 1
    Dernier message: 25/12/2006, 16h03
  4. courbe >> fonction?
    Par guitz dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 17/07/2006, 09h50
  5. Réponses: 4
    Dernier message: 24/11/2005, 19h51

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