routealgo.cc

Go to the documentation of this file.
00001 
00002 /*
00003  * routealgo.cc
00004  * Copyright (C) 2000 by the University of Southern California
00005  * $Id: routealgo.cc,v 1.5 2005/08/25 18:58:11 johnh Exp $
00006  *
00007  * This program is free software; you can redistribute it and/or
00008  * modify it under the terms of the GNU General Public License,
00009  * version 2, as published by the Free Software Foundation.
00010  *
00011  * This program is distributed in the hope that it will be useful,
00012  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00013  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00014  * GNU General Public License for more details.
00015  *
00016  * You should have received a copy of the GNU General Public License along
00017  * with this program; if not, write to the Free Software Foundation, Inc.,
00018  * 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
00019  *
00020  *
00021  * The copyright of this module includes the following
00022  * linking-with-specific-other-licenses addition:
00023  *
00024  * In addition, as a special exception, the copyright holders of
00025  * this module give you permission to combine (via static or
00026  * dynamic linking) this module with free software programs or
00027  * libraries that are released under the GNU LGPL and with code
00028  * included in the standard release of ns-2 under the Apache 2.0
00029  * license or under otherwise-compatible licenses with advertising
00030  * requirements (or modified versions of such code, with unchanged
00031  * license).  You may copy and distribute such a system following the
00032  * terms of the GNU GPL for this module and the licenses of the
00033  * other code concerned, provided that you include the source code of
00034  * that other code when and as the GNU GPL requires distribution of
00035  * source code.
00036  *
00037  * Note that people who make modified versions of this module
00038  * are not obligated to grant this special exception for their
00039  * modified versions; it is their choice whether to do so.  The GNU
00040  * General Public License gives permission to release a modified
00041  * version without this exception; this exception also makes it
00042  * possible to release a modified version which carries forward this
00043  * exception.
00044  *
00045  */
00046 
00047 /*
00048  * Generic helpers (all routing algorithms)
00049  * contributed to ns
00050  * George Riley, Georgia Tech, Winter 2000
00051  */
00052 
00053 #include "config.h"
00054 #ifdef HAVE_STL
00055 
00056 #include <stdio.h>
00057 
00058 #include "routealgo/rnode.h"
00059 
00060 // Forward declarations
00061 
00062 static void PrintPred(nodeid_t, nodeid_t, RoutingVec_t&);
00063 static void NixPred(nodeid_t, nodeid_t, RoutingVec_t&, RNodeVec_t&, NixVec&);
00064 
00065 // Globally visible routines
00066 
00067 void PrintRoute( nodeid_t s, nodeid_t d, RoutingVec_t& pred)
00068 { // Print the route, given source s, destination d and predecessor vector pred
00069   printf("Route to node %ld is : ", d);
00070   PrintPred(s, d, pred);
00071   printf("\n");
00072 }
00073 
00074 // Create the NixVector
00075 void NixRoute( nodeid_t s, nodeid_t d, RoutingVec_t& pred,
00076                RNodeVec_t& nodes, NixVec& nv)
00077 {
00078   NixPred(s, d, pred, nodes, nv);
00079 }
00080 
00081 
00082 // Print the parent list (debug)
00083 void PrintParents(RoutingVec_t& pred)
00084 {
00085   printf("Parent vector is");
00086   for (RoutingVec_it i = pred.begin(); i != pred.end(); i++)
00087     {
00088       printf(" %ld", *i);
00089     }
00090   printf("\n");
00091 }
00092 
00093 // Print the route from the nixvector (debug)
00094 void PrintNix(nodeid_t s, RNodeVec_t nodes, NixVec& nv)
00095 {
00096   printf("Printing Nv from %ld\n", s);
00097   while(1)
00098     {
00099       printf("%ld\n", s);
00100       fflush(stdout);
00101       if (!nodes[s])
00102         {
00103           printf("PrintNix Error, no node for %ld\n", s);
00104           break;
00105         }
00106       printf("Node %ld nixl %ld\n", s, nodes[s]->GetNixl());
00107       Nix_t n = nv.Extract(nodes[s]->GetNixl());
00108       if (n == NIX_NONE) break; // Done
00109       nodeid_t s1 = nodes[s]->GetNeighbor(n);
00110       if (s1 == NODE_NONE)
00111         {
00112           printf("Huh?  Node %ld can't get neighbor %ld\n", s, n);
00113           break;
00114         }
00115       s = s1;
00116     }
00117   printf("\n");
00118   nv.Reset();
00119 }
00120 
00121 
00122 
00123 // helpers
00124 static void PrintPred(nodeid_t s, nodeid_t p, RoutingVec_t& pred)
00125 {
00126   if (s == p)
00127     {
00128       printf(" %ld", s);
00129     }
00130   else
00131     {
00132       if (pred[p] == NODE_NONE)
00133         {
00134           printf(" No path..");
00135         }
00136       else
00137         {
00138           PrintPred(s, pred[p], pred);
00139           printf(" %ld", p);
00140         }
00141     }
00142 }
00143 
00144 static void NixPred(nodeid_t s, nodeid_t p, RoutingVec_t& pred,
00145                     RNodeVec_t& nodes, NixVec& nv)
00146 {
00147   if (s == p)
00148     {
00149       return; // Got there
00150     }
00151   else
00152     {
00153       if (pred[p] == NODE_NONE)
00154         {
00155           if(0)printf(" No path..");
00156           return;
00157         }
00158       else
00159         {
00160           NixPred(s, pred[p], pred, nodes, nv);
00161           NixPair_t n = nodes[pred[p]]->GetNix(p);
00162           if (n.first == NIX_NONE)
00163             { // ! Error.
00164               printf("RouteAlgo::GetNix returned NIX_NONE!\n");
00165               exit(1);
00166             }
00167           if(0)printf("NVAdding ind %ld lth %ld\n", n.first, n.second);
00168           nv.Add(n);
00169         }
00170     }
00171 }
00172 
00173 #endif /* STL */

Generated on Tue Mar 6 16:47:50 2007 for ns2 Network Simulator 2.29 by  doxygen 1.4.6