00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef _CJLS_GEOPOW_H_
00021 #define _CJLS_GEOPOW_H_ 1
00022
00023 #include <string>
00024 #include "CjLinkSelector.hh"
00025
00026 namespace jmitie {
00027 namespace corelib {
00028 class CjLS_geopow : public CjLinkSelector {
00029 public:
00030
00031 static std::string getName_static() { return "geopow"; }
00032 virtual std::string getName() const { return getName_static(); }
00033 std::string getProperty(const std::string & prop) const { return getProperty_static(prop); }
00034 static std::string getProperty_static(const std::string & opt) {
00035 if(opt=="desc") return "Selects a link or node-pair preferring those with a higher value of alpha*geographic_distance_between_nodes_in_pair^beta.";
00036 if(opt=="usage") return getProperty_static("desc") + "\n" +
00037 "alpha=float\tSpecifies the value to use for the distance co-efficient.\n" \
00038 "beta=float\tSpecifies the value to use for the distance exponent.\n" \
00039 "[no_warn]\tDisables the warning about values of alpha and beta outside of expected bounds.\n"\
00040 "[dupe_ok]\tIf specified a node pairs which are already connected are included in the node-pair selection(only applies when adding links).\n";
00041 throw std::invalid_argument("CjLS_geopow::getProperty_static(" + opt + "): Unknown property requested.");
00042 }
00043
00044 CjLS_geopow(std::string args, const ctor_va_t & va );
00045
00046 virtual bool selectLink( select_arg_t &, unsigned int & from, unsigned int & to );
00047 virtual ~CjLS_geopow() {};
00048
00049 protected:
00050 bool m_add_remove;
00051 double m_alpha;
00052 double m_beta;
00053 bool m_dupe_link_ok;
00054 bool m_no_alpha_beta_warn;
00055
00056 private:
00057
00058 };
00059 }
00060 }
00061
00062 #endif // _CJLS_GEOPOW_H_