1.一种基于NS3网络仿真平台的数据链仿真方法,其特征在于,所述数据链仿真方法包括以下步骤:S1,将Link‑16数据链整体模型拆分成不同功能的子模块,包括J系列消息生成处理子类、节点中继子类、NetDevice控制子类、队列组子类、TDMA系统子类、报文处理及信道控制子类和无线信道子类;
S2,创建继承于Application父类的J系列消息生成处理子类,用于创建和接收Link‑16数据链固定格式报文;
S3,创建继承于Object父类的节点中继子类,用于接收处理转发各种不同的固定格式报文,完成Link‑16数据链节点中继的任务;
S4,创建继承于NetDevice父类的NetDevice控制子类,该类对报文进行解析处理、报文包头添加和报文入队操作;
S5,创建继承于Object父类的队列组子类,该类创建队列组;
S6,创建继承于Object父类的TDMA系统子类,通过NS3计时器Simulator::Schedule()实现系统的TDMA功能和对队列组进行出队管理;
S7,创建继承于Object父类的报文处理及信道控制子类,用于将报文拆分成码片组,再基于码片组,通过预先设置的调频图案伪随机选取信道传播码片序列;
S8,创建继承于Channel父类的无线信道子类,用于完成Link‑16数据链的无线信道传输模型;
S9,将上述步骤S2至S8中所创建的子类通过各类中所创建的原语函数和回调函数相关联;
S10,在NS3文件夹的scratch文件夹下创建Link‑16数据链的仿真脚本,对步骤S2至S8做创建类并调用类函数,对Link‑16数据链进行仿真。
2.根据权利要求1所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S2中,创建继承于Application父类的J系列消息生成处理子类的过程包括以下步骤:S21,创建继承于Header父类的J系列消息库以对J系列消息进行生成与读取,具体地,通过NS3网络仿真平台中Packet类的AddHeader函数将J系列消息添加到创建的packet包中,通过NS3网络仿真平台中Packet类的RemoveHeader函数读取packet包中的J系列消息;
S22,创建第一原语函数和第一回调函数以使报文以及非报文信息在J系列消息生成处理子类和节点中继子类之间传输;其中,第一原语函数在NS3网络仿真平台中的作用为将J系列消息生成处理子类中的报文以及非报文信息传输到其它类中,第一回调函数是将其他子类中的报文以及非报文信息传输到J系列消息生成处理子类中;
S23,创建J系列消息生成发送函数SendLink16,用于生成和传输J系列消息;
S24,创建J系列消息接收处理函数RecvLink16,用于J系列消息的接收和处理。
3.根据权利要求1所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S3中,创建继承于Object父类的节点中继子类的过程包括以下步骤:S31,创建第二原语函数和第二回调函数以使报文以及非报文信息在节点中继子类和J系列消息生成处理子类之间传输;创建第三原语函数和第三回调函数以使报文以及非报文信息在节点中继子类和NetDevice控制子类之间传输;
S32,创建节点中继函数RelayPacket(),执行中继节点的节点中继功能;执行过程包括:S321,判断接收到的报文是否来自J系列消息生成处理子类,如果是,记录报文ID后直接将报文传递到NetDevice控制子类中,结束函数;如果不是,转入步骤S322;
S322,读取报文的ID判断报文是否已经接收过,如果已经接收过,结束函数,否则,转入步骤S323;
S323,通过调用容器的添加函数push_back(),记录报文ID;
S324,将报文通过第二回调函数传递给J系列消息生成处理子类;
S325,判断继承于Object父类的节点是否被规划为中继节点,如果为中继节点,则将报文传递给NetDevice控制子类,否则,结束函数。
4.根据权利要求1所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S4中,创建继承于NetDevice父类的NetDevice控制子类的过程包括以下步骤:S41,创建第四原语函数和第四回调函数以使报文以及非报文信息在NetDevice控制类和节点中继子类之间传输;创建第五原语函数和第五回调函数以使报文以及非报文信息在NetDevice控制子类和队列组子类之间传输;
S42,创建继承于Header类的报头库,通过Packet类的AddHeader()函数和RemoveHeader()函数添加和处理报头;
S43,创建报文处理及入队函数PacketHandle(),用于总体控制报头的添加和处理报文的入队操作;
当NetDevice控制子类接收到报文时,首先判断报文是否来自于节点中继子类,如果是,读取节点中继子类传递而来的报文,通过报文的初始字中的标识和子标识判断J系列消息所参与的网络参与群,将含有节点终端航迹号的报头添加到报文后,再将添加报头后的报文根据其网络参与组添加到相应的队列中;否则,通过NS3网络仿真平台中Packet类的RemoveHeader()函数读取报文的报头中的终端航迹号和报头中其它的报文信息,将报文信息和要传输的非报文信息直接上传到节点中继子类中。
5.根据权利要求1所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S5中,创建继承于Object父类的队列组子类的过程包括以下步骤:S51,创建单队列类,该单队列类包含报文的入队函数和出队函数,以及容纳报文的第一容器;
S52,在队列组类中创建第二容器,第二容器根据Link‑16数据链网络参与群个数创建相对应的23个队列组,用于代表固定格式报文中不同的网络参与群类型;
S53,创建第六原语函数、第七原语函数、第八原语函数、第九原语函数分别用于报文的入队、各个单队列的状态传递、控制队列出队和报文出队的操作。
6.根据权利要求1所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S6中,创建继承于Object父类的TDMA系统子类的过程包括以下步骤:S61,创建时隙分配函数SetSlot(),通过NS3网络仿真平台的脚本文件调用该时隙分配函数SetSlot(),使其采用Link‑16数据链中的时隙集方式对时隙进行分配;
S62,创建时分多址函数StartTdmaSessions(),通过NS3网络仿真平台的系统函数Simulator::Schedule()对各个时隙进行跳转操作;
S63,创建第十原语函数和第十一原语函数,通过NS3网络仿真平台的系统函数Simulator::Schedule()来调度第十原语函数和第十一原语函数,分别用于控制队列和读取队列状态传递。
7.根据权利要求6所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S62中,采用时分多址函数 StartTdmaSessions()对各个时隙进行跳转操作的过程包括以下步骤:S621,设置并初始化私有变量TotalSlot=0,开启新的时帧,私有变量TotalSlot用于时隙的计数;
S622,开启计数器TotalSlot,TotalSlot++,进入新的时隙;
S623,根据TotalSlot的值判断当前时隙所在的编号,并通过在仿真开始时就分配好的传播时隙来判断当前时隙是否为执行时分多址函数节点的某个网络参与群发送报文的时间,如果是,转入步骤S624,否则,转入步骤S626;
S624,通过TDMA系统子类的读取队列状态的第七原语函数,判断参与网络参与群的队列是否为空,如果为空,转入步骤S626,否则,转入步骤S625;
S625,将队列中报文通过TDMA系统子类中的队列控制的第十原语函数,向报文处理及信道控制子类发送报文;
S626,调用NS3网络仿真平台的系统函数Simulator::Schedule()设置计时器,根据TotalSlot的值判断是否开启一个新的时帧,若TotalSlot>=1536,则证明当前时帧已经结束,返回步骤S621,重启一个新的时帧,若TotalSlot<1536,则证明当前时帧还没有结束,转入步骤S622,开启一个新的时隙。
8.根据权利要求1所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S7中,创建继承于Object父类的报文处理及信道控制子类的过程包括以下步骤:S71,创建第十二原语函数和第六回调函数以使报文以及非报文信息在报文处理及信道控制子类和NetDevice控制子类之间传输;创建第十三原语函数和第七回调函数以使报文以及非报文信息在报文处理及信道控制子类和NetDevice控制子类之间传输无线信道子类之间传输;
S72,创建PacketManage()函数对报文进行处理,生成码片;
S73,创建跳频图案库;
S74,创建第三容器以容纳Link‑16数据链的51个信道;
S75,创建多个第四容器来同时接收并容纳无线信道接收到的多个码片;
S76,创建码片序列跳频函数ForwardDown(),用于向无线信道子类传递报文;
S77,创建函数Receive(),用于对跳频得到的码片序列进行重组,复现数据包。
9.根据权利要求1所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S76中,采用码片序列跳频函数ForwardDown()向无线信道子类传递报文的过程包括以下步骤:S761,判断接收到的码片序列是否来自队列组报文处理后生成的码片序列组,如果是,从跳频图案库中读取用于跳频的调频图案,转入步骤S762;否则,转入步骤S764;
S762,根据读取的跳频图案所规定的信道传递一个码片序列;
S763,判断是否完成码片序列组的跳频发送,若完成,则结束函数,若没有,通过NS3网络仿真平台的系统函数Simulator::Schedule(),在预设的等待周期后重新执行步骤S762;
S764,判断是否满足已读取码片序列组接下来的跳频图案,如果是,将码片加入满足跳频图案的码片序列组,转入步骤S765;否则,转入步骤S766;
S765,通过满足跳频图案的码片序列组中的码片序列的数量判断码片序列是否能够重组报文,如果能够重组报文,调用报文处理函数,将码片序列重新处理成报文,同时将报文上传到NetDevive控制子类中,结束函数;否则,直接结束函数;
S766,判断收到的码片序列是否对应跳频图案库中的首个跳频图案,如果对应,则创建用于添加码片序列的第五容器,将码片m序列添加到第五容器中,结束函数。
10.根据权利要求1所述的基于NS3网络仿真平台的数据链仿真方法,其特征在于,步骤S8中,创建继承于Channel父类的无线信道子类的过程包括以下步骤:S81,创建第十四原语函数用于接收报文处理及信道控制子类所传递下来的码片序列;
S82,创建无线信道发送码片序列函数Send(),该函数通过调用MobilityModel类以设置节点位置和节点移动模型,通过读取MobilityModel类的位置来判断是否超出通信距离;
该函数还通过调用NS3网络仿真平台的系统函数Simulator::ScheduleWithContext()来对报文进行跨节点传输;
无线信道子类发送码片序列的过程包括以下步骤:
当无线信道子类接收到要发送的码片信息时,通过NS3网络仿真平台中MobilityModel类来读取发送报文节点的位置信息,同时读取绑定在信道上的接收报文节点的位置信息;
假设发送节点和接收节点间的位置分别为 和 ,则两者之间的直线距
离为:
;
通过发送节点和接收节点间的直线距离来判断接收节点是否能够接收到码片序列,如果能够,通过两点间直线距离计算传播时延 为: ,其中,c=299792458m/s,再通过NS3网络仿真平台的系统函数Simulator::ScheduleWithContext()实现码片序列的跨节点发送;否则,结束函数。