param.hpp
Go to the documentation of this file.
1 
15 #ifndef MLPACK_CORE_UTIL_PARAM_HPP
16 #define MLPACK_CORE_UTIL_PARAM_HPP
17 
18 // Required forward declarations.
19 namespace mlpack {
20 namespace data {
21 
22 class IncrementPolicy;
23 
24 template<typename PolicyType, typename InputType>
25 class DatasetMapper;
26 
27 using DatasetInfo = DatasetMapper<IncrementPolicy, std::string>;
28 
29 } // namespace data
30 } // namespace mlpack
31 
45 #define SEE_ALSO(DESCRIPTION, LINK) {DESCRIPTION, LINK}
46 
71 #define PROGRAM_INFO(NAME, SHORT_DESC, DESC, ...) \
72  static mlpack::util::ProgramDoc \
73  cli_programdoc_dummy_object = mlpack::util::ProgramDoc(NAME, SHORT_DESC, \
74  []() { return DESC; }, { __VA_ARGS__ } )
75 
93 #define PARAM_FLAG(ID, DESC, ALIAS) \
94  PARAM_IN(bool, ID, DESC, ALIAS, false, false);
95 
118 #define PARAM_INT_IN(ID, DESC, ALIAS, DEF) \
119  PARAM_IN(int, ID, DESC, ALIAS, DEF, false)
120 
146 #define PARAM_INT_OUT(ID, DESC) \
147  PARAM_OUT(int, ID, DESC, "", 0, false)
148 
170 #define PARAM_DOUBLE_IN(ID, DESC, ALIAS, DEF) \
171  PARAM_IN(double, ID, DESC, ALIAS, DEF, false)
172 
198 #define PARAM_DOUBLE_OUT(ID, DESC) \
199  PARAM_OUT(double, ID, DESC, "", 0.0, false)
200 
223 #define PARAM_STRING_IN(ID, DESC, ALIAS, DEF) \
224  PARAM_IN(std::string, ID, DESC, ALIAS, DEF, false)
225 
252 #define PARAM_STRING_OUT(ID, DESC, ALIAS) \
253  PARAM_OUT(std::string, ID, DESC, ALIAS, "", false)
254 
278 #define PARAM_MATRIX_IN(ID, DESC, ALIAS) \
279  PARAM_MATRIX(ID, DESC, ALIAS, false, true, true)
280 
304 #define PARAM_MATRIX_IN_REQ(ID, DESC, ALIAS) \
305  PARAM_MATRIX(ID, DESC, ALIAS, true, true, true)
306 
335 #define PARAM_MATRIX_OUT(ID, DESC, ALIAS) \
336  PARAM_MATRIX(ID, DESC, ALIAS, false, true, false)
337 
362 #define PARAM_TMATRIX_IN(ID, DESC, ALIAS) \
363  PARAM_MATRIX(ID, DESC, ALIAS, false, false, true)
364 
390 #define PARAM_TMATRIX_IN_REQ(ID, DESC, ALIAS) \
391  PARAM_MATRIX(ID, DESC, ALIAS, true, false, true)
392 
423 #define PARAM_TMATRIX_OUT(ID, DESC, ALIAS) \
424  PARAM_MATRIX(ID, DESC, ALIAS, false, false, false)
425 
449 #define PARAM_UMATRIX_IN(ID, DESC, ALIAS) \
450  PARAM_UMATRIX(ID, DESC, ALIAS, false, true, true)
451 
476 #define PARAM_UMATRIX_IN_REQ(ID, DESC, ALIAS) \
477  PARAM_UMATRIX(ID, DESC, ALIAS, true, true, true)
478 
508 #define PARAM_UMATRIX_OUT(ID, DESC, ALIAS) \
509  PARAM_UMATRIX(ID, DESC, ALIAS, false, true, false)
510 
511 
535 #define PARAM_COL_IN(ID, DESC, ALIAS) \
536  PARAM_COL(ID, DESC, ALIAS, false, true, true)
537 
561 #define PARAM_ROW_IN(ID, DESC, ALIAS) \
562  PARAM_ROW(ID, DESC, ALIAS, false, true, true)
563 
587 #define PARAM_UCOL_IN(ID, DESC, ALIAS) \
588  PARAM_UCOL(ID, DESC, ALIAS, false, true, true)
589 
614 #define PARAM_UROW_IN(ID, DESC, ALIAS) \
615  PARAM_UROW(ID, DESC, ALIAS, false, true, true)
616 
645 #define PARAM_COL_OUT(ID, DESC, ALIAS) \
646  PARAM_COL(ID, DESC, ALIAS, false, true, false)
647 
676 #define PARAM_ROW_OUT(ID, DESC, ALIAS) \
677  PARAM_ROW(ID, DESC, ALIAS, false, true, false)
678 
707 #define PARAM_UCOL_OUT(ID, DESC, ALIAS) \
708  PARAM_UCOL(ID, DESC, ALIAS, false, true, false)
709 
738 #define PARAM_UROW_OUT(ID, DESC, ALIAS) \
739  PARAM_UROW(ID, DESC, ALIAS, false, true, false)
740 
762 #define PARAM_VECTOR_IN(T, ID, DESC, ALIAS) \
763  PARAM_IN(std::vector<T>, ID, DESC, ALIAS, std::vector<T>(), false)
764 
791 #define PARAM_VECTOR_OUT(T, ID, DESC, ALIAS) \
792  PARAM_OUT(std::vector<T>, ID, DESC, ALIAS, std::vector<T>(), false)
793 
828 #define TUPLE_TYPE std::tuple<mlpack::data::DatasetInfo, arma::mat>
829 #define PARAM_MATRIX_AND_INFO_IN(ID, DESC, ALIAS) \
830  PARAM_IN(TUPLE_TYPE, ID, DESC, ALIAS, TUPLE_TYPE(), false)
831 
861 #define PARAM_MODEL_IN(TYPE, ID, DESC, ALIAS) \
862  PARAM_MODEL(TYPE, ID, DESC, ALIAS, false, true)
863 
893 #define PARAM_MODEL_IN_REQ(TYPE, ID, DESC, ALIAS) \
894  PARAM_MODEL(TYPE, ID, DESC, ALIAS, true, true)
895 
916 #define PARAM_MODEL_OUT(TYPE, ID, DESC, ALIAS) \
917  PARAM_MODEL(TYPE, ID, DESC, ALIAS, false, false)
918 
938 #define PARAM_INT_IN_REQ(ID, DESC, ALIAS) \
939  PARAM_IN(int, ID, DESC, ALIAS, 0, true)
940 
960 #define PARAM_DOUBLE_IN_REQ(ID, DESC, ALIAS) \
961  PARAM_IN(double, ID, DESC, ALIAS, 0.0, true)
962 
982 #define PARAM_STRING_IN_REQ(ID, DESC, ALIAS) \
983  PARAM_IN(std::string, ID, DESC, ALIAS, "", true)
984 
1005 #define PARAM_VECTOR_IN_REQ(T, ID, DESC, ALIAS) \
1006  PARAM_IN(std::vector<T>, ID, DESC, ALIAS, std::vector<T>(), true);
1007 
1013 // These are ugly, but necessary utility functions we must use to generate a
1014 // unique identifier inside of the PARAM() module.
1015 #define JOIN(x, y) JOIN_AGAIN(x, y)
1016 #define JOIN_AGAIN(x, y) x ## y
1017 
1034 #ifdef __COUNTER__
1035  #define PARAM_IN(T, ID, DESC, ALIAS, DEF, REQ) \
1036  static mlpack::util::Option<T> \
1037  JOIN(cli_option_dummy_object_in_, __COUNTER__) \
1038  (DEF, ID, DESC, ALIAS, #T, REQ, true, false, testName);
1039 
1040  #define PARAM_OUT(T, ID, DESC, ALIAS, DEF, REQ) \
1041  static mlpack::util::Option<T> \
1042  JOIN(cli_option_dummy_object_out_, __COUNTER__) \
1043  (DEF, ID, DESC, ALIAS, #T, REQ, false, false, testName);
1044 
1045  #define PARAM_MATRIX(ID, DESC, ALIAS, REQ, TRANS, IN) \
1046  static mlpack::util::Option<arma::mat> \
1047  JOIN(cli_option_dummy_matrix_, __COUNTER__) \
1048  (arma::mat(), ID, DESC, ALIAS, "arma::mat", \
1049  REQ, IN, !TRANS, testName);
1050 
1051  #define PARAM_UMATRIX(ID, DESC, ALIAS, REQ, TRANS, IN) \
1052  static mlpack::util::Option<arma::Mat<size_t>> \
1053  JOIN(cli_option_dummy_umatrix_, __COUNTER__) \
1054  (arma::Mat<size_t>(), ID, DESC, ALIAS, "arma::Mat<size_t>", \
1055  REQ, IN, !TRANS, testName);
1056 
1057  #define PARAM_COL(ID, DESC, ALIAS, REQ, TRANS, IN) \
1058  static mlpack::util::Option<arma::vec> \
1059  JOIN(cli_option_dummy_col_, __COUNTER__) \
1060  (arma::vec(), ID, DESC, ALIAS, "arma::vec", \
1061  REQ, IN, !TRANS, testName);
1062 
1063  #define PARAM_UCOL(ID, DESC, ALIAS, REQ, TRANS, IN) \
1064  static mlpack::util::Option<arma::Col<size_t>> \
1065  JOIN(cli_option_dummy_ucol_, __COUNTER__) \
1066  (arma::Col<size_t>(), ID, DESC, ALIAS, "arma::Col<size_t>", \
1067  REQ, IN, !TRANS, testName);
1068 
1069  #define PARAM_ROW(ID, DESC, ALIAS, REQ, TRANS, IN) \
1070  static mlpack::util::Option<arma::rowvec> \
1071  JOIN(cli_option_dummy_row_, __COUNTER__) \
1072  (arma::rowvec(), ID, DESC, ALIAS, "arma::rowvec", \
1073  REQ, IN, !TRANS, testName);
1074 
1075  #define PARAM_UROW(ID, DESC, ALIAS, REQ, TRANS, IN) \
1076  static mlpack::util::Option<arma::Row<size_t>> \
1077  JOIN(cli_option_dummy_urow_, __COUNTER__) \
1078  (arma::Row<size_t>(), ID, DESC, ALIAS, "arma::Row<size_t>", \
1079  REQ, IN, !TRANS, testName);
1080 
1081  // There are no uses of required models, so that is not an option to this
1082  // macro (it would be easy to add).
1083  #define PARAM_MODEL(TYPE, ID, DESC, ALIAS, REQ, IN) \
1084  static mlpack::util::Option<TYPE*> \
1085  JOIN(cli_option_dummy_model_, __COUNTER__) \
1086  (nullptr, ID, DESC, ALIAS, #TYPE, REQ, IN, false, testName);
1087 #else
1088  // We have to do some really bizarre stuff since __COUNTER__ isn't defined. I
1089  // don't think we can absolutely guarantee success, but it should be "good
1090  // enough". We use the __LINE__ macro and the type of the parameter to try
1091  // and get a good guess at something unique.
1092  #define PARAM_IN(T, ID, DESC, ALIAS, DEF, REQ) \
1093  static mlpack::util::Option<T> \
1094  JOIN(JOIN(cli_option_dummy_object_in_, __LINE__), opt) \
1095  (DEF, ID, DESC, ALIAS, #T, REQ, true, false, testName);
1096 
1097  #define PARAM_OUT(T, ID, DESC, ALIAS, DEF, REQ) \
1098  static mlpack::util::Option<T> \
1099  JOIN(JOIN(cli_option_dummy_object_out_, __LINE__), opt) \
1100  (DEF, ID, DESC, ALIAS, #T, REQ, false, false, testName);
1101 
1102  #define PARAM_MATRIX(ID, DESC, ALIAS, REQ, TRANS, IN) \
1103  static mlpack::util::Option<arma::mat> \
1104  JOIN(JOIN(cli_option_dummy_object_matrix_, __LINE__), opt) \
1105  (arma::mat(), ID, DESC, ALIAS, "arma::mat", REQ, IN, !TRANS, \
1106  testName);
1107 
1108  #define PARAM_UMATRIX(ID, DESC, ALIAS, REQ, TRANS, IN) \
1109  static mlpack::util::Option<arma::Mat<size_t>> \
1110  JOIN(JOIN(cli_option_dummy_object_umatrix_, __LINE__), opt) \
1111  (arma::Mat<size_t>(), ID, DESC, ALIAS, "arma::Mat<size_t>", REQ, IN, \
1112  !TRANS, testName);
1113 
1114  #define PARAM_COL(ID, DESC, ALIAS, REQ, TRANS, IN) \
1115  static mlpack::util::Option<arma::vec> \
1116  JOIN(cli_option_dummy_object_col_, __LINE__) \
1117  (arma::vec(), ID, DESC, ALIAS, "arma::vec", REQ, IN, !TRANS, \
1118  testName);
1119 
1120  #define PARAM_UCOL(ID, DESC, ALIAS, REQ, TRANS, IN) \
1121  static mlpack::util::Option<arma::Col<size_t>> \
1122  JOIN(cli_option_dummy_object_ucol_, __LINE__) \
1123  (arma::Col<size_t>(), ID, DESC, ALIAS, "arma::Col<size_t>", REQ, IN, \
1124  !TRANS, testName);
1125 
1126  #define PARAM_ROW(ID, DESC, ALIAS, REQ, TRANS, IN) \
1127  static mlpack::util::Option<arma::rowvec> \
1128  JOIN(cli_option_dummy_object_row_, __LINE__) \
1129  (arma::rowvec(), ID, DESC, ALIAS, "arma::rowvec", REQ, IN, !TRANS, \
1130  testName);
1131 
1132  #define PARAM_UROW(ID, DESC, ALIAS, REQ, TRANS, IN) \
1133  static mlpack::util::Option<arma::Row<size_t>> \
1134  JOIN(cli_option_dummy_object_urow_, __LINE__) \
1135  (arma::Row<size_t>(), ID, DESC, ALIAS, "arma::Row<size_t>", REQ, IN, \
1136  !TRANS, testName);
1137 
1138  #define PARAM_MODEL(TYPE, ID, DESC, ALIAS, REQ, IN) \
1139  static mlpack::util::Option<TYPE*> \
1140  JOIN(JOIN(cli_option_dummy_object_model_, __LINE__), opt) \
1141  (nullptr, ID, DESC, ALIAS, #TYPE, REQ, IN, false, \
1142  testName);
1143 #endif
1144 
1145 #endif
.hpp
Definition: add_to_po.hpp:21
DatasetMapper< data::IncrementPolicy > DatasetInfo