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

Bioinformatique Perl Discussion :

correction script pour analyses bayesiennes


Sujet :

Bioinformatique Perl

Mode arborescent

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2013
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2013
    Messages : 12
    Par défaut correction script pour analyses bayesiennes
    Bonjour
    Je travaille sur des analyses evolutives phylogenetiques de type bayesienne avec notamment des software comme beast et j'aurais besoin d'aide pour adapter un script perl afin de retravailler un des fichiers obtenus (fichier txt).
    A partir de ce type de fichier en PJ 'history.txt'


    Je souhaiterais obtenir un fichier final organisé de la sorte (4 colonnes: from - to - time - states)
    from to time states
    A B 69.381812150211935 500000

    Mais le script supprime la colonne 'states'???


    Le script en question:

    #!/usr/bin/perl

    $num_args = $#ARGV + 1;
    if (($num_args != 1) && ($num_args != 3)) {
    print "Usage: collect_times <burning #> [from_state] [to_state]\n";
    exit(-1);
    }

    $burn_in = $ARGV[0];
    $print_all = 1;
    if ($num_args == 3) {
    $print_all = 0;
    $from = $ARGV[1];
    $to = $ARGV[2];
    } else {
    $from = "ALL";
    $to = "ALL";
    }

    print STDERR "Removing states < $burn_in as burn in.\n";
    print STDERR "Recording jumps from $from to $to.\n";

    for ($i = 0; $i < 3; $i++) {
    $line = <STDIN>;
    }

    print "from\tto\ttime\n";
    while($line = <STDIN>) {
    chomp($line);
    ($state, $count, $jumpf) = split('\t',$line,3);
    if ($state >= $burn_in) {
    $jumpf =~ s/\{//;
    $jumpf =~ s/\}//;
    @jumps = split(',',$jumpf);
    $n_jumps = scalar(@jumps);
    for ($i = 0; $i < $n_jumps; $i++) {
    $tmp = $jumps[$i];
    $tmp =~ s/\[//;
    $tmp =~ s/\]//;
    @info = split(':',$tmp);
    $info[2] =~ s/\s\d+$//;
    if (
    ($print_all == 1) ||
    (($info[0] eq $from) && ($info[1] eq $to))
    ) {
    print "$info[0]\t$info[1]\t$info[2]\n";
    }
    }
    }
    }



    Merci beaucoup pour votre aide!!!
    Amicalement,
    Fichiers attachés Fichiers attachés

Discussions similaires

  1. Réponses: 2
    Dernier message: 11/07/2015, 10h59
  2. Script pour lire correctement date access.log
    Par jfg59 dans le forum Linux
    Réponses: 3
    Dernier message: 30/03/2013, 10h54
  3. Réponses: 0
    Dernier message: 17/03/2010, 10h55
  4. Aide pour script d'analyse d'évènements
    Par Spear- dans le forum VBScript
    Réponses: 7
    Dernier message: 18/10/2006, 11h49
  5. Script pour envoyer des info a mysql
    Par rhum1 dans le forum Linux
    Réponses: 6
    Dernier message: 15/04/2003, 16h19

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