/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */ #include #include "ns3/core-module.h" #include "ns3/mobility-module.h" #include "ns3/leo-module.h" using namespace ns3; NS_LOG_COMPONENT_DEFINE ("LeoCircularOrbitTracingExample"); void CourseChange (std::string context, Ptr position) { Vector pos = position->GetPosition (); Ptr node = position->GetObject (); std::cout << Simulator::Now () << ":" << node->GetId () << ":" << pos.x << ":" << pos.y << ":" << pos.z << ":" << position->GetVelocity ().GetLength() << std::endl; } int main(int argc, char *argv[]) { CommandLine cmd; std::string orbitFile; std::string traceFile; double duration = 60; cmd.AddValue("orbitFile", "CSV file with orbit parameters", orbitFile); cmd.AddValue("traceFile", "CSV file to store mobility trace in", traceFile); cmd.AddValue("precision", "ns3::LeoCircularOrbitMobilityModel::Precision"); cmd.AddValue("duration", "Duration of the simulation in seconds", duration); cmd.Parse (argc, argv); LeoOrbitNodeHelper orbit; NodeContainer satellites; if (orbitFile.empty()) { satellites = orbit.Install (orbitFile); } else { satellites = orbit.Install ({ LeoOrbit (1200, 20, 32, 16), LeoOrbit (1180, 30, 12, 10) }); } Config::Connect ("/NodeList/*/$ns3::MobilityModel/CourseChange", MakeCallback (&CourseChange)); std::streambuf *coutbuf = std::cout.rdbuf(); // redirect cout if traceFile is specified std::ofstream out; out.open (traceFile); if (out.is_open ()) { std::cout.rdbuf(out.rdbuf()); } std::cout << "Time,Satellite,x,y,z,Speed" << std::endl; Simulator::Stop (Seconds (duration)); Simulator::Run (); Simulator::Destroy (); out.close (); std::cout.rdbuf(coutbuf); }