




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
進(jìn)程說明
Broadcast01_xr:
仿真時間開始前200s廣播包
HB:
//headfile
#include<math.h>
//GV
intglobal_total_packet_load=0;
//Constants
#defineLOW_OUT_STRM0
//Macro
#definePKT_SENT(op_intrpt_type()==OPC_INTRPT_SELF)
//functiondeclaration
staticvoidsend_pk(void);
staticvoidschedule_next_send();
FB:
staticvoidschedule_next_send(void)
{
doublenext_creation_time;FIN(schedule_next_send())
next_creation_time=op_dist_outcome(ia_dist);op_intrpt_schedule_self(op_sim_time()+next_creation_time,0);
FOUT
}
staticvoidsend_pk(void)
{
Packet*pkptr;charmsg[256];FIN(send_pk())
if(op_sim_time()<200)
{
pkptr=op_pk_create_fmt("wireless_pk01_xr");if(pkptr==OPC_NIL)
{
sprintf(msg,"Unabletocreatepacket");op_sim_end(msg,OPC_NIL,OPC_NIL,OPC_NIL);
}
else
{
op_pk_bcast_general(pkptr);packet_load++;global_total_packet_load++;
op_stat_write(packet_load_lhndl,packet_load);op_stat_write(total_packet_load_ghndl,global_total_packet_load++);op_pk_send(pkptr,LOW_OUT_STRM);
schedule_next_send();
}
}FOUT
}
//init入口代碼
packet_load_lhndl=op_stat_reg("PacketLoad",OPC_STAT_INDEX_NONE,OPC_STAT_LOCAL);total_packet_load_ghndl=op_stat_reg("TotalLoad",OPC_STAT_INDEX_NONE,OPC_STAT_GLOBAL);
packet_load=0;
ia_dist=op_dist_load("exponential",30,0.0);
Packet
schedule_next_send();
Broadcast02_xr:
仿真時間開始廣播包,廣播時間可以由用戶通過節(jié)點屬性自行控制。
增加節(jié)點進(jìn)程屬性
TV:
Objidmy_id;
HB:同broadcast01_xr
//headfile
#include<math.h>
//GV
intglobal_total_packet_load=0;
//Constants
#defineLOW_OUT_STRM0
//Macro
#definePKT_SENT(op_intrpt_type()==OPC_INTRPT_SELF)
//functiondeclaration
staticvoidsend_pk(void);
staticvoidschedule_next_send();
FB:
staticvoidschedule_next_send(void)
{
doublenext_creation_time;FIN(schedule_next_send())
next_creation_time=op_dist_outcome(ia_dist);op_intrpt_schedule_self(op_sim_time()+next_creation_time,0);
FOUT
}
staticvoidsend_pk(void)
{
Packet*pkptr;charmsg[256];FIN(send_pk())
if(op_sim_time()<broadcast_time)
{
pkptr=op_pk_create_fmt("wireless_pk01_xr");if(pkptr==OPC_NIL)
{
sprintf(msg,"Unabletocreatepacket");op_sim_end(msg,OPC_NIL,OPC_NIL,OPC_NIL);
}
else
{
op_pk_bcast_general(pkptr);packet_load++;global_total_packet_load++;
op_stat_write(packet_load_lhndl,packet_load);op_stat_write(total_packet_load_ghndl,global_total_packet_load++);op_pk_send(pkptr,LOW_OUT_STRM);
schedule_next_send();
}
}FOUT
}
//init入口
packet_load_lhndl=op_stat_reg("PacketLoad",OPC_STAT_INDEX_NONE,OPC_STAT_LOCAL);total_packet_load_ghndl=op_stat_reg("TotalLoad",OPC_STAT_INDEX_NONE,OPC_STAT_GLOBAL);
packet_load=0;
ia_dist=op_dist_load("exponential",30,0.0);
Packet
my_id=op_id_self();
op_ima_obj_attr_get(my_id,"BroadcastTime",&broadcast_time);if(broadcast_time<=0)
broadcast_time=200;
schedule_next_send();
Broadcast03_xr:
保持broadcast02_xr的功能,并初始化需要廣播的包的各個字段。
進(jìn)程大致沒有什么變化,增加了局部統(tǒng)計量X,狀態(tài)變量x_stathandle并修改了函數(shù)send_pk()。函數(shù)如下:
staticvoidsend_pk(void)
{
Packet*pkptr;charmsg[256];doublex;doubley;
Objidmodule_id;
Objidnode_id;
FIN(send_pk())
if(op_sim_time()<broadcast_time)
{
pkptr=op_pk_create_fmt("wireless_pk01_xr");if(pkptr==OPC_NIL)
{
sprintf(msg,"Unabletocreatepacket");op_sim_end(msg,OPC_NIL,OPC_NIL,OPC_NIL);
}
else
{
module_id=op_id_self();node_id=op_topo_parent(module_id);op_ima_obj_attr_get(node_id,"xposition",&x);
op_ima_obj_attr_get(node_id,"yposition",&y);
op_pk_nfd_set(pkptr,"x_pos",x);
op_pk_nfd_set(pkptr,"y_pos",y);op_pk_nfd_set(pkptr,"hop",1);op_pk_nfd_set(pkptr,"ave",0);
op_pk_nfd_set(pkptr,"packet_type",0);
op_pk_bcast_general(pkptr);
packet_load++;global_total_packet_load++;
op_stat_write(packet_load_lhndl,packet_load);op_stat_write(total_packet_load_ghndl,global_total_packet_load++);op_pk_send(pkptr,LOW_OUT_STRM);
schedule_next_send();
}
}
FOUT
}
Br_rv01:
保持broadcast03的發(fā)送功能,并增加接收其它節(jié)點傳來的包的功能,對傳來的包進(jìn)行銷毀。節(jié)
點屬性
TV:
Objidmy_id;
HB:
//頭文件
#include<math.h>
//全局變量
intglobal_total_packet_load=0;
intglobal_total_r_packet_load=0;
//常量
#defineLOW_OUT_STRM0
//宏
#definePKT_SENT(op_intrpt_type()==OPC_INTRPT_SELF)
#definePKT_RECEIVE(op_intrpt_type()==OPC_INTRPT_STRM)
//函數(shù)聲明
staticvoidsend_pk(void);
staticvoidschedule_next_send();staticvoidreceive_pk(void);
staticvoidschedule_next_send(void)
{
doublenext_creation_time;FIN(schedule_next_send())
next_creation_time=op_dist_outcome(ia_dist);
op_intrpt_schedule_self(op_sim_time()+next_creation_time,0);
FOUT
}
staticvoidsend_pk(void)
{
Packet*pkptr;charmsg[256];doublex;doubley;
Objidmodule_id;
Objidnode_id;
FIN(send_pk())
if(op_sim_time()<broadcast_time)
{
pkptr=op_pk_create_fmt("wireless_pk01_xr");if(pkptr==OPC_NIL)
{
sprintf(msg,"Unabletocreatepacket");op_sim_end(msg,OPC_NIL,OPC_NIL,OPC_NIL);
}
else
{
module_id=op_id_self();node_id=op_topo_parent(module_id);op_ima_obj_attr_get(node_id,"xposition",&x);
op_ima_obj_attr_get(node_id,"yposition",&y);
op_pk_nfd_set(pkptr,"x_pos",x);
op_pk_nfd_set(pkptr,"y_pos",y);op_pk_nfd_set(pkptr,"hop",1);op_pk_nfd_set(pkptr,"ave",0);
op_pk_nfd_set(pkptr,"packet_type",0);
op_pk_bcast_general(pkptr);
packet_load++;global_total_packet_load++;
op_stat_write(packet_load_lhndl,packet_load);op_stat_write(total_packet_load_ghndl,global_total_packet_load);op_pk_send(pkptr,LOW_OUT_STRM);
schedule_next_send();
}
}
FOUT
}
staticvoidreceive_pk(void)
{
Packet*pkptr;charmsg[256];FIN(receive_pk())
pkptr=op_pk_get(op_intrpt_strm());if(pkptr==OPC_NIL)
{
sprintf(msg,"Unabletopickapacket");op_sim_end(msg,OPC_NIL,OPC_NIL,OPC_NIL);
}
else
{
global_total_r_packet_load++;r_packet_load++;
op_stat_write(r_packet_load_lhndl,r_packet_load);
op_stat_write(total_r_packet_load_ghndl,global_total_r_packet_load);
op_pk_destroy(pkptr);
}
FOU
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 《課間活動》(教案)2024-2025學(xué)年數(shù)學(xué)二年級上冊
- 2025年美容院會員協(xié)議模板
- 學(xué)習(xí)2025年雷鋒精神六十二周年主題活動方案 合計3份
- 2025年青海省安全員A證考試題庫
- 《游山西村》歷年中考古詩欣賞試題匯編(截至2024年)
- 全國河大音像版初中信息技術(shù)七年級下冊第一章第二節(jié)《文字素材的采集》教學(xué)設(shè)計
- 歷史-云南省師范大學(xué)附屬中學(xué)2025屆高三下學(xué)期開學(xué)考試試題和答案
- 2025年??谑袉握新殬I(yè)適應(yīng)性測試題庫附答案
- 2025年度兒童游樂場主題包裝與品牌推廣合作協(xié)議書
- 2025年度個人公司資金走賬專項管理合同協(xié)議
- 2023年通遼市中考數(shù)學(xué)試卷及答案
- 腸內(nèi)營養(yǎng)考評標(biāo)準(zhǔn)終
- Mysql 8.0 OCP 1Z0-908 CN-total認(rèn)證備考題庫(含答案)
- 三年級下冊音樂教學(xué)計劃含教學(xué)進(jìn)度安排活動設(shè)計word表格版
- STEM教學(xué)設(shè)計與實施PPT完整全套教學(xué)課件
- 門窗加工制作合同
- 項目邊坡護(hù)坡工程施工組織設(shè)計
- 四年級上冊音樂《楊柳青》課件PPT
- 安徽省廬陽區(qū)小升初語文試卷含答案
- 全國2017年4月自考00043經(jīng)濟法概論(財經(jīng)類)試題及答案
- 蘇教版六年級數(shù)學(xué)下冊《解決問題的策略2》優(yōu)質(zhì)教案
評論
0/150
提交評論