网络包含两个节点,一个发送节点,一个接收节点。发送节点按照某种随机的规律产生数据包(包大小和包间隔可自己定义),然后发送给接收节点。传输过程中会有一些随机的差错(误包率也可自己定义)。接收节点收到正确的包之后统计吞吐量。并可将接收吞吐量与发送吞吐量进行比较,观察误包率对接收吞吐量的影响。

模型中发送节点模型为一个处理器类的节点,其进程模型为:

其用于产生ICI数据结构,并且使用远程中断进行发送和检错重传

发送节点为六个状态,其中五个为强制状态一个为非强制状态,无转移函数

Init的入口代码为

pk_code=0;

pk_count=0;

pk_number=0;

该函数作用为获得仿真属性值,参数为属性类型、属性名、指向属性值得指针

op_ima_sim_attr_get(OPC_DOUBLE,"FailureRate",&frate);

获得分级名称指定的对象ID

dest_id=op_id_from_hierarchical_name("top.my_rx_node.rx_pro") ;为接收节点的进程

统计量注册,返回统计量句柄

transmitted_index= op_stat_reg("Transmitted Index", OPC_STAT_INDEX_NONE,OPC_STAT_GLOBAL);

transmitted_traffic= op_stat_reg("Transmitted Traffic", OPC_STAT_INDEX_NONE,OPC_STAT_GLOBAL);

generate_index= op_stat_reg("Generating Index", OPC_STAT_INDEX_NONE,OPC_STAT_GLOBAL);

ack_state=1;

该函数作用是为调用进程预设一个中断,第一个参数为预设的中断时间,第二个参数是用户自定义的代码,在头文件中有声明,op_sim_time为获取当前仿真时间

op_intrpt_schedule_self(op_sim_time(),INTRPT_NEW_PKT);

init状态执行完之后,进入idle状态,其入口代码为

if(pk_count>0&& ack_state)

op_intrpt_schedule_self(op_sim_time(),PK_SEND);

头文件

#defineINTRPT_NEW_PKT  0  自定义中断

#definePK_SEND 1   自定义中断

#defineRE_SEND 2   自定义中断

#defineGEN (op_intrpt_type() == OPC_INTRPT_SELF && op_intrpt_code() ==INTRPT_NEW_PKT)

GEN条件中断类型为自中断,且中断值为INTRPT_NEW_PKT,第一次中断

#defineSEND (op_intrpt_type() == OPC_INTRPT_SELF && op_intrpt_code() ==PK_SEND && ack_state == OPC_TRUE)

SEND条件:中断类型为自中断,且中断值为PK_SEND

#defineACK (op_intrpt_type() == OPC_INTRPT_REMOTE && op_intrpt_code()  == pk_code)

ACK条件中断类型为远程中断,并且中断值为pk_code

#defineRESEND (op_intrpt_type() == OPC_INTRPT_SELF && op_intrpt_code() ==RE_SEND)

RESEND条件:中断类型为自中断,并且中断值为RE_SEND

第一次条件GEN成立,进入gen状态,其入口代码

pk_count++;

pk_number++;

op_dist_uniform函数的作用是产生一个均匀分布的随机值,取值范围为0-0.2

op_intrpt_schedule_self(op_sim_time()+ op_dist_uniform(0.2),INTRPT_NEW_PKT);

op_stat_write(generate_index,pk_number);

gen状态运行后回到init,之后满足SECD条件进入send状态,其入口代码为

pk_code++;

pk_count--;

创建一个接口

获取给定接口的某属性值

pk_inf=op_ici_create("my_td");

op_ici_attr_set(pk_inf,"index",pk_code);

size_dist=op_dist_load("Normal",1000,10000);

pk_size=op_dist_outcome(size_dist);随机生成的包大小

if(pk_size<0)

pk_size=0;

elseif(pk_size>10000)

pk_size=10000;

op_ici_attr_set(pk_inf,"size",pk_size);

op_ici_attr_set(pk_inf,"fal_rate",frate);

op_ici_install(pk_inf);创建一个与输出中断相关联的接口

op_intrpt_schedule_remote(op_sim_time(),pk_code,dest_id);预设一个远程中断

ack_state=0;

re_send=op_intrpt_schedule_self(op_sim_time()+0.2,RE_SEND);

op_stat_write(transmitted_index,pk_code);

op_stat_write(transmitted_traffic,pk_size);

op_ici_install(OPC_NIL);  拆除当前ICI的绑定

send 状态结束后ACK条件满足,进入ack状态,其入口代码为

op_ev_cancel(re_send);撤销事件

ack_state=1;

send状态出错,就会进入resend状态,其入口代码

op_ici_install(pk_inf);

op_intrpt_schedule_remote(op_sim_time(),pk_code,dest_id);

re_send=op_intrpt_schedule_self(op_sim_time()+0.2,RE_SEND);

op_ici_install(OPC_NIL);拆除当前ICI的绑定(释放)

接收节点为四个状态,其中三个为强制状态,一个为非强制状态,无转移函数

Init的入口代码为

send_id=op_id_from_hierarchical_name("top.my_tx_node.tx_pro");发送节点的ID

获得分级名称指定的对象ID

received_index= op_stat_reg("Received Index",OPC_STAT_INDEX_NONE, OPC_STAT_GLOBAL);

received_traffic= op_stat_reg("Received Traffic", OPC_STAT_INDEX_NONE,OPC_STAT_GLOBAL);

统计量注册,接收数目和索引

头文件为

#defineARRIVAL (op_intrpt_type() == OPC_INTRPT_REMOTE)
远程中断

#defineEND (op_intrpt_type() == OPC_INTRPT_ENDSIM)
 结束仿真中断

声明了包到达的条件及仿真结束的标志

当包到达时进入arrival状态,执行以下代码

pk_index=op_intrpt_code();

intrpt_ici=op_intrpt_ici();返回与当前中断相关联的接口

op_ici_attr_get(intrpt_ici,"size",&pk_size);

op_ici_attr_get(intrpt_ici,"fal_rate",&frate);

if(op_dist_uniform(1)>=frate)

{

op_ici_destroy(intrpt_ici);

op_intrpt_schedule_remote(op_sim_time()+op_dist_uniform(0.1),pk_index,send_id);

}

op_stat_write(received_index,pk_index);

op_stat_write(received_traffic,pk_size);

opnet点对点通信模型 分类: opnet 2014-05-26 22:15 246人阅读 评论(3) 收藏的更多相关文章

  1. 博弈论入门小结 分类: ACM TYPE 2014-08-31 10:15 73人阅读 评论(0) 收藏

    文章原地址:http://blog.csdn.net/zhangxiang0125/article/details/6174639 博弈论:是二人或多人在平等的对局中各自利用对方的策略变换自己的对抗策 ...

  2. 全方位分析Objcetive-C Runtime 分类: ios技术 2015-03-11 22:29 77人阅读 评论(0) 收藏

    本文详细整理了 Cocoa 的 Runtime 系统的知识,它使得 Objective-C 如虎添翼,具备了灵活的动态特性,使这门古老的语言焕发生机.主要内容如下: 引言 简介 与Runtime交互 ...

  3. C/C++文字常量与常变量的概念与区别 分类: C/C++ 2015-06-10 22:56 111人阅读 评论(0) 收藏

    以下代码使用平台是Windows 64bits+VS2012. 在C/C++编程时,经常遇到以下几个概念:常量.文字常量.符号常量.字面常量.常变量.字符串常量和字符常量,网上博客资料也是千篇千律,不 ...

  4. NPOI 通用导出数据到Excel 分类: C# Helper 2014-11-04 16:06 246人阅读 评论(0) 收藏

    应用场景: 在项目中,经常遇到将数据库数据导出到Excel,针对这种情况做了个程序封装.工作原理:利用NPOI将SQL语句查询出的DataTable数据导出到Excel,所见即所得. 程序界面:   ...

  5. hdu 1039 (string process, fgets, scanf, neat utilization of switch clause) 分类: hdoj 2015-06-16 22:15 38人阅读 评论(0) 收藏

    (string process, fgets, scanf, neat utilization of switch clause) simple problem, simple code. #incl ...

  6. PIGS 分类: POJ 图论 2015-08-10 09:15 3人阅读 评论(0) 收藏

    PIGS Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 18209 Accepted: 8277 Description Mir ...

  7. bzoj 1041 圆上的整点 分类: Brush Mode 2014-11-11 20:15 80人阅读 评论(0) 收藏

    这里先只考虑x,y都大于0的情况 如果x^2+y^2=r^2,则(r-x)(r+x)=y*y 令d=gcd(r-x,r+x),r-x=d*u^2,r+x=d*v^2,显然有gcd(u,v)=1且u&l ...

  8. 快速幂取模 分类: ACM TYPE 2014-08-29 22:01 95人阅读 评论(0) 收藏

    #include<stdio.h> #include<stdlib.h> //快速幂算法,数论二分 long long powermod(int a,int b, int c) ...

  9. Hibernate检索方式 分类: SSH框架 2015-07-10 22:10 4人阅读 评论(0) 收藏

    我们在项目应用中对数据进行最多的操作就是查询,数据的查询在所有ORM框架中也占有极其重要的地位.那么,如何利用Hibernate查询数据呢?Hibernate为我们提供了多种数据查询的方式,又称为Hi ...

