物联网与射频识别技术,课程实验(四)

news2024/11/16 8:51:38

实验4—— 基于帧的时隙ALOHA(FSA)算法的实现与性能分析

实验说明: 利用Python或Matlab模拟基于帧的时隙ALOHA算法; 分析标签数量k、帧中所含时隙个数n对信道利用率的影响,其中, 信道利用率=发送数据的时间/(发送数据的时间+信道空闲的时间) 利用Python或Matlab画出相应的曲线,并分析算法的优缺点。

 FSA.py:

"""
1.利用Python或Matlab模拟基于帧的时隙ALOHA算法;
2.分析标签数量k、帧中所含时隙个数n对信道利用率的影响,其中,信道利用率=发送数据的时间/(发送数据的时间+信道空闲的时间)
3.利用Python或Matlab画出相应的曲线,并分析算法的优缺点。
"""
import random

from task4_FSA.Tag import Tag
import numpy as np
import matplotlib.pyplot as plt

font3 = {'family': 'SimHei',
         'weight': 'normal',
         'size': 20,
         }

def cal(tagNum, slotNum):
    """
    function: 计算标签数量为k、帧中所含时隙个数为n时的信道利用率
    :param tagNum: 标签数量
    :param slotNum: 帧中所含时隙个数
    :return: 返回信道利用率
    """
    # print(tagNum, slotNum)
    tagList = []
    vis = []
    for i in range(tagNum):
        tag = Tag()
        # tag.slot = random.randint(0, slotNum)
        tag.id = "tag" + str(i)
        tagList.append(tag)
        vis.append(False)

    flag = 0
    cntSum = 0
    while 1:  # 不知道需要多少帧数才能完成所有标签发送
        for i in range(tagNum):  #新的一帧 全部重置随机数
            tagList[i].slot = random.randint(0, slotNum)

        for j in range(slotNum):
            cnt = 0
            index = None

            for i in range(tagNum):
                cntSum += 1
                if vis[i]:
                    flag += 1
                    continue
                if tagList[i].slot == 0:  # 该标签还没有静默
                    cnt += 1
                    index = i
                tagList[i].slot -= 1

            if flag >= tagNum:
                print(tagNum, cntSum, tagNum / cntSum)
                return tagNum / cntSum
            if cnt == 1:  # 未冲突 只有一个标签在该时隙发送数据 即单时隙
                vis[index] = True
            elif cnt > 1:  #冲突时隙
                pass
            else:  # 空时隙
                pass

def main():
    tagNum = 250
    slotNum = 70

    ratio = []
    # print('---------------标签数量k对信道利用率的影响--------------')
    #
    # for i in range(1, tagNum):
    #     rate = []
    #     for j in range(3):
    #         t = cal(i, i)  # 默认每帧时隙数为最优帧长 即tagNum
    #         rate.append(t)
    #     ratio.append(np.average(rate))
    #
    # plt.plot(np.arange(1, tagNum), ratio, color='r', linestyle='--', marker='*', linewidth=2.0)
    # plt.xlabel('标签数量', font3)
    # plt.ylabel('信道利用率', font3)
    # plt.show()
    #
    # ratio.clear()
    # print('---------------帧中所含时隙个数n对信道利用率的影响--------------')
    # for i in range(5, slotNum):
    #     rate = []
    #     for j in range(3):
    #         t = cal(25, i)  # 默认有25个标签 帧长从1到slotNum
    #         rate.append(t)
    #     ratio.append(np.average(rate))
    #     # print(i, np.average(rate))
    #
    # plt.plot(np.arange(5, slotNum), ratio, color='g', linestyle='-', marker='*', linewidth=2.0)
    # plt.xlabel('帧中所含时隙个数', font3)
    # plt.ylabel('信道利用率', font3)
    # plt.show()

    ratio.clear()
    print('---------------不同帧长对信道利用率的影响--------------')

    for i in range(1, tagNum*2):
        rate = []
        for j in range(3):
            t = cal(i, 32)  # 默认每帧时隙数为最优帧长 即tagNum
            rate.append(t)
        ratio.append(np.average(rate))

    plt.plot(np.arange(1, tagNum*2), ratio, color='r', linestyle='-', marker='*', linewidth=2.0, label='32')

    for i in range(1, tagNum*2):
        rate = []
        for j in range(3):
            t = cal(i, 64)  # 默认每帧时隙数为最优帧长 即tagNum
            rate.append(t)
        ratio.append(np.average(rate))

    plt.plot(np.arange(1, tagNum*2), ratio, color='g', linestyle='-', marker='*', linewidth=2.0, label='64')

    for i in range(1, tagNum*2):
        rate = []
        for j in range(3):
            t = cal(i, 128)  # 默认每帧时隙数为最优帧长 即tagNum
            rate.append(t)
        ratio.append(np.average(rate))

    plt.plot(np.arange(1, tagNum*2), ratio, color='b', linestyle='-', marker='*', linewidth=2.0, label='128')
    plt.xlabel('标签数量', font3)
    plt.ylabel('信道利用率', font3)

    plt.show()

