#ifndef E2EMETRIC_HH
#define E2EMETRIC_HH
#include <click/element.hh>
#include "gridgenericmetric.hh"
CLICK_DECLS
/*
* =c
* E2ELossMetric(LinkStat, [, I<KEYWORDS>])
* =s Grid
* =io
* None
* =d
*
* Child class of GridGenericMetric that implements the end-to-end
* cumulative link loss ratio metric. The metric is the product of
* the delivery ratios of each link in the path, from 0--100 as a
* percentage. Larger metrics values are better.
*
* LinkStat is this node's LinkStat element, which is needed to obtain
* the link delivery ratios used to calculate the metric.
*
* Keywords arguments are:
*
* =over 8
*
* =item TWOWAY
*
* Boolean. If true, multiply the delivery ratios in both directions
* for each link. If false, only use the forward delivery ratio.
* Defaults to false.
*
* =back
*
* =a HopcountMetric, LinkStat, ETXMetric */
class LinkStat;
class E2ELossMetric : public GridGenericMetric {
public:
E2ELossMetric();
~E2ELossMetric();
const char *class_name() const { return "E2ELossMetric"; }
const char *port_count() const { return PORTS_0_0; }
const char *processing() const { return AGNOSTIC; }
int configure(Vector<String> &, ErrorHandler *);
bool can_live_reconfigure() const { return false; }
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:
LinkStat *_ls;
bool _twoway;
};
CLICK_ENDDECLS
#endif
syntax highlighted by Code2HTML, v. 0.9.1