File: ATWDumbbench.pm

package info (click to toggle)
libarchive-tar-wrapper-perl 0.42-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 372 kB
  • sloc: perl: 782; makefile: 2
file content (57 lines) | stat: -rw-r--r-- 1,346 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package ATWDumbbench;
use strict;
use warnings;
use parent 'Dumbbench';

sub new {
    my ( $class, @args ) = @_;
    my $self = $class->SUPER::new(@args);
    $self->{atw_measure_map} = {};
    return $self;
}

sub measurements {
    my $self = shift;
    return ( sort { $a <=> $b } values( %{ $self->{atw_measure_map} } ) )[0];
}

sub get_measure {
    my ( $self, $name ) = @_;
    return $self->{atw_measure_map}->{$name};
}

sub get_map {
    my ($self) = @_;
    return $self->{atw_measure_map};
}

sub report_as_text {
    my ($self) = @_;
    my $formatted;

    foreach my $instance ( $self->instances ) {
        my $result     = $instance->result;
        my $result_str = Dumbbench::unscientific_notation($result);

        my $mean  = $result->raw_number;
        my $sigma = $result->raw_error->[0];
        my $name  = $instance->_name_prefix;

        $self->{atw_measure_map}->{ $instance->name } = $result->number;

        $formatted .= sprintf(
            "%sRan %u iterations (%u outliers).\n",
            $name,
            scalar( @{ $instance->timings } ),
            scalar( @{ $instance->timings } ) - $result->nsamples
        );

        $formatted .=
          sprintf( "%sRounded run time per iteration: %s (%.1f%%)\n",
            $name, $result_str, $sigma / $mean * 100 );
    }

    return $formatted;
}

1;