[Bioperl-l] Interface of the method

Chris Fields cjfields at illinois.edu
Fri Jun 18 13:41:32 UTC 2010


Jun, 

It all depends on optimization.  I like the named argument version myself.  The current bioperl named parameters implementation requires, in order to parse out the named parameters, you have to call either the core _rearrange() method or Lincoln's rearrange() utility for consistency (deals with all sorts of variants, and Lincoln's allows aliases).  Either way is a small hit, which is fine in most cases, but if the method is called possibly thousands of times it amplifies accordingly and may become a bottleneck on speed.  

You could have your cake and eat it too; check if the first argument is an arrayref and do it it the original way, otherwise use rearrange().  

BTW, this won't work:

'-seqs' => (1, 3, 5..10,15), -toggle => "yes"

The list flattens out into this:

'-seqs', 1, 3, 5, 6, 7, 8, 9, 10, 15, -toggle, "yes" (12 elems) 

So they don't pair up as you would expect; this is a silent bug, as rearrange() will happily assign 1 to 'seqs' and toss the rest unless they are asked for.  With and odd number of elements you would see warnings popping up.

You'll have to use arrayrefs to get proper name-value pairings:

'-seqs', [ 1, 3, 5, 6, 7, 8, 9, 10, 15], -toggle, "yes" (4 elems)

chris

On Jun 18, 2010, at 5:47 AM, Jun Yin wrote:

> Hi, Dave,
> 
> No problem. I think your suggestion of using 
> $newaln=$aln->select_Seqs('-seqs' => (1, 3, 5..10,15), -toggle => "yes"); 
> is more reasonable. It is a more BioPerl way of defined parameters.
> 
> And, $newaln=$aln->select_Seqs(1, 3, 5..10,15); 
> will also be recognized for the simplicity of use.
> 
> Cheers,
> Jun Yin
> Ph.D. student in U.C.D.
> 
> Bioinformatics Laboratory
> Conway Institute
> University College Dublin
> 
> 
> -----Original Message-----
> From: bioperl-l-bounces at lists.open-bio.org [mailto:bioperl-l-bounces at lists.open-bio.org] On Behalf Of Dave Messina
> Sent: Friday, June 18, 2010 10:38 AM
> To: Jun Yin
> Cc: bioperl-l at lists.open-bio.org
> Subject: Re: [Bioperl-l] Interface of the method
> 
> Hi Jun,
> 
> 
>> In the BioPerl guide,
>> http://www.bioperl.org/wiki/Advanced_BioPerl
>> 
>> They say that, Capital word should be used for methods returning  
>> objects,
> 
> You're absolutely right. My apologies — thanks for pointing that out.
> 
> 
>> Thus an array reference
>> [1,3,5..10] seems better than a list (1,3,5..10),
>> the latter will be hard to recognize the other parameters.
> 
> 
>> 
> Aaand, you're right here, too.
> 
> Again, sorry about that. It was quite late last night when I was  
> replying to your email, and I sure wasn't thinking clearly.
> 
> So, please don't mind me, ( carry on, as you were!) and thanks again  
> for your work on this.
> 
> 
> Dave 
> 
> _______________________________________________
> Bioperl-l mailing list
> Bioperl-l at lists.open-bio.org
> http://lists.open-bio.org/mailman/listinfo/bioperl-l
> 
> 
> __________ Information from ESET Smart Security, version of virus signature database 5099 (20100509) __________
> 
> The message was checked by ESET Smart Security.
> 
> http://www.eset.com
> 
> 
> 
> _______________________________________________
> Bioperl-l mailing list
> Bioperl-l at lists.open-bio.org
> http://lists.open-bio.org/mailman/listinfo/bioperl-l





More information about the Bioperl-l mailing list