📄 diff_prob.h
字号:
/****************************************************************//* diff_prob.h : Chalermek Intanagonwiwat (USC/ISI) 08/16/99 *//****************************************************************/// Important Note: Work still in progress !!! Major improvement is needed.#ifndef ns_diff_prob_h#define ns_diff_prob_hextern "C" {#include <assert.h>#include <math.h>#include <stdio.h>#include <signal.h>#include <float.h>#include <stdlib.h>}#include <tcl.h>#include "diff_header.h"#include "agent.h"#include "tclcl.h"#include "ip.h"#include "config.h"#include "packet.h"#include "trace.h"#include "random.h"#include "classifier.h"#include "node.h"#include "iflist.h"#include "hash_table.h"#include "arp.h"#include "mac.h"#include "ll.h"#include "dsr/path.h"#include "routing_table.h"#include "diffusion.h"//#define DEBUG_PROB#define BACKTRACK_ false#define ENERGY_CHECK 0.05 // (sec) between energy checks#define INTEREST_DELAY 0.05 // (sec) bw receive and forward#define MAX_REINFORCE_COUNTER 10 // (pkts) bw pos reinfclass DiffusionProb;class EnergyTimer : public TimerHandler {public: EnergyTimer(DiffusionProb *a, Node *b) : TimerHandler() { a_ = a; node_ = b; init_eng_ = node_->energy(); threshold_ = init_eng_ / 2; } virtual void expire(Event *e);protected: DiffusionProb *a_; Node *node_; double init_eng_; double threshold_;};class InterestTimer : public TimerHandler {public: InterestTimer(DiffusionProb *a, Pkt_Hash_Entry *hashPtr, Packet *pkt) : TimerHandler() { a_ = a; hashPtr_ = hashPtr; pkt_ = pkt; } virtual ~InterestTimer() { if (pkt_ != NULL) Packet::free(pkt_); } void expire(Event *e);protected: DiffusionProb *a_; Pkt_Hash_Entry *hashPtr_; Packet *pkt_;};class DiffusionProb : public DiffusionAgent { public: DiffusionProb(); void recv(Packet*, Handler*); protected: int num_neg_bcast_send; int num_neg_bcast_rcv; EnergyTimer *energy_timer; bool is_low_power; void Start(); void consider_old(Packet *); void consider_new(Packet *); void add_outlist(unsigned int, From_List *); void data_request_all(unsigned int dtype); void CreateIOList(Pkt_Hash_Entry *, unsigned int); void UpdateIOList(From_List *, unsigned int); void Print_IOlist(); void CalGradient(unsigned int); void IncGradient(unsigned int, ns_addr_t); void DecGradient(unsigned int, ns_addr_t); void ForwardData(Packet *); void ForwardTxFailed(Packet *); void ReTxData(Packet *); void GenPosReinf(unsigned int); void FwdPosReinf(unsigned int, Packet *); void InterfaceDown(int, ns_addr_t); void SendInhibit(int); void SendNegReinf(); void InterestPropagate(Packet *pkt, Pkt_Hash_Entry *hashPtr); void xmitFailed(Packet *pkt); friend class InterestTimer; friend class EnergyTimer;};#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -