




版權(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é)點(diǎn)屬性自行控制。
增加節(jié)點(diǎn)進(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é)點(diǎn)傳來的包的功能,對傳來的包進(jìn)行銷毀。節(jié)
點(diǎn)屬性
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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 策略性復(fù)習(xí)2024年商務(wù)禮儀師試題及答案
- 探討紡織機(jī)械的創(chuàng)新技術(shù)試題及答案
- 理解紡織機(jī)械工作環(huán)境適應(yīng)性試題及答案
- 深度解析智慧交通行業(yè)的挑戰(zhàn)與機(jī)遇試題及答案
- 切入電氣工程師資格考試的方法試題及答案
- 酒店國際市場拓展試題及答案
- 如何在Adobe考試中提高得分的訣竅試題及答案
- 酒店行業(yè)數(shù)據(jù)分析方法試題及答案
- 二零二五全新協(xié)議書離婚撫養(yǎng)權(quán)
- 離婚協(xié)議談話筆錄1500字二零二五年
- 公路工程技術(shù)標(biāo)準(zhǔn)(JTG B01-2003)
- 廈門大學(xué)放射性藥物研發(fā)實(shí)驗(yàn)項(xiàng)目環(huán)境影響報告
- 應(yīng)收款項(xiàng)-應(yīng)收款項(xiàng)減值
- 江蘇省書法水平等級證書考試-硬筆書法考試專用紙-(123級)
- 紹興古城歷史建筑和傳統(tǒng)民居
- 13J104《蒸壓加氣混凝土砌塊、板材構(gòu)造》
- (完整word)軟件驗(yàn)收單
- 全套IATF16949內(nèi)審核檢查表(含審核記錄)
- 第一章醫(yī)學(xué)統(tǒng)計學(xué)方法的基本概念和基本步驟講課課件
- 高中數(shù)學(xué)說題課件
- 基于51單片機(jī)家用電熱水器的設(shè)計論文
評論
0/150
提交評論