NAME

perfSONAR_PS::owdb

DESCRIPTION

TBD

owdb_prep()

owdb_prep: this routine is used to initialize the database connection for fetching owamp data. Pass in a ref to a hash, and it will be filled with values for: START END SENT LOST DUPS MIN MAX ERR ALPHA_%08.6f (with the %08.6f replaced ala sprintf for every alpha value passed in using the 'ALPHAS' arg.) ALPHAS (A sub hash with the keys set from the original alphas passed in and the values set to the delay of that "alpha".)

owdb_fetch()

TDB

owdb_plot_script()

TDB

bwdb_plot_script()

TDB

bwdb_dist_plot_script()

TDB

ntpdb_loop_plot_script()

TDB

ntpdb_peer_plot_script()

TDB

ntpdb_color_per_peer_plot_script()

TDB

trdb_plot_script()

TDB

ts_owptstamppldatetime()

TDB

	my $nrecs;
        my $sql;
        my $sth;
        my @row;
	my $sql2;
	my $sth2;
	my @row2;

	######################################################################
	# Definition of parameters

	my $basex = 0; #base for all plots of the traceroute route tree
	my $basey = 0;
	my $stepx = 500;
	my $stepy = 700;
	my $radius= 200;
	my $offsetTextx = 7000;
	my $offsetTexty = 500;

	my $outfile = "route_changes.fig"; 
	my $psfile = "route_changes.ps"; 
	my $pngfile = "route_changes.png"; 
	######################################################################
	#global vars
	my (@arrayOfDates,       @arrayOfRoutes,         %hashOfRoutes,  %hashOfRoutesList,      %arrayOfDefectsByDate);
	my (@listOfRouters, @stringOfRouters);
	my ($maxRoutes, $sumRoutes,     $errorInTrace);
	my (%edge,      %x,     %y,     %error, %name,  %domain); #data about each router [node] and link [edge] in the graph
	my (%miniEdge, @miniRouter); #same but for the timed graphs
	my ($source, $destination); #source and destination nodes
	my $family="hola"; #destination
	my $dir; #source
	my $indir;
	my $maxy;
	my ($widthWeigth);
	my (%nodeIndex, @routeName);
	my @nodeNumbers;
	my ($xfigSummaryTreeWithDomains, $xfigSummaryTree, $xfigTimedTree,
                $printTableWithAllAnomalies, $nodebug);

	$nodebug = 1;
	chomp($dir = `/`);
	$outfile = $dir  "/tmp/traceplots/". $outfile;
	$psfile = $dir  "/tmp/traceplots/". $psfile;
	$pngfile = $dir "/tmp/traceplots/". $pngfile;

	print `rm -rf $outfile $psfile $pngfile`;

	$indir = $dir . "/tmp/tracedata";
	
	#code to generate the input files by quering the database

	#output file
	open (OUT,">$outfile");
	#go over all families
	&goOverAllFamilies();
	close OUT;

	#Convert fig to ps
	#print `fig2dev -L ps -m 0.750 -x -200 -y -1500 -M -e -z Letter $outfile $psfile`;
	print `fig2dev -L ps -m 0.75 $outfile $psfile`;
	#Convert ps to png
	#print `convert $psfile $pngfile`;
	print `gs -dNOPAUSE -q -sDEVICE=png256 -sOutputFile=$pngfile $psfile -dBATCH`;
	$plfh = $pngfile;

	if(!$plfh){
		$nrecs++;
	} else {
		$nrecs =  0;
	}
	return $nrecs;
}

###################################################################### sub printDebug { if (!$nodebug) { print STDERR "@_"; } }

###################################################################### #go over all families sub goOverAllFamilies() {

&printXFigHeader();
my $key;
my $value;

my @file_list;

my @listOfFiles = `ls $indir`;
#       print "\nFile list: @listOfFiles\n";

undef @arrayOfDates;
undef @arrayOfRoutes;
undef %hashOfRoutes;
undef %hashOfRoutesList;
undef %arrayOfDefectsByDate;
$maxRoutes = 0;
$sumRoutes = 0;
$errorInTrace = 0;

my $file;
my $routerNum;
my $router;
my $date;
my @field;
my $fileNumber;

#go over all files
$fileNumber = 0;
foreach $file (@listOfFiles) {
        chop($file);
        $file = $indir . "/" . $file ;
        #print "\nInput file: $file \n";
        open(IN, "<$file");
        $routerNum = 1;
        #if($fileNumber!=0){&SetArrayOfRoutes("$date");}
        &ClearListOfRouters();

        #$date = $1;
        if ($errorInTrace) {printDebug "clearing up the error ($date)\n\n";print "Inside 3.2\n";}
        $errorInTrace = 0;

        my $lineNum=0;
        my $line;
        while ($line=<IN>) {
                #print "Reading Line $line\n";
                if($lineNum==0){
                @routeName[$fileNumber]= $line;
                $lineNum++;
                next;
                }
                $lineNum++;
                if($lineNum > 10000) {last;}
                @field = split ' ', $line ;
                #&InsertRouter(@field[1], $fileNumber);
                &InsertRouter(@field[0], -1);

                $nodeIndex{@field[0]}= "@field[1] @field[2]";


        }
        #This is a new trace

        #if (!$errorInTrace && ($stringOfRouters[0] ne "")) {

        &SetArrayOfRoutes("$fileNumber");
        #print "Inside 3.1\n";
        #}
        #print "String of Routers: @stringOfRouters \n";
        #print "List of Routers: @listOfRouters \n";
        $fileNumber++;
}


#&SetArrayOfRoutes("UNDEF");

&calculateEdges($date);
&xfigTimedTree();
}

###################################################################### sub printXFigHeader() { print OUT "#FIG 3.1\n". # "Landscape\n". "Portrait\n". "Center\n". "Inches\n". "1200 2\n"; } ######################################################################

###################################################################### sub SetArrayOfRoutes() { my ($date) =@_; my ($i, $myStringOfRouters, $myStringOfRouters0);

      for ($i=0; $i < 3; $i++) {
        $myStringOfRouters = $stringOfRouters[$i];
        $myStringOfRouters0 = $stringOfRouters[0];
              if (($i == 0) || ($myStringOfRouters ne $myStringOfRouters0)) {
                      $arrayOfDates[$sumRoutes] = "$date";
              #       print "I am doing something\n";
                      $arrayOfRoutes[$sumRoutes] = $myStringOfRouters;
                      $hashOfRoutes{$myStringOfRouters}=5-$date;
                      #$hashOfRoutes{$date}=$myStringOfRouters;
                      $sumRoutes++;
                      $hashOfRoutesList{$myStringOfRouters}= \@{$listOfRouters[$i]};
                      #if ($maxRoutes < $hashOfRoutes{$myStringOfRouters}) {
                      #       $maxRoutes = $hashOfRoutes{$myStringOfRouters};
                      #}
#                               printDebug "router: $myStringOfRouters=> $hashOfRoutes{$myStringOfRouters}\n";
              }
      }
}
######################################################################
sub GetRouterName() {
      my ($router) = @_;

      return ($router, $router);
}
######################################################################
sub ClearListOfRouters() {
      my $i;
      for ($i=0; $i <= 3; $i++) {
              @{$listOfRouters[$i]}= ();
              $stringOfRouters[$i]="";
}
}
######################################################################
sub InsertRouter() {
      my ($router, $listNum) = @_;
      my $i;

# printDebug "router: $router\n"; if ($listNum >= 0 ) { push(@{$listOfRouters[$listNum]}, "$router"); if ($stringOfRouters[$listNum] ne "") { $stringOfRouters[$listNum] .= "-"; } $stringOfRouters[$listNum] .= "$router"; } else { for ($i=0; $i <= $#listOfRouters; $i++) { push(@{$listOfRouters[$i]}, "$router"); if ($stringOfRouters[$i] ne "") { $stringOfRouters[$i] .= "-"; } $stringOfRouters[$i] .= "$router"; } } }

###################################################################### sub calculateEdges() { my ($date) = @_;

my ($router, $end, $i);
my ($key);

undef %edge;
undef %x;
undef %y;
undef %error;
undef %name;
undef %domain;
#       %edge = %x = %y = ();
my $y=0;
my ($x, $first, $previous);

if ($maxRoutes > 20) {$widthWeigth = 20/$maxRoutes;}
else {$widthWeigth=1;}
$maxy=0;
$destination = "";
my (@routes);
#print "Inside Edge 1.0\n";
#now print the results of all the files
if (%hashOfRoutes !=()) {
        #print "Inside Edge 1.1\n";
        my $mostCommmonRoute =1;
        foreach $key (sort  { $hashOfRoutes{$b} <=> $hashOfRoutes{$a} } keys %hashOfRoutes) {
        #foreach $key (sort  { $hashOfRoutes{$a} <=> $hashOfRoutes{$b} } keys %hashOfRoutes) {
        #my(@routelist);
        #@routelist = keys %hashOfRoutes;
        #print "Route list: @routelist\n";
        #foreach $key (@routelist) {
                #print "Inside Edge 1.2\n";
                printDebug "router: $key=> $hashOfRoutes{$key}\n";
                @routes = split(/-/, $key);
                if ($mostCommmonRoute) {
                        $mostCommmonRoute=0;
                        $source = $routes[0];
                        $destination = $routes[$#routes];
                }

                $first =1;
                $maxy = ++$y;
                $x=0;
                foreach $router (@routes) {
                        $x++;
                        #printDebug "router: $router ($x, $y)\n";
                        if ($first) {
                                $first=0;
                                $previous = "$router";
                                if (! defined  $x{"$router"}) {
                                        ($domain{"$router"}, $name{"$router"})= &GetRouterName($router);
                                        $x{"$router"}=$x;
                                        $y{"$router"}=$y;
                                printDebug "$router ($x, $y, $name{$router}, $domain{$router})\n";
                                }
                                next;
                        }

                        ${$edge{"$router"}}{"$previous"}+=$hashOfRoutes{"$key"};
                        if (! defined  $x{"$router"}) {
                                ($domain{"$router"}, $name{"$router"})= &GetRouterName($router);
                                $x{"$router"}=$x;
                                $y{"$router"}=$y;
                                printDebug "$router ($x, $y, $name{$router}, $domain{$router})\n";
                        }
                        $previous = "$router";
                }
        if ("$router" ne "$destination") {
                        $error{"$router"}++;
                        printDebug "$router error: ".$error{"$router"}."\n";
                        ${$arrayOfDefectsByDate{$date}}{"NotEndingInDestination"}++;
                }
#                               printDebug "$router $destination\n";
  }
$maxy = $y;
}
}
######################################################################

###################################################################### sub calculateMiniEdges() { my ($path, $numPaths) = @_; # printDebug "$path=> $numPaths\n";

undef %miniEdge;
undef @miniRouter;
&recalculateMiniEdges($path, $numPaths);
}
######################################################################
sub recalculateMiniEdges() {
my ($path, $numPaths) = @_;

my ($router);
my ($first, $previous);

# printDebug "$path=> $numPaths\n";

#now print the results of all the files
if (%hashOfRoutes !=()) {
        $first =1;
        foreach $router (split(/-/, $path)) {
#                       printDebug "router: $router ($x, $y)\n";
                push (@miniRouter, "$router");
                if ($first) {
                        $first=0;
                        $previous = "$router";
                        next;
                }
                ${$miniEdge{"$router"}}{"$previous"}+=$numPaths;
        #                                       printDebug "$router ($x, $y)\n";
        $previous = "$router";
}

#print "LIst of miniRouter: @miniRouter\n";
}

} ###################################################################### sub xfigTimedTree() {

