Unconfigured Ad

Collapse
X
 
  • Filter
  • Time
  • Show
Clear All
new posts
  • uloeber
    Member
    • Mar 2013
    • 44

    Filtering BLAST results using BioPerl

    Hi all,
    I try to fix the following issue:
    I have a BLAST output from the command line, using PacBio data as queries and a custom database. I have some filtering criteria for my hits, e.g. >db_1 should at least cover 80bp, while >db_2 should cover at least 1000bp.

    In the end I'd like to have a graphical representation of my queries and the corresponding (filtered) hits.
    A refinement would be, if the alignment of db_2 is in total longer than the alignment of db_3, db_3 should be discarded...

    I tried to use Bio::Search::Result::ResultI first. I ended up with a very ugly script, which works and processes my custom blast tab, but I even failed to visualize my results.
    Code:
    while( my $result = $in->next_result ) {
      ## $result is a Bio::Search::Result::ResultI compliant object
      while( my $hit = $result->next_hit ) {
        ## $hit is a Bio::Search::Hit::HitI compliant object
        while( my $hsp = $hit->next_hsp ) {
          ## $hsp is a Bio::Search::HSP::HSPI compliant object
          if( $hit->name =~ m/someexpression/ ) {
           if($hit->name =~ m/db_2/ && $hsp->length('hit')>=90){
                    my $aln = $hsp->get_aln;
                    my $alnIO = Bio::AlignIO->new(-format =>"msf", -file => ">hsp.msf");
                    $alnIO->write_aln($aln);
                    print   $result->query_name, "\t",
                      $hit->name, "\t",
                      $hsp->length('total'), "\t",
                      $hsp->percent_identity, "\t",
                      $hsp->start('query'), "\t",
                      $hsp->end('query'), "\t",
                      $hsp->start('hit'), "\t",
                      $hsp->end('hit'), "\t",
                      $alnIO, "\n";
            }
           elsif($hit->name =~ m/db_2/ && $hsp->length('hit')>=80){
                    my $aln = $hsp->get_aln;
                    my $alnIO = Bio::AlignIO->new(-format =>"msf", -file => ">hsp.msf");
                    $alnIO->write_aln($aln);
                    print   $result->query_name, "\t",
                      $hit->name, "\t",
                      $hsp->length('total'), "\t",
                      $hsp->percent_identity, "\t",
    ...
    Next thing I gave a try was Bio::SearchIO::Writer::HTMLResultWriter;
    Code:
    my $in = new Bio::SearchIO(     -format => 'blast', 
                                    -file   => $ARGV[0]);
    
    
    sub hsp_filter {
            my $hsp = shift;
            return 1 if ($hit->name =~ m/db_1/ && $hsp->length('hit')>=70);
            return 1 if ($hit->name =~ m/db_2/ && $hsp->length('hit')>=65);
     ...
    
    }
    
    my $writer = Bio::SearchIO::Writer::HTMLResultWriter ->new (-filters => {'HSP' => \&hsp_filter});
    my $out = Bio::SearchIO ->new (-writer =>$writer);
    $out ->write_result($in->next_result);
    The problem is, the syntax doesn't work. Of cause, because I mixed up hits and hsp. Is it possible to combine hit and hsp filters?

    I know, that this question is very specific. But maybe anybody struggles on similar issues parsing blast outputs, trying to filter them somehow and visualize the results. I hope I could make my problem clear and maybe anybody could give me a suggestion how to solve it.

    Thanks in advance!

    ps: it doesn't matter whether I parse xml, pure blast or tables, just want to get it to run
  • uloeber
    Member
    • Mar 2013
    • 44

    #2
    Okay, I fixed most of the issues... is anybody aware of how to write multiple panels in an output file using
    while( my $result = $searchio->next_result )
    with
    Bio::Graphics::Panel->new
    ??

    I will post my complete script, when I found a solution and am done

    Comment

    Latest Articles

    Collapse

    • SEQadmin2
      Nine Things a Sample Prep Scientist Thinks About Before Sequencing
      by SEQadmin2


      I’m not a sequencing expert. I’m a purification scientist who uses NGS to evaluate workflows my group develops. With this perspective, we think about the sample first and the NGS workflow second. The sequencer is an exceptionally honest reporter, but it can only report on what you give it, so whether you get clean, interpretable data from an NGS workflow is largely determined before you begin.


      Here are nine questions we think about, in roughly the order they matter, before...
      06-18-2026, 07:11 AM
    • SEQadmin2
      From Collection to Sequencing: Why Sample Preparation and Preservation Define Sequencing Data
      by SEQadmin2


      Data variability is still an issue in sequencing technologies despite the advances in reproducibility and accuracy of these platforms. But the problem does not originate in the sequencing itself, but in the previous steps, before the sample reaches the sequencer.


      The first step is collection, followed by preservation and sample preparation for analysis. Most scientists overlook those steps, but not being careful might just be skewing the experiment’s results.
      ...
      06-02-2026, 10:05 AM
    • SEQadmin2
      Single-Cell Sequencing at an Inflection Point: Early Impacts of New Platforms and Emerging Trends
      by SEQadmin2


      With the launch of new single-cell sequencing platforms in 2026, the field stands at an exciting inflection point. This article surveys the most impactful advances in the field and discusses how they’re reshaping research in cancer, immunology, and beyond.


      Introduction

      Single-cell sequencing technologies have undergone remarkable advances over the past decade, transitioning from low-throughput experimental approaches to highly scalable platforms capable of...
      05-22-2026, 06:42 AM

    ad_right_rmr

    Collapse

    News

    Collapse

    Topics Statistics Last Post
    Started by SEQadmin2, 06-17-2026, 06:09 AM
    0 responses
    21 views
    0 reactions
    Last Post SEQadmin2  
    Started by SEQadmin2, 06-09-2026, 11:58 AM
    0 responses
    40 views
    0 reactions
    Last Post SEQadmin2  
    Started by SEQadmin2, 06-05-2026, 10:09 AM
    0 responses
    46 views
    0 reactions
    Last Post SEQadmin2  
    Started by SEQadmin2, 06-04-2026, 08:59 AM
    0 responses
    49 views
    0 reactions
    Last Post SEQadmin2  
    Working...