⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lirmetric.hh

📁 COPE the first practical network coding scheme which is developped on click
💻 HH
字号:
#ifndef LIRMETRIC_HH#define LIRMETRIC_HH#include <click/element.hh>#include "gridgenericmetric.hh"CLICK_DECLS/* * =c * LIRMetric(GridGenericRouteTable) * =s Grid * =io * None * =d * * Child class of GridGenericMetric that implements the `Least * Interference Routing' metric.  The metric is the sum of the number * 1-hop neighbors of each node in the route.  This node's number of * 1-hop neighbors is obtained from the GridGenericRouteTable * argument.  Smaller metric values are better. * * LIR is described in `Spatial Reuse Through Dynamic Power and * Routing Control in Common-Channel Random-Access Packet Radio * Networks', James Almon Stevens, Ph.D. Thesis, University of Texas * at Dallas, 1988. * * =a HopcountMetric, LinkStat, ETXMetric, E2ELossMetric */class GridGenericRouteTable;class LIRMetric : public GridGenericMetric {  public:  LIRMetric();  ~LIRMetric();  const char *class_name() const { return "LIRMetric"; }  const char *processing() const { return AGNOSTIC; }  int configure(Vector<String> &, ErrorHandler *);  bool can_live_reconfigure() const { return false; }  void add_handlers();  void *cast(const char *);  // generic metric methods  bool metric_val_lt(const metric_t &, const metric_t &) const;  metric_t get_link_metric(const EtherAddress &, bool) const;  metric_t append_metric(const metric_t &, const metric_t &) const;  metric_t prepend_metric(const metric_t &r, const metric_t &l) const   { return append_metric(r, l); }  unsigned char scale_to_char(const metric_t &m) const { return (unsigned char) m.val(); }  metric_t unscale_from_char(unsigned char c)    const { return metric_t(c);             }private:  GridGenericRouteTable *_rt;};CLICK_ENDDECLS#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -