summaryrefslogtreecommitdiffstats
path: root/lib/Smokeping/sorters/StdDev.pm
blob: fc974462bd949a0824334a143dbfab0c213bca7c (plain)
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
package Smokeping::sorters::StdDev;

=head1 NAME

Smokeping::sorters::StdDev - Order the target charts by StdDev

=head1 OVERVIEW

Find the charts with the highest standard deviation among the Pings sent to
a single target. The more smoke - higher the standard deviation.

=head1 DESCRIPTION

Call the sorter in the charts section of the config file

 + charts
  menu = Charts
  title = The most interesting destinations

 ++ stddev
  sorter = StdDev(entries=>4)
  title = Top StdDev
  menu = Std Deviation
  format = Stdandard Deviation %f

=head1 COPYRIGHT

Copyright (c) 2007 by OETIKER+PARTNER AG. All rights reserved.

=head1 LICENSE

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

=head1 AUTHOR

Tobias Oetiker <tobi@oetiker.ch>

=cut

use strict;
use base qw(Smokeping::sorters::base);
use vars qw($VERSION);
$VERSION = 1.0;
use Carp;

# how many values does the matcher need to do it's magic

sub new(@) {
    my $class = shift;
    my $rules = {
        entries => '\d+'
    };
    my $self = $class->SUPER::new( $rules, @_ );
    return $self;
}

sub Desc ($) {
    return "The Standard Deviation sorter sorts the targets by Standard Deviation.";
}    

sub CalcValue($) {
    my $self = shift;
    my $info = shift;
    # $info = { uptime => w,
    #           loss   => x,
    #           median => y,
    #           alert  => z, (0/1)
    #           pings  => [qw(a b c d)]
    #
    my $avg = 0;
    my $cnt = 0;
    my @values = grep { defined $_ } @{$info->{pings}};
    for (@values){ $avg += $_; $cnt++};
    return -1 if $cnt == 0;
    $avg = $avg / $cnt;
    my $dev = 0;
    for (@values){ $dev += ($_ - $avg)**2};
    $dev = sqrt($dev / $cnt);
    return $dev;
}