Indeed an interesting and clean approach!! As minor remark for a side note, when doing numerical integration one may likely be concerned about speed - not that relevant after all: I know full well that "premature optimization is the root of all evil", and if one is really concerned then he'd probably not doing this in Perl at all...
But all those dereferentiations and method accesses do not make for *speed* and apart a clean syntax I'm not really sure about what this gives you more than a C-style for loop which for once seems appropriate! (Most often in my experience it is not.)
Whatever, I stress once again that especially for educational purposes I find it great. In this sense, just for fun here's my rewrite of your code according to my own stylistic preferences. It should be just the same as yours modulo one tiny change in logic ("adaptive delta")
.
#!/usr/bin/perl
use strict;
use warnings;
package Range;
sub new {
my ($class, $lower, $upper, $delta) = @_;
bless {
lower => $lower,
upper => $upper,
delta => $delta || ($upper-$lower)/1000,
current => $lower,
}, $class;
}
sub next {
my $self = shift;
($self->{current} += $self->{delta}) < $self->{upper};
}
package main;
sub integrate {
my ($function, $iter) = @_;
my $sum;
$sum += $function->($iter->{current}) * $iter->{delta} while $iter
+->next;
$sum;
}
printf "%.2f\n", integrate sub {(shift)**2}, new Range (2, 5);
__END__