[Bioperl-l] evalues/floating point tests
Chris Fields
cjfields at illinois.edu
Sun Jan 18 17:51:42 EST 2009
On Jan 18, 2009, at 6:01 AM, Sendu Bala wrote:
> Chris Fields wrote:
>> is_float_eq()?
>
> The 'is' obviates the need for the 'eq'. On the other hand there's
> precedent for this, since is() actually calls is_eq().
Yes, that's partly why I suggested it. That's most descriptive of
what we are doing with this method, 'is float $ev1 eq float $ev2'.
>> On Jan 17, 2009, at 8:44 PM, Mark A. Jensen wrote:
>>> how bout is_asfloat() ?
>
> This is better. However...
Sorry, no disrespect to you or Mark but I don't agree. 'Is as float'
doesn't come across to me as an equality test, it almost sounds like a
role/interface check.
>> I thought the same thing at first, but (at least to me) is_float
>> sounds more like a boolean test on whether the scalar value passed is
>> a float rather than a comparison checking whether two floats are
>> equal.
>
> I understand that, but the naming convention is already like that.
> is_deeply() doesn't test if both values are 'deep', it tests if they
> are 'is' (are equal) in a deep way. is_float() would test if they
> are 'is' (are equal) in a float way. Yeah, grammatically it is all a
> mess, but to me this seems the most consistent.
I see what you're saying in this case. We can go back to the simpler
is_float() if everyone agrees. Just want to have something decided so
we can move on.
> The alternative, which may at the same time may be safer (the test
> writer doesn't need to remember to use a special function) and more
> dangerous (the regex matches something it shouldn't?), is to simply
> override is():
>
> my $e_num = '^\de-\d+$';
> sub is {
> my ($val1, $val2, @args) = @_;
>
> if ($val1 && $val2 && $val1 =~ /$e_num/ && $val2 =~ /$e_num/) {
> $val1 = sprintf("%g", $val1);
> $val2 = sprintf("%g", $val2);
> }
>
> return SUPER::is($val1, $val2, @args);
> }
>
> Or something like that. I didn't try it.
I understand the sentiment about extending is() but I'm not convinced
it makes sense for a specific case such as this. I agree with the
second sentiment; extending is() may be more dangerous and prone to
subtle issues, such as the regex above not matching '1.23e-12'. Yes, I
know, you didn't test it. ;>
And, if we ever change our minds it would be very easy to just
delegate to is_float().
$e_num = qr/something that matches just floats/;
sub is {
my ($val1, $val2, @args) = @_;
if ($val1 && $val2 && $val1 =~ /$e_num/ && $val2 =~ /$e_num/) {
return is_float($val1, $val2, @args);
} else {
return SUPER::is($val1, $val2, @args);
}
}
chris
More information about the Bioperl-l
mailing list