my ($centerx,                   $centery,                       $borderx,                       $bordery,                       $width);
my ($startx,                                    $starty,                                        $endx,                                  $endy);
my ($labelx,                    $labely,                                $label, $textx, $texty);
my ($router, $end, $i);
my ($sumEdges, $firstDate);

if (%hashOfRoutes !=()) {
        #print "fig 1.0 \n";
        my $numPaths=1;
        for ($i=0; $i<=$#arrayOfRoutes; $i++) {
                #print "fig 1.1 \n";
#printDebug "path=> $arrayOfRoutes[$i] \n****** $arrayOfRoutes[$i+1]\n";
                if ($numPaths==1) {
                        $firstDate=$arrayOfDates[$i];
                }

                if (((($i+1)<=$#arrayOfRoutes) &&
                                ("$arrayOfRoutes[$i]" eq "$arrayOfRoutes[$i+1]")) &&
                                ((($i+2)<=$#arrayOfRoutes) && ("$arrayOfDates[$i+1]" ne "$arrayOfDates[$i+2]"))) {
                        #print "fig 1.2 \n";
                        $numPaths++;
                        next;
                }

                if ((($i+1)<=$#arrayOfRoutes) &&
                                ("$arrayOfDates[$i]" eq "$arrayOfDates[$i+1]")) {
                        #print "fig 1.3 \n";
                        &calculateMiniEdges($arrayOfRoutes[$i], 1);
                        &recalculateMiniEdges($arrayOfRoutes[$i+1], 1);
#printDebug "path=> $arrayOfRoutes[$i] \n****** $arrayOfRoutes[$i+1]\n";
                        $i++;
                } elsif ((($i+2)<=$#arrayOfRoutes) &&
                                ("$arrayOfDates[$i]" eq "$arrayOfDates[$i+2]")) {
                        #print "fig 1.4 \n";
                        &calculateMiniEdges($arrayOfRoutes[$i], 1);
                        &recalculateMiniEdges($arrayOfRoutes[$i+1], 1);
                        &recalculateMiniEdges($arrayOfRoutes[$i+2], 1);
                        $i++;
                        $i++;
                } else {
                        #print "fig 1.5 \n";
                        &calculateMiniEdges($arrayOfRoutes[$i], $numPaths);
                }

                $maxy=0;

                #Print the route Name first
                print OUT "4 0 0 2 0 0 18 0.0000 4 135 360 $basex $basey @routeName[$i]\\001\n\n";
                $basey+=300;

                foreach $router (@miniRouter) {
                        #print "Router: $router ($x{\"$router\"},$y{\"$router\"})\n";
                        $centerx=$basex+$x{"$router"}*$stepx;
                        $centery=$basey+$y{"$router"}*$stepy;
                        if ($maxy < $y{"$router"}) {$maxy = $y{"$router"};};

                        #printDebug "router: $router ($centerx, $centery)\n";

                        $borderx=$centerx-$radius;
                        $bordery=$centery-$radius;
                        $width=1;
                        print OUT "1 3 0 $width -1 7 0 0 -1 0.000 1 0.0000 $centerx $centery ".
                                "$radius $radius $borderx $bordery $borderx $bordery\n";
                        $labelx=$centerx-$radius;
                        $labely=$centery-$radius;
                        #if ($router =~ /(\w+)\.(\w+)\.(\w+)\.(\w+)/) {
                        #label="$4";
                        #}
                        $label = $router;
                        print OUT "4 0 0 2 0 0 16 0.0000 4 135 360 $labelx $labely $label\\001\n\n";
                        #print OUT "4 0 0 2 0 0 12 0.0000 4 135 360 $labelx $labely test\\001\n\n";

                        $sumEdges=0;
                        foreach $end ( keys %{$miniEdge{"$router"}}) {
                                $startx=$centerx;
                                $starty=$centery;
                                $endx=$basex+$x{"$end"}*$stepx;
                                $endy=$basey+$y{"$end"}*$stepy;
                                $width=int(${$miniEdge{"$router"}}{"$end"}*$widthWeigth);
                                $width=($width?$width:1);
                                $sumEdges+=${$miniEdge{"$router"}}{"$end"};
                                if (($startx == $endx) && ($starty == $endy)) {
                                        #this is looping into itself
                                        $endx=$startx-$radius;
                                        $endy=$starty+$radius*1.5;
                                }
                                print OUT "2 1 0 $width -1 7 0 0 -1 0.000 0 0 -1 0 0 2\n".
                                "         $startx $starty $endx $endy\n";
                                #                                       printDebug "$router $end 2 1 0 $width -1 7 0 0 -1 0.000 0 0 -1 0 0 2\n".
                                #                                               "         $startx $starty $endx                                                                 (=$basex+".$x{"$end"}."*$stepx) $endy \n";
                        }
                        #$labelx=$centerx+$radius*0;
                        #$labely=$centery+$radius+200;
                        #$label=(int($sumEdges/$sumRoutes*100))."%";
                        #if ($label eq "0%") {
                        #$label=(int($sumEdges/$sumRoutes*1000))."%%";
                        #}
                        #if ($label eq "0%%") {
                        #         $label=".".(int($sumEdges/$sumRoutes*10000))."%%";
                        #}
                        #print OUT "4 0 1 2 0 0 12 0.0000 4 135 360 $labelx $labely $label \\001\n\n";

                }
                $basey += ($maxy+1)*$stepy;
                $numPaths=1;
        }

$texty = $offsetTexty+$basey;
$textx = $offsetTextx+$basex;

my $key;
foreach $key (sort (keys %nodeIndex)){
print OUT "4 0 -1 0 0 0 16 0.0000 4 135 360 $stepx $texty $key => $nodeIndex{$key} \\001\n\n";
#$textx += $basex;
$texty += 250;
}

}

#print "Done leaving Timed Tree\n"; }

SEE ALSO

FindBin, POSIX, Fcntl, FileHandle, perfSONAR_PS::OWP, perfSONAR_PS::OWP::Utils, perfSONAR_PS::CGI::Carp, File::Basename

To join the 'perfSONAR-PS' mailing list, please visit:

https://mail.internet2.edu/wws/info/i2-perfsonar

The perfSONAR-PS subversion repository is located at:

https://svn.internet2.edu/svn/perfSONAR-PS

Questions and comments can be directed to the author, or the mailing list. Bugs, feature requests, and improvements can be directed here:

https://bugs.internet2.edu/jira/browse/PSPS

VERSION

$Id: owdb.pm 1814 2008-03-10 19:10:27Z zurawski $

AUTHOR

Jeff Boote, boote@internet2.edu Jason Zurawski, zurawski@internet2.edu

LICENSE

You should have received a copy of the Internet2 Intellectual Property Framework along with this software. If not, see <http://www.internet2.edu/membership/ip.html>

COPYRIGHT

Copyright (c) 2002-2008, Internet2

All rights reserved.

1 POD Error

The following errors were encountered while parsing the POD:

Around line 1892:

=pod directives shouldn't be over one line long! Ignoring all 5 lines of content