if __name__ == '__main__':
    main()

Tag.py可以不用管,没有用到

常用的防碰撞算法其特点:

(1)ALOHA:随机竞争

  • 核心思想:需要发送的数据包立刻发送
  • 最大信道利用率:18.4%

(2)时隙ALOHA:

  • 核心思想:时间分成小的间隙,电子标签只在下一个间隙开始时才可以发送数据包
  • 最大信道利用率:36.8%

(3)动态时隙ALOHA:

  • 发生潜在碰撞时逐步增加标签可用的时隙数,直到有一个标签可以发送成功
  • (根据标签碰撞和空闲的概率来调整帧长)

(4)二进制搜索算法

  • 只有符合限制的标签才应答

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/132571.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【JavaEE】线程的状态转换

新年快乐! 祝新的一年万事胜意! 魅力无限! 随心所欲! 蒸蒸日上! 文章目录1. 线程的基本状态2.Java中线程的状态3. 线程的转换1. 线程的基本状态 操作系统中线程有三个基本状态,就绪状态,运行状态,阻塞状态. 就绪状态, 已经获得除CPU之外的所有资源,只要得到CPU,可立即执行. …

(二十五)大白话数据库无法连接故障的定位,Too many connections

文章目录 1、你是否遇到过Too many connections?2、linux的文件句柄数量被限制1、你是否遇到过Too many connections? 今天要给大家分析另外一个真实的大家都经常会碰到的数据库生产故障,就是数据库无法连接的问题。 大家会看到的异常信息往往是“ERROR 1040(HY000): Too …

ubuntu18.04下mysql数据库安装和C语言连接操作

数据库在应用系统开发中很常见,在众多的数据库中,mysql总是会占有一席之地。本篇说明一下如何在ubuntu18.04上安装mysql数据库。 目录 1.更新环境 2.安装mysql数据库系统 3.检测是否安装成功 4.启动、重启、关闭,删除 5.给root用户设置…

vue3+Ts使用vuex模块化和非模块化管理的2种方式(非pinia)

官网写的很清楚:https://vuex.vuejs.org/zh/guide/typescript-support.html 2种方式 (都不是使用pinia的) 1:复杂版本(不定义自己的 useStore 组合式函数) 使用的时候需要在vuex引入 useStore 在store文件引入导出的key import { useStore } from ‘vu…

CSS3新增的has伪类选择器,让你能轻松选择父元素

文章目录一、语法二、链式操作三、兼容性问题CSS现在新增了一个允许我们选择父元素的伪类:has选择器。可以将其当做父级选择器。 一、语法 选择器1:has(选择器2){} /* 表示选择包含有选择器2的所有的选择器1 比如:*/ div:has(p) {background: black; }…

计算机网络期末考试重点归纳

第 1 章 概述 1. 网络的基本特点 连通性共享性 2. internet 和 Internet 的含义 internetInternet中文名称互连网互联网/因特网名词性质通用名词专用名词名词解释指由多个计算机网络互连而成的计算机网络指当前全球最大的、开放的、由众多网络连接而成的特定互连网&#xff…

电子学会2020年6月青少年软件编程(图形化)等级考试试卷(一级)答案解析

目录 一、单选题(共25题,每题2分,共50分) 二、判断题(共10题,每题2分,共20分) 三、编程题(共3题,每题10分,共30分) 青少年软件编程…

Ubuntu22.04下安装MongoDB(6.0版本)并进行相关数据库操作

前言 昨天用ubuntu22.04安装redis-5.0.5服务,因为版本不兼容,导致问题频发,最终在老师帮助下解决了,这又一次提醒了版本兼容的重要性 MongoDB安装与部署 因为所用ubuntu版本为22.04,所以不能按照老师所给文档进行安…

