blob: 63e202e374bf407a39d45ff8ee025368abe3953a [file] [log] [blame]
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
/*
* Copyright (c) 2011 UCLA
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation;
*
* 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Author: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
*/
#include "ccnx-global-routing-helper.h"
#include "ns3/ccnx.h"
#include "../model/ccnx-net-device-face.h"
#include "../model/ccnx-global-router.h"
#include "ns3/ccnx-name-components.h"
#include "ns3/node.h"
#include "ns3/net-device.h"
#include "ns3/channel.h"
#include "ns3/log.h"
#include "ns3/assert.h"
#include "ns3/names.h"
#include "ns3/node-list.h"
#include "ns3/channel-list.h"
#include <boost/lexical_cast.hpp>
#include "boost-graph-ccnx-global-routing-helper.h"
NS_LOG_COMPONENT_DEFINE ("CcnxGlobalRoutingHelper");
using namespace std;
using namespace boost;
namespace ns3 {
void
CcnxGlobalRoutingHelper::Install (Ptr<Node> node)
{
NS_LOG_LOGIC ("Node: " << node->GetId ());
Ptr<Ccnx> ccnx = node->GetObject<Ccnx> ();
NS_ASSERT_MSG (ccnx != 0, "Cannot install CcnxGlobalRoutingHelper before Ccnx is installed on a node");
Ptr<CcnxGlobalRouter> gr = node->GetObject<CcnxGlobalRouter> ();
if (gr != 0)
{
NS_LOG_DEBUG ("CcnxGlobalRouter is already installed: " << gr);
return; // already installed
}
gr = CreateObject<CcnxGlobalRouter> ();
node->AggregateObject (gr);
for (uint32_t faceId = 0; faceId < ccnx->GetNFaces (); faceId++)
{
Ptr<CcnxNetDeviceFace> face = DynamicCast<CcnxNetDeviceFace> (ccnx->GetFace (faceId));
if (face == 0)
{
NS_LOG_DEBUG ("Skipping non-netdevice face");
continue;
}
Ptr<NetDevice> nd = face->GetNetDevice ();
if (nd == 0)
{
NS_LOG_DEBUG ("Not a NetDevice associated with CcnxNetDeviceFace");
continue;
}
Ptr<Channel> ch = nd->GetChannel ();
if (ch == 0)
{
NS_LOG_DEBUG ("Channel is not associated with NetDevice");
continue;
}
if (ch->GetNDevices () == 2) // e.g., point-to-point channel
{
for (uint32_t deviceId = 0; deviceId < ch->GetNDevices (); deviceId ++)
{
Ptr<NetDevice> otherSide = ch->GetDevice (deviceId);
if (nd == otherSide) continue;
Ptr<Node> otherNode = otherSide->GetNode ();
NS_ASSERT (otherNode != 0);
Ptr<CcnxGlobalRouter> otherGr = otherNode->GetObject<CcnxGlobalRouter> ();
if (otherGr == 0)
{
Install (otherNode);
}
otherGr = otherNode->GetObject<CcnxGlobalRouter> ();
NS_ASSERT (otherGr != 0);
gr->AddIncidency (face, otherGr);
}
}
else
{
Ptr<CcnxGlobalRouter> grChannel = ch->GetObject<CcnxGlobalRouter> ();
if (grChannel == 0)
{
Install (ch);
}
grChannel = ch->GetObject<CcnxGlobalRouter> ();
gr->AddIncidency (0, grChannel);
}
}
}
void
CcnxGlobalRoutingHelper::Install (Ptr<Channel> channel)
{
NS_LOG_LOGIC ("Channel: " << channel->GetId ());
Ptr<CcnxGlobalRouter> gr = channel->GetObject<CcnxGlobalRouter> ();
if (gr != 0)
return;
gr = CreateObject<CcnxGlobalRouter> ();
channel->AggregateObject (gr);
for (uint32_t deviceId = 0; deviceId < channel->GetNDevices (); deviceId ++)
{
Ptr<NetDevice> dev = channel->GetDevice (deviceId);
Ptr<Node> node = dev->GetNode ();
NS_ASSERT (node != 0);
Ptr<CcnxGlobalRouter> grOther = node->GetObject<CcnxGlobalRouter> ();
if (grOther == 0)
{
Install (node);
}
grOther = node->GetObject<CcnxGlobalRouter> ();
NS_ASSERT (grOther != 0);
gr->AddIncidency (0, grOther);
}
}
void
CcnxGlobalRoutingHelper::AddOrigin (const std::string &prefix, Ptr<Node> node)
{
Ptr<CcnxGlobalRouter> gr = node->GetObject<CcnxGlobalRouter> ();
NS_ASSERT_MSG (gr != 0,
"CcnxGlobalRouter is not installed on the node");
Ptr<CcnxNameComponents> name = Create<CcnxNameComponents> (boost::lexical_cast<CcnxNameComponents> (prefix));
gr->AddLocalPrefix (name);
}
void
CcnxGlobalRoutingHelper::AddOrigin (const std::string &prefix, const std::string &nodeName)
{
Ptr<Node> node = Names::Find<Node> (nodeName);
NS_ASSERT_MSG (node != 0, nodeName << "is not a Node");
AddOrigin (prefix, node);
}
} // namespace ns3
#include <boost/concept/assert.hpp>
#include <boost/graph/graph_concepts.hpp>
// #include <boost/graph/adjacency_list.hpp>
#include <boost/graph/dijkstra_shortest_paths.hpp>
namespace ns3 {
void
CcnxGlobalRoutingHelper::CalculateRoutes ()
{
BOOST_CONCEPT_ASSERT(( VertexListGraphConcept< CcnxGlobalRouterGraph > ));
BOOST_CONCEPT_ASSERT(( IncidenceGraphConcept< CcnxGlobalRouterGraph > ));
// BOOST_CONCEPT_ASSERT(( ReadablePropertyMapConcept< CcnxGlobalRouterGraph,
// graph_traits < CcnxGlobalRouterGraph >::edge_descriptor > ));
// BOOST_CONCEPT_ASSERT(( PropertyGraphConcept< CcnxGlobalRouterGraph,
// graph_traits < CcnxGlobalRouterGraph >::edge_descriptor,
// edge_weight_t> ));
// BOOST_CONCEPT_ASSERT(( PropertyMapConcept< CcnxGlobalRouterGraph, edge_weight_t,
// graph_traits < CcnxGlobalRouterGraph >::edge_descriptor> ));
CcnxGlobalRouterGraph graph;
Ptr<CcnxGlobalRouter> source = (*NodeList::Begin ())->GetObject<CcnxGlobalRouter> ();
typedef graph_traits < CcnxGlobalRouterGraph >::vertex_descriptor vertex_descriptor;
PredecessorsMap predecessors;
DistancesMap distances;
// std::map< vertex_descriptor, int > distances;
// std::vector<uint32_t> d (num_vertices (graph));
// std::vector<int> distances;
// std::map< vertex_descriptor, std::
dijkstra_shortest_paths (graph, source,
predecessor_map (predecessors)
.
distance_map (distances)
);
// BOOST_CONCEPT_ASSERT(( BidirectionalGraphConcept<CcnxGlobalRouterGraph> ));
// BOOST_CONCEPT_ASSERT(( MutableGraphConcept<CcnxGlobalRouterGraph> ));
// typedef adjacency_list < listS, vecS, undirectedS, no_property, property < edge_weight_t, uint16_t > > Graph;
// typedef Graph::vertex_descriptor Vertex;
// class Graph
// {
// public:
// typedef Ptr<CcnxGlobalRouter> vertex_descriptor;
// typedef pair< Ptr<CcnxGlobalRouter>, Ptr<CcnxGlobalRouter> > edge_descriptor;
// typedef directed_tag directed_category;
// typedef disallow_parallel_edge_tag edge_parallel_category;
// typedef adjacency_graph_tag traversal_category;
// typedef CcnxGlobalRouter::Incidency adjacency_iterator;
// // null_vertex() ???
// // adjacent_vertices(v, g) ???
// };
// Graph graph;
// for (NodeList::Iterator node = NodeList::Begin (); node != NodeList::End (); node++)
// {
// Ptr<CcnxGlobalRouter> gr = (*node)->GetObject<CcnxGlobalRouter> ();
// if (gr == 0)
// continue;
// for (CcnxGlobalRouter::IncidencyList::const_iterator i = gr->GetIncidencies ().begin ();
// i != gr->GetIncidencies ().end ();
// i++)
// {
// add_edge (gr, i->get<1> (), 10, graph);
// }
// break;
// }
}
}