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 :

[doParallel] ne pas renvoyer de valeur


Sujet :

R

  1. #1
    Membre actif
    Homme Profil pro
    Inscrit en
    Février 2013
    Messages
    604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 604
    Points : 206
    Points
    206
    Par défaut [doParallel] ne pas renvoyer de valeur
    Bonjour,

    Je génère des plots en parallèle puis les regroupes dans un seul plot avec la fonction grid.arrange. Pour créer un plot je dois avant tout remplir une condition que j'ai représenté par la variable b. Mais comment pourrais-je faire pour que quand la condition n'est pas rempli il n'est rien qui soit ajouté à lp ? Car l'élément null qui s'y ajoute n'est pas accepté lorsque j'utilise la fonction grid.arrange


    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
     
    library(ggplot2)
    library(doParallel)
     
    dt <- data.frame("a"=rnorm(100), "b"=rnorm(100))
     
    cl <- makeCluster(5)
    registerDoParallel(cl)
    b <- c(T,T,F,F,T)
    #lp <- list()
    clusterExport(cl, c("dt", "b")) #,"lp"))
     
    tryCatch(
      {
        lp <- foreach::foreach(i=1:5, .packages = c("pxlsar", "ggplot2")) %dopar%
        {
     
          if(b[i]==T) {
            p <- ggplot(dt, aes(a,b))+ geom_point()+ labs(x = "", y="", title = paste0("plot",i))
     
            return(p)
     
          } else { message("F") }
        } # fin foreach
      }, error=function(e) { message(e); stopCluster(cl) }
    ) # fin tryCatch
     
    stopCluster(cl) 
     
    gp <- gridExtra::grid.arrange(grobs = lp,ncol = 3,
                                  bottom="x",
                                  left="y")

  2. #2
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Corse (Corse)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 476
    Points : 831
    Points
    831
    Par défaut
    bonjour , à tester juste avant le gp

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    #....
     lp <- Filter(Negate(is.null), lp)
    gp <- gridExtra::grid.arrange(grobs = lp,ncol = 3,
                                   bottom="x",
                                   left="y")
    juste une remarque si tu veux réaliser des graphiques tu peux utiliser tidyr::nest()

  3. #3
    Membre actif
    Homme Profil pro
    Inscrit en
    Février 2013
    Messages
    604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 604
    Points : 206
    Points
    206
    Par défaut
    bonjour,
    merci de votre aide.

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

Discussions similaires

  1. Ne pas renvoyer les valeurs NULL
    Par David78180 dans le forum SQL
    Réponses: 6
    Dernier message: 07/11/2008, 14h40
  2. [Excel] Ne pas tracer les valeurs nulles d'un graphe
    Par laloune dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 04/02/2006, 19h00
  3. Renvoyer la valeur dans une fenêtre
    Par ouam81 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 23/12/2005, 11h34
  4. Réponses: 1
    Dernier message: 22/09/2005, 15h46
  5. Réponses: 5
    Dernier message: 25/11/2003, 10h02

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