图书管理系统(Java实现简易版)

目录前言预期效果分析1. book包1.1 Book类1.2 BookList 类2. user包2.1 User类2.2 AdminUser类2.3 NormalUser类3. opera包3.1 IOPeration 接口3.2 AddOperation 类3.3 BrrowOperation 类3.4 DelOperation 类3.5 ExitOperation 类3.6 FindOperation 类3.7 ReturnOperation 类3.…

wikijs-一款wiki系统

2022,别了。 1、介绍 wikijs是一款知识共享wiki,优点是有权限管理系统、支持多人协作共同维护、支持markdown格式、支持评论、风格简洁等等。适合作为个人博客,或者小团队的文档知识库。 效果图: 2、部署流程 2.1、安装dock…

前端 | 装饰你的github profile(github 首页)

1.创建存储库 您可以创建一个与您的 github 帐户名同名的存储库 添加README文件 2.编辑README.md 现在,可以根据自己的喜好修改 repo 中的自述文件,但我在考虑包含哪些信息时查看了其他开发人员的资料。通常包括简短的介绍、使用的技术堆栈和联系方式…

【JAVA进阶】包装类,Arrays类,Lambda表达式

📃个人主页:个人主页 🔥系列专栏:JAVASE基础 目录 一、包装类 二、Arrays类 三、Lambda表达式 一、包装类 其实就是8种基本数据类型对应的引用类型。 基本数据类型 引用数据类型 byte Byte short Short int Integer l…

GPU存储器架构

上表表述了各种存储器的各种特性。作用范围栏定义了程序的哪个部分能使用该存储器。而生存期定义了该存储器中的数据对程序可见的时间。除此之外,Ll和L2缓存也可以用于GPU程序以便更快地访问存储器。 总之,所有线程都有一个寄存器堆,它是最快…

Vue 页面渲染的流程

前言 在 Vue 核心中除了响应式原理外,视图渲染也是重中之重。我们都知道每次更新数据,都会走视图渲染的逻辑,而这当中牵扯的逻辑也是十分繁琐。 本文主要解析的是初始化视图渲染流程,你将会了解到从挂载组件开始,Vue…

2022年度总结与2023未来规划

这里写自定义目录标题2022年计划完成情况原始计划生活方面技术方面完成情况2023年规划初步安排技术方面生活方面2022年计划完成情况 原始计划 生活方面 健身(体重增到145)争取发展一个新的爱好(游泳、拳击)会做6个菜&#xff0c…

卷径计算详解(通过卷绕的膜长和膜厚进行计算)

有关卷绕+张力控制可以参看专栏的系列文章,文章链接如下: 变频器简单张力控制(线缆收放卷应用)_RXXW_Dor的博客-CSDN博客_收放卷应用张力控制的开闭环算法,可以查看专栏的其它文章,链接地址如下:PLC张力控制(开环闭环算法分析)_RXXW_Dor的博客-CSDN博客。https://blo…

元旦绚丽3D烟花代码

每天就是元旦了,新年怎么能少得了烟花呢?虽然绝大部分地区禁止燃放烟花,但该欣赏的烟花还是要欣赏滴~~ 最近整理文件,找到了一份烟花代码,3D特效,今天分享给大家,希望大家喜欢。 链接: https://…

深入浅出索引(下)

在上一篇文章中,我和你介绍了 InnoDB 索引的数据结构模型,今天我们再继续聊聊跟 MySQL 索引有关的概念。 在开始这篇文章之前,我们先来看一下这个问题: 在下面这个表 T 中,如果我执行 select * from T where k between 3 and 5,需要执行几次树的搜索操作,会扫描多少行…

搜索二叉树及其实现(迭代和递归实现)

二叉搜索树 二叉树搜索树又叫二叉排序树,它还有可能为一个空树。搜索二叉树的性质有 若他的左子树不为空,则左子树上所有节点的值都小于根节点。若他的右子树不为空,则右子树上所有节点的值都大于根节点。他的左右子树均为二叉搜索树 迭代…

微信小程序登录鉴权

小程序使用微信登录态进行授权登录 1、调用wx.login生成code wx.login()这个API的作用为当前用户生成一个临时的登录凭证,这个临时登录凭证有效期只有5分钟。拿到登录凭证后就可进行下一步操作,获取openid和session_key Taro.login().then((res) > …