C++中Secheduler和Events用法(12.27)

2024-04-16 19:32

本文主要是介绍C++中Secheduler和Events用法(12.27),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

继续学习下Secheduler和Events:
事件不能部分执行或者提前执行,event由firing time和handler function组成,从Event衍生的两种类型的对象,分别是:Packets和at events
(1)Scheduler::instance().schedule(&CallBack_handler, &callback_event, CALLBACK_DELAY)
CallBack_handler的原型是:UWALOHA_CallBackHandler,其handle方法:
void UWALOHA_CallBackHandler::handle(Event* e)
{
    mac_->CallbackProcess(e);
}
调用Uwalohamac的CallBackProcess函数,

void UWALOHA::CallbackProcess(Event* e)
{
    callback_->handle(e);
}

Handler* callback_;  // for the upper layer protocol,上层协议

(2)s.schedule(&status_handler,&status_event,txtime+0.01);
status_handler:UWALOHA_StatusHandler,主要包含is_ack布尔型参数,当超时时就会调用handler的handle函数,相当于一个定时的任务。

void UWALOHA_StatusHandler::handle(Event *e){
    mac_->StatusProcess(is_ack_);//UWALOHA_StatusHandler存储了is_ack的信息
}

uwaloha.cc的statusProcess函数如下:

void UWALOHA::StatusProcess(bool is_ack){
    UnderwaterSensorNode* n=(UnderwaterSensorNode*) node_;
    n->SetTransmissionStatus(IDLE);    //设置节点为空闲状态
    
    if( blocked ) {
        blocked = false;
        processPassive();
        return;
    }
    
    if( !ACKOn ) {
        /*Must be DATA*/
        UWALOHA_Status = PASSIVE;
        processPassive();
    }
    else if (ACKOn && !is_ack ) {
        UWALOHA_Status = WAIT_ACK;
    }
}

该函数貌似是为了更新状态所用的,但是会有一定的延迟。在sendPkt中,
if 节点 idle:
    if 包 数据包:
        mac对象进入Wait_ACK
        或 直接进入Passive状态
        status_handler.is_ack() = false;
    else ACK包
        发送ACK
        status_handler.is_ack() = true;
    难道说是记录上次发送包的类型?
    发送数据包后将mac对象状态修改为
    blocked = true;
    s.schedule(&status_handler,&status_event,txtime+0.01),传输时间后更新状态,调用StatusProcess函数

状态转移还不是很清楚,所以需要调试看看在statusProcess之前是什么状态,之后又是什么状态

今天把昨天没看的东西看完了,说白了一天真正工作地没多长时间,所以这个习惯要改阿。

接下来做什么呢?
(1)RSSI全称是“Received Signal Strength Indication”,是接收的信号强度指示,无线发送层的可选部分,用于判定链接质量,可以用于定位,以及是否增大广播发送强度,通常是通过硬件来测试的。
(2)窦志斌的论文用的是累计ACK机制,ACK携带接收段的RSSI值,从而预测下一个时隙的信道强度,如果要借鉴他的思想就要看在仿真层的RSSI模型是在怎么做的
(3)返回的ACK信息,携带信息包括:上一个时隙接收数据包的RSSI,节点剩余能量,


想想要实现的目标是什么:
(1)节省能量:如果信道不号,多次重传消耗能量
(2)为了获得更高的成功率,解决包冲突,因此采用ACK确认机制,为了保证成功率则需要进行重传,而重传是比较消耗能量的。重传的原因是因为节点移动或者干扰(节点移动比较麻烦,还是先考虑静态,干扰可以在底层做文章,但是直接的方法是“符合某种模型的丢包”,这种模型)。

张钢老师的思路,考虑下一跳节点的信道状态,这种方法的好处是同样还是保持着分布式算法的特性,张蕾老师的思路和张钢老师是一样的,在选路是不是依赖位置信息,而是依赖从我到下一跳节点的信息。(这就是下象棋的思路,既然有思路那就得按照这个思路往下走走看)
(1)建立一个合理的丢包模型(泊松模型),也可以是故意延迟回发包。
(2)记录等待到ACK包的时间,backoff的次数,下一条节点的能量信息。
如果是分布式的还有个问题,就是广播出去,在路由层的判断是:<1>我已经转发过这个包;<2>已经有人转发过这个包了;

既然要统计,肯定有个比较,比较的结果是会不会所有的人都不发了?
我隐约懂了,broadcast其实就是flooding,这就是造成了当两个节点对称时,无法接收到包的情况。那么就要规避这种情况,得设计一个能很好的区分的拓扑,其实就是个“移动节点的路由问题”,难道这个就要建立个树?

节点移动相当于丢包
如图所示:
1正常选择4(因为离目标节点更近),把包发给4,4发给5,而5迟迟未反馈给4 ACK,而因此当4再接收到1来的包时,返回给1的ACK将携带信息告知下一跳并不好,让其选择别的节点(这就意味着是有路由表的),或者自己不转发了,让别的节点转发(这个和自身发给5但是没有成功是一样的),那么节点2会转发节点(本来也会转发)

这个思路简单并且容易实现:
2、这么看来一旦迟迟接收不到任何节点的ACK的话,就增大传输功率,能使更多的节点接收到数据包。



这篇关于C++中Secheduler和Events用法(12.27)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/909694

相关文章

C#如何调用C++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

SpringBoot3.4配置校验新特性的用法详解

《SpringBoot3.4配置校验新特性的用法详解》SpringBoot3.4对配置校验支持进行了全面升级,这篇文章为大家详细介绍了一下它们的具体使用,文中的示例代码讲解详细,感兴趣的小伙伴可以参考... 目录基本用法示例定义配置类配置 application.yml注入使用嵌套对象与集合元素深度校验开发

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils

Spring Boot 整合 SSE的高级实践(Server-Sent Events)

《SpringBoot整合SSE的高级实践(Server-SentEvents)》SSE(Server-SentEvents)是一种基于HTTP协议的单向通信机制,允许服务器向浏览器持续发送实... 目录1、简述2、Spring Boot 中的SSE实现2.1 添加依赖2.2 实现后端接口2.3 配置超时时

Java中的@SneakyThrows注解用法详解

《Java中的@SneakyThrows注解用法详解》:本文主要介绍Java中的@SneakyThrows注解用法的相关资料,Lombok的@SneakyThrows注解简化了Java方法中的异常... 目录前言一、@SneakyThrows 简介1.1 什么是 Lombok?二、@SneakyThrows

Python中的getopt模块用法小结

《Python中的getopt模块用法小结》getopt.getopt()函数是Python中用于解析命令行参数的标准库函数,该函数可以从命令行中提取选项和参数,并对它们进行处理,本文详细介绍了Pyt... 目录getopt模块介绍getopt.getopt函数的介绍getopt模块的常用用法getopt模

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Java中Scanner的用法示例小结

《Java中Scanner的用法示例小结》有时候我们在编写代码的时候可能会使用输入和输出,那Java也有自己的输入和输出,今天我们来探究一下,对JavaScanner用法相关知识感兴趣的朋友一起看看吧... 目录前言一 输出二 输入Scanner的使用多组输入三 综合练习:猜数字游戏猜数字前言有时候我们在

java解析jwt中的payload的用法

《java解析jwt中的payload的用法》:本文主要介绍java解析jwt中的payload的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解析jwt中的payload1. 使用 jjwt 库步骤 1:添加依赖步骤 2:解析 JWT2. 使用 N