news 2026/6/9 8:59:02

NS3仿真——fifth

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
NS3仿真——fifth

fifth引入了tcp的newreno模型,以及信道错误概率,对于tcp拥塞控制的研究,可以后期在此基础上进行更改

1.文件头注释

/* GPL许可证声明 */ #include "tutorial-app.h" // 关键:自定义应用头文件 #include "ns3/applications-module.h" // 应用层模块 #include "ns3/core-module.h" // 核心模块 #include "ns3/internet-module.h" // 网络层模块 #include "ns3/network-module.h" // 网络模块 #include "ns3/point-to-point-module.h" // 点对点链路模块 #include <fstream>

为什么需要自定义应用:

问题1:OnOff应用的socket在启动时才创建,无法在配置时连接跟踪点 问题2:即使能在启动后连接,socket不是public的,无法访问 解决方案:创建自定义的简单应用

2.TCP参数配置

设置拥塞策略为tcpnewreno,类似的还有cubic等;

初始拥塞窗口以及窗口恢复机制同样可以设置

Config::SetDefault("ns3::TcpL4Protocol::SocketType", StringValue("ns3::TcpNewReno")); Config::SetDefault("ns3::TcpSocket::InitialCwnd", UintegerValue(1)); // 初始拥塞窗口=1包 Config::SetDefault("ns3::TcpL4Protocol::RecoveryType", TypeIdValue(TypeId::LookupByName("ns3::TcpClassicRecovery")));

3、网络建立过程

步骤1:创建节点和链路

NodeContainer nodes; nodes.Create(2); // 创建2个节点 PointToPointHelper pointToPoint; pointToPoint.SetDeviceAttribute("DataRate", StringValue("5Mbps")); pointToPoint.SetChannelAttribute("Delay", StringValue("2ms")); NetDeviceContainer devices; devices = pointToPoint.Install(nodes);

步骤2:配置错误模型

Ptr<RateErrorModel> em = CreateObject<RateErrorModel>(); em->SetAttribute("ErrorRate", DoubleValue(0.00001)); // 0.001%错误率 devices.Get(1)->SetAttribute("ReceiveErrorModel", PointerValue(em));

步骤3:安装协议栈和IP地址

InternetStackHelper stack; stack.Install(nodes); // 安装TCP/IP协议栈 Ipv4AddressHelper address; address.SetBase("10.1.1.0", "255.255.255.252"); // 30位掩码 Ipv4InterfaceContainer interfaces = address.Assign(devices);

步骤4:创建接收端应用

uint16_t sinkPort = 8080; Address sinkAddress(InetSocketAddress(interfaces.GetAddress(1), sinkPort)); PacketSinkHelper packetSinkHelper("ns3::TcpSocketFactory", InetSocketAddress(Ipv4Address::GetAny(), sinkPort)); ApplicationContainer sinkApps = packetSinkHelper.Install(nodes.Get(1)); sinkApps.Start(Seconds(0.)); sinkApps.Stop(Seconds(20.));

步骤5:关键部分 - 创建socket并连接跟踪点

Ptr<Socket> ns3TcpSocket = Socket::CreateSocket(nodes.Get(0), TcpSocketFactory::GetTypeId()); ns3TcpSocket->TraceConnectWithoutContext("CongestionWindow", MakeCallback(&CwndChange));

步骤6:创建自定义发送应用

Ptr<TutorialApp> app = CreateObject<TutorialApp>(); app->Setup(ns3TcpSocket, sinkAddress, 1040, 1000, DataRate("1Mbps")); nodes.Get(0)->AddApplication(app); app->SetStartTime(Seconds(1.)); app->SetStopTime(Seconds(20.));

步骤7:连接丢包跟踪点

devices.Get(1)->TraceConnectWithoutContext("PhyRxDrop", MakeCallback(&RxDrop));

4、回调函数分析

1.拥塞窗口变化回调

static void CwndChange(uint32_t oldCwnd, uint32_t newCwnd) { NS_LOG_UNCOND(Simulator::Now().GetSeconds() << "\t" << newCwnd); }

2.接收丢包回调

static void RxDrop(Ptr<const Packet> p) { NS_LOG_UNCOND("RxDrop at " << Simulator::Now().GetSeconds()); }

部分运行截图

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 2:23:41

光刻胶用增感剂:乙氧基/丙氧基改性吡唑啉有机物

1. 基本信息乙氧基/丙氧基改性的吡唑啉有机物是一种专门设计用于光刻胶的增感剂。其核心结构是在吡唑啉环上引入了乙氧基&#xff08;-CH₂-CH₂-O-&#xff09;和/或丙氧基&#xff08;-CH(CH₃)-CH₂-O-&#xff09;链段。这种独特的分子设计使其吸收波段通常在360-400nm之间…

作者头像 李华
网站建设 2026/6/9 19:42:00

TCN-GRU回归+特征贡献SHAP分析+新数据预测+多输出,MATLAB代码

MATLAB代码实现了一个TCN-GRU混合神经网络模型&#xff0c;用于多输出回归预测任务&#xff0c;并集成了SHAP特征重要性分析和新数据预测功能。以下是详细分析&#xff1a; 一、主要功能 TCN-GRU混合模型构建与训练&#xff1a; 结合时序卷积网络&#xff08;TCN&#xff09;和…

作者头像 李华
网站建设 2026/6/9 6:03:41

zotero-arxiv-daily完整指南:快速构建你的个性化论文推荐系统

zotero-arxiv-daily完整指南&#xff1a;快速构建你的个性化论文推荐系统 【免费下载链接】zotero-arxiv-daily Recommend new arxiv papers of your interest daily according to your Zotero libarary. 项目地址: https://gitcode.com/GitHub_Trending/zo/zotero-arxiv-dai…

作者头像 李华
网站建设 2026/6/9 15:15:30

CLIP Surgery

CLIP surgery动机 CLIP存在相反激活问题&#xff0c;意味着它关注图像的背景&#xff0c;而不是前景。 验证实验 反向可视化 Q-K自注意力本来应该在前景位置激活&#xff0c;但是却发现主要在背景位置激活&#xff0c;这说明Q-K学偏了。噪声激活 即使使用空字符串作为类别嵌入&…

作者头像 李华
网站建设 2026/6/5 9:52:58

终极Sionna入门指南:5分钟快速上手下一代物理层研究

终极Sionna入门指南&#xff1a;5分钟快速上手下一代物理层研究 【免费下载链接】sionna Sionna: An Open-Source Library for Next-Generation Physical Layer Research 项目地址: https://gitcode.com/gh_mirrors/si/sionna Sionna是一个开源的Python库&#xff0c;专…

作者头像 李华