随机推荐

  1. python每天一个小练习-强壮的密码

    强壮的密码 题目来源 checkio 需求 斯蒂芬和索菲亚对于一切都使用简单的密码,忘记了安全性.请你帮助尼古拉开发一个密码安全检查模块 如果密码的长度大于或等于10个符号,至少有一个数字,一个大写字 ...

  2. 浏览器未安装flash插件,js判断直接去官网安装

    近期做了个活动页,里面根据需求插入了阿里云的视频,常见的浏览器都支持包括低版本的. 由于浏览器的更新换代很多版本放弃了flash的插件安装,火狐就是其中之一. 未安装flash的浏览器如果打开这个链接 ...

  3. VirtualBox的快照功能

    VirtualBox是非常好用的一个虚拟机软件,无论是性能还是易用性不比商用的Vmware差.VirtualBox最初是Sun公司的产品,由于Sun被Oracle收购,现在也归Oracle了.除了虚拟 ...

  4. POJ 1459-Power Network(网络流-最大流-ISAP)C++

    Power Network 时间限制: 1 Sec  内存限制: 128 MB 题目描述 A power network consists of nodes (power stations, cons ...

  5. CSS技巧和经验列表

    如何清除图片下方出现几像素的空白间隙? img{display:block;} 如何让文本垂直对齐文本输入框? input{vertical-align:middle;} 如何使文本溢出边界显示为省略 ...

  6. springboot(十四):springboot整合shiro-登录认证和权限管理

    这篇文章我们来学习如何使用Spring Boot集成Apache Shiro.安全应该是互联网公司的一道生命线,几乎任何的公司都会涉及到这方面的需求.在Java领域一般有Spring Security ...

  7. PHP大批量插入mysql数据库的优化

    <?php /** * Created by PhpStorm. * User: hanks * Date: 6/2/2017 * Time: 6:03 PM */ //PHP大批量插入mysq ...

  8. [leetcode-494-Target Sum]

    You are given a list of non-negative integers, a1, a2, ..., an, and a target, S. Now you have 2 symb ...

  9. angular 4使用jquery 第三方插件库

    用jBox插件为例子 1,npm install jBox --save 2,找到.angular-cli.json  增加 "../node_modules/jbox/Source/jBo ...

  10. Android源码博文集锦1

    Android精选源码 功能齐全的实用Android视频播放器 实现滑动到底部,加载更多RecyclerViewDemo 使用Kotlin语言编写Android MVP案例KotlinMVPDemo ...