【问题标题】:Need Help in understading ns3 -> RandomWalk2MobilityModel需要帮助了解 ns3 -> RandomWalk2MobilityModel
【发布时间】:2015-01-31 02:59:40
【问题描述】:

我是 NS3 的新手;您能解释一下RandomWalk2dMobilityModel 的工作原理吗?

我正在尝试对一个环境进行建模,在该环境中,用户将获得一个目的地,并且他将以随机生成的速度去那里。可以用这个模型设计吗?

谢谢。

static void 
CourseChange (std::string foo, Ptr<const MobilityModel> mobility)
{
  Vector pos = mobility->GetPosition ();
  Vector vel = mobility->GetVelocity ();
  std::cout << Simulator::Now () << ", model=" << mobility << ", POS: x=" << pos.x << ", y=" << pos.y
            << ", z=" << pos.z << "; VEL:" << vel.x << ", y=" << vel.y
            << ", z=" << vel.z << std::endl;
}

int main (int argc, char *argv[])
{
  Config::SetDefault ("ns3::RandomWalk2dMobilityModel::Mode", StringValue ("Time"));
  Config::SetDefault ("ns3::RandomWalk2dMobilityModel::Time", StringValue ("2s"));
  Config::SetDefault ("ns3::RandomWalk2dMobilityModel::Speed", StringValue ("ns3::ConstantRandomVariable[Constant=1.0]"));
  Config::SetDefault ("ns3::RandomWalk2dMobilityModel::Bounds", StringValue ("0|200|0|200"));

  CommandLine cmd;
  cmd.Parse (argc, argv);

  NodeContainer c;
  c.Create (100);

  MobilityHelper mobility;
  mobility.SetPositionAllocator ("ns3::RandomDiscPositionAllocator",
                                 "X", StringValue ("100.0"),
                                 "Y", StringValue ("100.0"),
                                 "Rho", StringValue ("ns3::UniformRandomVariable[Min=0|Max=30]"));
  mobility.SetMobilityModel ("ns3::RandomWalk2dMobilityModel",
                             "Mode", StringValue ("Time"),
                             "Time", StringValue ("2s"),
                             "Speed", StringValue ("ns3::ConstantRandomVariable[Constant=1.0]"),
                             "Bounds", StringValue ("0|200|0|200"));
  mobility.InstallAll ();
  Config::Connect ("/NodeList/*/$ns3::MobilityModel/CourseChange",
                   MakeCallback (&CourseChange));

【问题讨论】:

    标签: c++ networking simulator ns-3


    【解决方案1】:

    基本上答案是否定的, RandomWalk2dMobilityModel 用于生成具有随机速度的随机方向,如果您想要具有随机速度的特定方向,则必须创建您的模式。

    我创建了一个函数来创建到我传递节点 id、startPosition、endPosition 和当前模拟时间的位置之间的移动。该函数返回在两个位置之间移动所花费的模拟时间

    double GenerateMovementBetweenTwoPosition(Ptr<Node> node, Vector startPosition,Vector newPosition, double time)
    {
        float x,y;
      Ptr<MobilityModel> mobilityModel = node->GetObject<MobilityModel> ();
      //Vector startPosition = mobilityModel->GetPosition();
      double distance = sqrt( pow(startPosition.x - newPosition.x, 2)
              + pow(startPosition.y - newPosition.y, 2)  );
      double tagSpeed = UniformVariable ().GetValue(0.7,1.3);
      double MovementTime = distance/tagSpeed; // time is in seconds as distance in meter and 1.5 m/s
      double distanceStep = distance/ceil(MovementTime);
      for ( int i=1; i <=  (int)ceil(MovementTime); i++)
      {
          if (time+i >= simTime)
              return time;
          x = startPosition.x + ( distanceStep * i / distance )*(newPosition.x - startPosition.x)+ NormalVariable (-2,2).GetValue(); //path width
          y = startPosition.y + ( distanceStep * i / distance )*(newPosition.y - startPosition.y)+ NormalVariable (-2,2).GetValue();
         // std::cout << "x: " << x << " y: "<< y<<std::endl;
          Simulator::Schedule (Seconds (time+i), &MobilityModel::SetPosition, mobilityModel,
         Vector( x, y,  0.0));
    
      }
        return time+ceil(MovementTime);
    
    }
    

    例如,节点 10 在模拟时间 100 从点 A 移动到点 B,此移动需要 50 秒,因此返回模拟时间 150。 但是,如果模拟时间在 140 秒处结束,则此函数将返回 140,因为模拟在轨迹中间结束。

    【讨论】:

      猜你喜欢
      • 2019-03-17
      • 2017-06-19
      • 2016-05-03
      • 1970-01-01
      • 2021-01-18
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多