43 template <
typename GUM_SCALAR >
46 const std::string& extends,
48 bool delayInheritance) {
49 std::string real_name = __addPrefix(name);
50 if (__prm->__classMap.exists(real_name)
51 || __prm->__interfaceMap.exists(real_name)) {
58 if (implements != 0) {
59 for (
const auto& imp : *implements) {
60 impl.
insert(__retrieveInterface(imp));
64 if (extends !=
"") { mother = __retrieveClass(extends); }
66 if ((extends ==
"") && impl.
empty()) {
68 }
else if ((extends !=
"") && impl.
empty()) {
70 }
else if ((extends ==
"") && (!impl.
empty())) {
72 }
else if ((extends !=
"") && (!impl.
empty())) {
76 __prm->__classMap.insert(c->
name(), c);
77 __prm->__classes.insert(c);
81 template <
typename GUM_SCALAR >
83 std::string real_name = __addPrefix(name);
84 if (!(__prm->__classMap.exists(real_name))) {
85 std::stringstream msg;
86 msg <<
"'" << real_name <<
"' not found";
89 __stack.push_back(&(__prm->getClass(real_name)));
92 template <
typename GUM_SCALAR >
97 if (checkImplementations) { __checkInterfaceImplementation(c); }
102 template <
typename GUM_SCALAR >
108 for (
const auto& node : i->containerDag().nodes()) {
109 std::string name = i->get(node).name();
111 switch (i->get(node).elt_type()) {
114 if ((c->
get(name).elt_type()
116 || (c->
get(name).elt_type()
118 if (!c->
get(name).type().isSubTypeOf(i->get(name).type())) {
119 std::stringstream msg;
120 msg <<
"class " << c->
name()
121 <<
" does not respect interface ";
125 std::stringstream msg;
126 msg <<
"class " << c->
name() <<
" does not respect interface ";
134 if (c->
get(name).elt_type()
144 std::stringstream msg;
145 msg <<
"class " << c->
name()
146 <<
" does not respect interface ";
150 std::stringstream msg;
151 msg <<
"class " << c->
name() <<
" does not respect interface ";
165 "unexpected ClassElement<GUM_SCALAR> in interface ";
171 std::stringstream msg;
172 msg <<
"class " << c->
name() <<
" does not respect interface ";
182 template <
typename GUM_SCALAR >
185 const std::string& extends,
186 bool delayInheritance) {
187 std::string real_name = __addPrefix(name);
188 if (__prm->__classMap.exists(real_name)
189 || __prm->__interfaceMap.exists(real_name)) {
195 if (extends !=
"") { super = __retrieveInterface(extends); }
197 if (super !=
nullptr) {
203 __prm->__interfaceMap.insert(i->
name(), i);
204 __prm->__interfaces.insert(i);
205 __stack.push_back(i);
208 template <
typename GUM_SCALAR >
211 std::string real_name = __addPrefix(name);
212 if (!__prm->__interfaceMap.exists(real_name)) {
217 __stack.push_back(i);
220 template <
typename GUM_SCALAR >
228 attr->
cpf().variablesSequence();
232 if (vars.
exists(&(c->
get(node).type().variable()))) {
242 if (count != attr->
cpf().variablesSequence().size()) {
247 template <
typename GUM_SCALAR >
251 const std::string& name) {
258 "can not add a reference slot as a parent of an attribute");
265 "can not add a multiple slot chain to an attribute");
287 "found no ClassElement<GUM_SCALAR> with the given name ";
295 "Impossible to add a multiple reference slot as" 296 " direct parent of an PRMAttribute<GUM_SCALAR>.");
302 template <
typename GUM_SCALAR >
309 __addParent(c, a, name);
317 template <
typename GUM_SCALAR >
319 const std::vector< float >& array) {
324 if (a->
cpf().domainSize() != array.size())
327 std::vector< GUM_SCALAR > array2(array.begin(), array.end());
328 a->
cpf().fillWith(array2);
331 template <
typename GUM_SCALAR >
333 const std::vector< GUM_SCALAR >& array) {
338 if (a->cpf().domainSize() != array.size()) {
342 a->cpf().fillWith(array);
345 template <
typename GUM_SCALAR >
347 const std::vector< float >& array) {
351 if (a->
cpf().domainSize() != array.size()) {
355 std::vector< GUM_SCALAR > array2(array.begin(), array.end());
356 setRawCPFByColumns(array2);
359 template <
typename GUM_SCALAR >
361 const std::vector< GUM_SCALAR >& array) {
365 if (a->
cpf().domainSize() != array.size()) {
369 if (a->
cpf().nbrDim() == 1) {
370 setRawCPFByLines(array);
375 for (
auto idx = inst.variablesSequence().rbegin();
376 idx != inst.variablesSequence().rend();
382 auto idx = (std::size_t)0;
383 while ((!jnst.end()) && idx < array.size()) {
385 a->
cpf().set(inst, array[idx]);
392 template <
typename GUM_SCALAR >
394 const std::vector< std::string >& parents,
395 const std::vector< float >& values) {
399 if ((parents.size() + 1) != a->cpf().variablesSequence().size()) {
403 if (values.size() != a->type().variable().domainSize()) {
407 std::vector< GUM_SCALAR > values2(values.begin(), values.end());
408 setCPFByRule(parents, values2);
411 template <
typename GUM_SCALAR >
413 const std::vector< std::string >& parents,
414 const std::vector< GUM_SCALAR >& values) {
418 if ((parents.size() + 1) != a->cpf().variablesSequence().size()) {
422 if (values.size() != a->type().variable().domainSize()) {
435 for (
Idx i = 0; i < parents.size(); ++i) {
436 var = form->formulas().variablesSequence().atPos(1 + i);
438 if (parents[i] ==
"*") {
446 if (var->
label(j) == parents[i]) {
447 jnst.chgVal(*var, j);
454 std::string msg =
"could not find label ";
463 for (
Size i = 0; i < form->type()->domainSize(); ++i) {
464 inst.
chgVal(form->type().variable(), i);
466 for (inst.setFirstIn(knst); !inst.end(); inst.incIn(knst)) {
476 template <
typename GUM_SCALAR >
478 const std::vector< std::string >& parents,
479 const std::vector< std::string >& values) {
483 if ((parents.size() + 1) != a->cpf().variablesSequence().size()) {
487 if (values.size() != a->type().variable().domainSize()) {
500 for (
Idx i = 0; i < parents.size(); ++i) {
501 var = form->formulas().variablesSequence().atPos(1 + i);
503 if (parents[i] ==
"*") {
511 if (var->
label(j) == parents[i]) {
512 jnst.chgVal(*var, j);
519 std::string msg =
"could not find label ";
528 for (
Size i = 0; i < form->type()->domainSize(); ++i) {
529 inst.
chgVal(form->type().variable(), i);
531 for (inst.setFirstIn(knst); !inst.end(); inst.incIn(knst)) {
532 form->formulas().set(inst, values[i]);
541 template <
typename GUM_SCALAR >
543 const std::string& name,
554 }
else if (type ==
"real") {
566 template <
typename GUM_SCALAR >
568 const std::string& name,
569 const std::string& agg_type,
570 const std::string& rv_type,
571 const std::vector< std::string >& params) {
578 *__retrieveType(rv_type));
584 switch (agg->agg_type()) {
588 if (params.size() != 1) {
591 agg->setLabel(params.front());
598 __stack.push_back(agg);
601 template <
typename GUM_SCALAR >
606 auto& agg = c->
get(name);
610 __stack.push_back(&agg);
613 template <
typename GUM_SCALAR >
617 const std::string& name) {
618 auto chains = std::vector< std::string >{name};
619 auto inputs = std::vector< PRMClassElement< GUM_SCALAR >* >();
620 __retrieveInputs(c, chains, inputs);
625 if (inputs.front()->type() != *(__retrieveType(
"boolean"))) {
639 while (label_idx < inputs.front()->type()->domainSize()) {
640 if (inputs.front()->type()->label(label_idx) == param) {
break; }
645 if (label_idx == inputs.front()->type()->domainSize()) {
668 template <
typename GUM_SCALAR >
674 template <
typename GUM_SCALAR >
676 const std::string& name,
677 const std::string& agg_type,
678 const std::vector< std::string >& chains,
679 const std::vector< std::string >& params,
685 if (chains.size() == 0) {
687 "a PRMAggregate<GUM_SCALAR> requires at least one parent");
691 std::vector< PRMClassElement< GUM_SCALAR >* > inputs;
696 bool hasSC = __retrieveInputs(c, chains, inputs);
701 if (inputs.size() > 1) {
702 for (
auto iter = inputs.begin() + 1; iter != inputs.end(); ++iter) {
703 if ((**(iter - 1)).type() != (**iter).type()) {
715 if (inputs.front()->type() != *(__retrieveType(
"boolean"))) {
718 if (params.size() != 0) {
725 inputs.front()->type());
732 if (params.size() != 1) {
738 while (label_idx < inputs.front()->type()->domainSize()) {
739 if (inputs.front()->type()->label(label_idx) == params.front()) {
746 if (label_idx == inputs.front()->type()->domainSize()) {
754 *(__retrieveType(
"boolean")),
765 if (params.size() != 0) {
769 auto output_type = __retrieveType(type);
779 if (params.size() != 1) {
785 while (label_idx < inputs.front()->type()->domainSize()) {
786 if (inputs.front()->type()->label(label_idx) == params.front()) {
793 if (label_idx == inputs.front()->type()->domainSize()) {
797 auto output_type = __retrieveType(type);
812 std::string safe_name = agg->
safeName();
835 for (
const auto& elt : inputs) {
836 c->
addArc(elt->safeName(), safe_name);
840 template <
typename GUM_SCALAR >
842 const std::string& name,
848 slotType = __retrieveClass(type);
851 slotType = __retrieveInterface(type);
865 template <
typename GUM_SCALAR >
867 const std::string& name,
877 for (
Size i = 0; i < size; ++i) {
878 std::stringstream elt_name;
879 elt_name << name <<
"[" << i <<
"]";
881 model->
add(name, inst);
892 template <
typename GUM_SCALAR >
894 const std::string& r_i) {
900 model->
add(l_i, model->
get(r_i));
909 template <
typename GUM_SCALAR >
911 const std::string& l_i,
const std::string& l_ref,
const std::string& r_i) {
914 std::vector< PRMInstance< GUM_SCALAR >* > lefts;
915 std::vector< PRMInstance< GUM_SCALAR >* > rights;
917 if (model->isInstance(l_i)) {
918 lefts.push_back(&(model->get(l_i)));
919 }
else if (model->isArray(l_i)) {
920 for (
const auto& elt : model->getArray(l_i))
921 lefts.push_back(elt);
926 if (model->isInstance(r_i)) {
927 rights.push_back(&(model->get(r_i)));
928 }
else if (model->isArray(r_i)) {
929 for (
const auto& elt : model->getArray(r_i))
930 rights.push_back(elt);
935 for (
const auto l : lefts) {
936 for (
const auto r : rights) {
937 auto& elt = l->type().get(l_ref);
939 l->add(elt.id(), *r);
948 template <
typename GUM_SCALAR >
951 std::vector< std::string > v;
957 for (
size_t i = 0; i < v.size(); ++i) {
959 switch (current->
get(v[i]).elt_type()) {
962 current->
get(v[i])));
971 if (i == v.size() - 1) {
978 default: {
return nullptr; }
980 }
catch (
NotFound&) {
return nullptr; }
983 GUM_ASSERT(v.size() == elts.
size());
990 template <
typename GUM_SCALAR >
993 const std::vector< std::string >& chains,
997 for (
size_t i = 0; i < chains.size(); ++i) {
999 inputs.push_back(&(c->
get(chains[i])));
1003 inputs.push_back(__buildSlotChain(c, chains[i]));
1006 if (inputs.back()) {
1007 c->
add(inputs.back());
1014 PRMType* t = __retrieveCommonType(inputs);
1016 std::vector< std::pair< PRMClassElement< GUM_SCALAR >*,
1020 for (
const auto& elt : inputs) {
1021 if ((*elt).type() != (*t)) {
1025 std::stringstream name;
1027 for (
Size idx = 0; idx < sc->
chain().size() - 1; ++idx) {
1028 name << sc->
chain().atPos(idx)->name() <<
".";
1031 name <<
".(" << t->
name() <<
")" << sc->
lastElt().name();
1034 toAdd.push_back(std::make_pair(elt, &(c->
get(name.str()))));
1037 std::make_pair(elt, __buildSlotChain(c, name.str())));
1040 std::stringstream name;
1041 name <<
"(" << t->
name() <<
")" << elt->name();
1042 toAdd.push_back(std::make_pair(elt, &(c->
get(name.str()))));
1050 template <
typename GUM_SCALAR >
1053 const PRMType* current =
nullptr;
1057 for (
const auto& elt : elts) {
1059 current = &((*elt).type());
1061 while (current != 0) {
1064 ++(counters[current->
name()]);
1070 if (current->isSubType()) {
1071 current = &(current->superType());
1078 "found a ClassElement<GUM_SCALAR> without a type");
1087 int current_depth = 0;
1089 for (
const auto& elt : counters) {
1090 if ((elt.second) == elts.size()) {
1091 current_depth = __typeDepth(__retrieveType(elt.first));
1093 if (current_depth > max_depth) {
1094 max_depth = current_depth;
1095 current = __retrieveType(elt.first);
1100 if (current) {
return const_cast< PRMType*
>(current); }
1105 template <
typename GUM_SCALAR >
1107 const std::string& name,
1108 const std::vector< std::string >& chains,
1109 const std::vector< float >& numbers,
1111 const std::vector< std::string >& labels) {
1119 std::vector< PRMClassElement< GUM_SCALAR >* > parents;
1121 for (
const auto& elt : chains)
1122 parents.push_back(&(c->
get(elt)));
1124 PRMType* common_type = __retrieveCommonType(parents);
1126 for (
size_t idx = 0; idx < parents.size(); ++idx) {
1127 if (parents[idx]->type() != (*common_type)) {
1131 std::string safe_name = parent->
cast(*common_type);
1133 if (!c->
exists(safe_name)) {
1135 parents[idx] = __buildSlotChain(c, safe_name);
1136 c->
add(parents[idx]);
1141 parents[idx] = &(c->
get(safe_name));
1146 if (numbers.size() == 1) {
1150 name, retrieveType(
"boolean"), impl);
1152 }
else if (numbers.size() == parents.size()) {
1157 name, retrieveType(
"boolean"), noisy);
1159 for (
size_t idx = 0; idx < numbers.size(); ++idx) {
1160 noisy->
causalWeight(parents[idx]->type().variable(), numbers[idx]);
1168 if (!labels.empty()) {
1170 "labels definitions not handle for noisy-or");
1174 template <
typename GUM_SCALAR >
1178 std::string full_name;
1181 if (__prm->__typeMap.exists(name)) {
1182 type = __prm->__typeMap[name];
1187 std::string prefixed = __addPrefix(name);
1188 if (__prm->__typeMap.exists(prefixed)) {
1190 type = __prm->__typeMap[prefixed];
1191 full_name = prefixed;
1192 }
else if (full_name != prefixed) {
1194 "Type name '" << name <<
"' is ambiguous: specify full name.");
1199 std::string relatif_ns = currentPackage();
1200 size_t last_dot = relatif_ns.find_last_of(
'.');
1201 if (last_dot != std::string::npos) {
1202 relatif_ns = relatif_ns.substr(0, last_dot) +
'.' + name;
1203 if (__prm->__typeMap.exists(relatif_ns)) {
1205 type = __prm->__typeMap[relatif_ns];
1206 full_name = relatif_ns;
1207 }
else if (full_name != relatif_ns) {
1209 "Type name '" << name
1210 <<
"' is ambiguous: specify full name.");
1217 if (!__namespaces.empty()) {
1218 auto ns_list = __namespaces.back();
1219 for (
gum::Size i = 0; i < ns_list->size(); ++i) {
1220 std::string ns = (*ns_list)[i];
1221 std::string ns_name = ns +
"." + name;
1222 if (__prm->__typeMap.exists(ns_name)) {
1224 type = __prm->__typeMap[ns_name];
1225 full_name = ns_name;
1226 }
else if (full_name != ns_name) {
1228 "Type name '" << name
1229 <<
"' is ambiguous: specify full name.");
1242 template <
typename GUM_SCALAR >
1246 std::string full_name;
1249 if (__prm->__classMap.exists(name)) {
1250 a_class = __prm->__classMap[name];
1255 std::string prefixed = __addPrefix(name);
1256 if (__prm->__classMap.exists(prefixed)) {
1257 if (a_class ==
nullptr) {
1258 a_class = __prm->__classMap[prefixed];
1259 full_name = prefixed;
1260 }
else if (full_name != prefixed) {
1262 "Class name '" << name
1263 <<
"' is ambiguous: specify full name.");
1268 if (!__namespaces.empty()) {
1269 auto ns_list = __namespaces.back();
1270 for (
gum::Size i = 0; i < ns_list->size(); ++i) {
1271 std::string ns = (*ns_list)[i];
1272 std::string ns_name = ns +
"." + name;
1273 if (__prm->__classMap.exists(ns_name)) {
1275 a_class = __prm->__classMap[ns_name];
1276 full_name = ns_name;
1277 }
else if (full_name != ns_name) {
1279 "Class name '" << name
1280 <<
"' is ambiguous: specify full name.");
1293 template <
typename GUM_SCALAR >
1295 const std::string& name)
const {
1297 std::string full_name;
1300 if (__prm->__interfaceMap.exists(name)) {
1301 interface = __prm->__interfaceMap[name];
1306 std::string prefixed = __addPrefix(name);
1307 if (__prm->__interfaceMap.exists(prefixed)) {
1308 if (interface ==
nullptr) {
1309 interface = __prm->__interfaceMap[prefixed];
1310 full_name = prefixed;
1311 }
else if (full_name != prefixed) {
1313 "Interface name '" << name
1314 <<
"' is ambiguous: specify full name.");
1319 if (!__namespaces.empty()) {
1320 auto ns_list = __namespaces.back();
1322 for (
gum::Size i = 0; i < ns_list->size(); ++i) {
1323 std::string ns = (*ns_list)[i];
1324 std::string ns_name = ns +
"." + name;
1326 if (__prm->__interfaceMap.exists(ns_name)) {
1327 if (interface ==
nullptr) {
1328 interface = __prm->__interfaceMap[ns_name];
1329 full_name = ns_name;
1330 }
else if (full_name != ns_name) {
1333 << name <<
"' is ambiguous: specify full name.");
1339 if (interface ==
nullptr) {
1341 "Interface '" << name <<
"' not found, check imports.");
1347 template <
typename GUM_SCALAR >
1353 template <
typename GUM_SCALAR >
1359 template <
typename GUM_SCALAR >
1369 template <
typename GUM_SCALAR >
1374 template <
typename GUM_SCALAR >
1378 return __stack.back()->obj_type();
1381 template <
typename GUM_SCALAR >
1388 template <
typename GUM_SCALAR >
1395 template <
typename GUM_SCALAR >
1406 template <
typename GUM_SCALAR >
1411 template <
typename GUM_SCALAR >
1414 std::string super) {
1416 if (
__prm->__typeMap.exists(real_name)) {
1425 t->__label_map =
new std::vector< Idx >();
1430 template <
typename GUM_SCALAR >
1432 std::string extends) {
1433 if (extends ==
"") {
1440 "the current type's variable is not a LabelizedVariable.");
1441 }
else if (t->__superType) {
1457 "the current type's variable is not a LabelizedVariable.");
1458 }
else if (!t->__superType) {
1464 for (
Idx i = 0; i < t->__superType->__var->
domainSize(); ++i) {
1465 if (t->__superType->__var->
label(i) == extends) {
1472 t->__label_map->push_back(i);
1483 template <
typename GUM_SCALAR >
1488 if (!t->__isValid()) {
1492 "current type is not a valid discrete type");
1497 __prm->__types.insert(t);
1501 template <
typename GUM_SCALAR >
1505 if (
__prm->__typeMap.exists(real_name)) {
1513 template <
typename GUM_SCALAR >
1522 "the current type's variable is not a LabelizedVariable.");
1532 template <
typename GUM_SCALAR >
1539 "current type is not a valid discrete type");
1544 __prm->__types.insert(t);
1548 template <
typename GUM_SCALAR >
1553 if (
__prm->__typeMap.exists(real_name)) {
1554 std::stringstream msg;
1555 msg <<
"\"" << real_name <<
"' is already used.";
1562 if (t->variable().domainSize() < 2) {
1564 "current type is not a valid discrete type");
1567 __prm->__typeMap.insert(t->name(), t);
1568 __prm->__types.insert(t);
1571 template <
typename GUM_SCALAR >
1577 template <
typename GUM_SCALAR >
1579 const std::string& name) {
1585 template <
typename GUM_SCALAR >
1587 const std::string& name,
1602 std::string dot =
".";
1609 if (a !=
nullptr && (!c->
exists(a->
id()))) {
delete a; }
1615 template <
typename GUM_SCALAR >
1620 auto& a = c->
get(name);
1627 template <
typename GUM_SCALAR >
1633 template <
typename GUM_SCALAR >
1635 if (
__prm->__systemMap.exists(name)) {
1641 __prm->__systemMap.insert(model->
name(), model);
1642 __prm->__systems.insert(model);
1645 template <
typename GUM_SCALAR >
1655 template <
typename GUM_SCALAR >
1657 const std::string& name) {
1661 if (c->parameters().size() > 0) {
1670 template <
typename GUM_SCALAR >
1672 const std::string& type,
1673 const std::string& name,
1677 if (c->parameters().empty()) {
1678 if (params.
empty()) {
1682 "Class " + type +
" does not have parameters");
1686 auto my_params = params;
1688 for (
const auto& p : c->parameters()) {
1689 if (!my_params.exists(p->name())) {
1690 my_params.
insert(p->name(), p->value());
1695 std::stringstream sBuff;
1696 sBuff << c->name() <<
"<";
1698 for (
const auto& p : my_params) {
1699 sBuff << p.first <<
"=" << p.second <<
",";
1703 std::string sub_c = sBuff.str().substr(0, sBuff.str().size() - 1) +
">";
1713 for (
auto p : my_params) {
1736 template <
typename GUM_SCALAR >
1739 const std::string& name) {
1748 if (i) {
delete i; }
1753 template <
typename GUM_SCALAR >
1758 full_name.append(
".");
1759 full_name.append(str);
1766 template <
typename GUM_SCALAR >
1784 template <
typename GUM_SCALAR >
1802 template <
typename GUM_SCALAR >
1825 template <
typename GUM_SCALAR >
1830 while (current->isSubType()) {
1832 current = &(current->superType());
1838 template <
typename GUM_SCALAR >
1844 template <
typename GUM_SCALAR >
1862 template <
typename GUM_SCALAR >
1864 if (name.size() == 0) {
1873 template <
typename GUM_SCALAR >
1876 const std::string& r_i) {
1877 size_t pos = l_i.find_last_of(
'.');
1879 if (pos != std::string::npos) {
1880 std::string l_ref = l_i.substr(pos + 1, std::string::npos);
1887 template <
typename GUM_SCALAR >
1893 template <
typename GUM_SCALAR >
1899 template <
typename GUM_SCALAR >
1906 template <
typename GUM_SCALAR >
1908 const std::string& type)
const {
1926 template <
typename GUM_SCALAR >
1928 const std::string& name)
const {
1931 return (system && system->
isArray(name));
1934 template <
typename GUM_SCALAR >
1936 const std::vector< std::string >& array) {
1942 if (a->formulas().domainSize() != array.size()) {
1946 if (a->formulas().nbrDim() == 1) {
1952 for (
auto idx = inst.variablesSequence().rbegin();
1953 idx != inst.variablesSequence().rend();
1959 auto idx = (std::size_t)0;
1960 while ((!jnst.end()) && idx < array.size()) {
1962 a->formulas().set(inst, array[idx]);
1972 template <
typename GUM_SCALAR >
1974 const std::vector< std::string >& array) {
1980 if (a->formulas().domainSize() != array.size()) {
1984 a->formulas().populate(array);
PRM< GUM_SCALAR > * __prm
The pointer on the PRM<GUM_SCALAR> built by this factory.
virtual NodeId add(PRMClassElement< GUM_SCALAR > *elt)
See gum::prm::add(PRMClassElement<GUM_SCALAR>*).
const Set< PRMInterface< GUM_SCALAR > *> & implements() const
Returns the Set of PRMInterface<GUM_SCALAR> implemented by this Class<GUM_SCALAR>.
PRMParameter is a member of a Class in a PRM.
std::vector< PRMObject *> __stack
A stack used to keep track of created PRMObject.
virtual void endInterface() override
Tells the factory that we finished an interface declaration.
virtual void pushPackage(const std::string &name) override
Define the current package.
virtual void addAggregator(const std::string &name, const std::string &agg_type, const std::vector< std::string > &chains, const std::vector< std::string > ¶ms, std::string type="") override
Add an aggregator in the current declared class.
virtual void addRangeType(const std::string &name, long minVal, long maxVal) override
Add a range variable type declaration.
bool empty() const noexcept
Indicates whether the set is the empty set.
static AggregateType str2enum(const std::string &str)
Static method which returns the AggregateType given its string representation.
static INLINE bool isClass(const PRMObject &obj)
Returns true if obj_ptr is of type Class.
DiscreteVariable & variable()
Return a reference on the DiscreteVariable contained in this.
MultiDimImplementation< GUM_SCALAR > * buildImpl() const
Returns a pointer over an empty gum::MultiDimImplementation of the good type for this PRMAggregate...
void add(NodeId id, PRMInstance< GUM_SCALAR > &instance)
Add an PRMInstance<GUM_SCALAR> to a given PRMReferenceSlot, PRMSlotChain<GUM_SCALAR> or output node...
void endAggregator()
Finishes an aggregate declaration.
virtual void setReferenceSlot(const std::string &left_instance, const std::string &left_reference, const std::string &right_instance) override
Instantiate a reference in the current model.
Headers of gum::PRMAttribute.
virtual ~PRMFactory()
Destructor.
virtual void addNoisyOrCompound(const std::string &name, const std::vector< std::string > &chains, const std::vector< float > &numbers, float leak, const std::vector< std::string > &label) override
Add a compound noisy-or as an PRMAttribute<GUM_SCALAR> to the current Class<GUM_SCALAR>.
const std::string & name() const
Returns the name of this object.
virtual std::string popPackage() override
Pop the current package from the package stack.
Size size() const noexcept
Returns the size of the sequence.
virtual void addInstance(const std::string &type, const std::string &name) override
Add an instance to the model.
virtual void setRawCPFByFloatColumns(const std::vector< float > &array) override
Gives the factory the CPF in its raw form.
virtual PRMType & type()=0
See gum::PRMClassElement::type().
virtual void addArray(const std::string &type, const std::string &name, Size size) override
Creates an array with the given number of instances of the given type.
An PRMInstance is a Bayesian Network fragment defined by a Class and used in a PRMSystem.
virtual void setCPFByFloatRule(const std::vector< std::string > &labels, const std::vector< float > &values) override
Fills the CPF using a rule.
The generic class for storing (ordered) sequences of objects.
Class for discretized random variable.
virtual prm_type obj_type() const =0
Returns the type of this object.
PRMType * __retrieveType(const std::string &name) const
Returns a pointer on a PRMType given it's name. Since the type can be given either with it's local na...
virtual void continueClass(const std::string &c) override
Continue the declaration of a class.
PRMClassElementContainer< GUM_SCALAR > * __checkStackContainter(Idx i)
Adds __prefix to str iff __prefix != "".
virtual void continueInterface(const std::string &name) override
Continue the declaration of an interface.
Abstract class representing an element of PRM class.
virtual void addImport(const std::string &name) override
Add an import for namespace lookup.
virtual void startDiscretizedType(const std::string &name) override
Start a discretized type declaration.
PRMClass< GUM_SCALAR > & retrieveClass(const std::string &name)
Returns a reference over a Class<GUM_SCALAR> given its name.
virtual void endAttribute() override
Tells the factory that we finished declaring an attribute.
bool exists(const Key &key) const
Checks whether there exists an element with a given key in the hashtable.
virtual void startInterface(const std::string &i, const std::string &ext="", bool delayInheritance=false) override
Tells the factory that we start an interface declaration.
virtual void addReferenceSlot(const std::string &type, const std::string &name, bool isArray) override
Tells the factory that we started declaring a slot.
Instantiation & chgVal(const DiscreteVariable &v, Idx newval)
Assign newval to variable v in the Instantiation.
virtual PRMClassElement< GUM_SCALAR > & get(const std::string &name)=0
Getter on a member of this PRMClassElementContainer.
PRMType & retrieveCommonType(const std::vector< PRMClassElement< GUM_SCALAR > * > &elts)
Returns a pointer on the PRM<GUM_SCALAR> created by this factory.
Base class for discrete random variable.
PRMType & retrieveType(const std::string &name)
Returns a reference over a PRMType given its name.
virtual bool exists(const std::string &name) const
Returns true if a member with the given name exists in this PRMClassElementContainer or in the PRMCla...
void __addInstance(PRMClass< GUM_SCALAR > *type, const std::string &name)
Adds a instance to the current model.
gum is the global namespace for all aGrUM entities
virtual void addAttribute(const std::string &type, const std::string &name) override
Add an attribute to an interface.
Instantiation & setVals(const Instantiation &i)
Assign the values from i in the Instantiation.
void setLabel(Idx idx)
Set the aggregator's label.
A PRMReferenceSlot represent a relation between two PRMClassElementContainer.
virtual void startClass(const std::string &c, const std::string &ext="", const Set< std::string > *implements=nullptr, bool delayInheritance=false) override
Tells the factory that we start a class declaration.
PRMClassElementContainer< GUM_SCALAR > & slotType()
Returns the type of this slot, which is a PRMClassElementContainer (it is not the type of PRMObject)...
void continueAggregator(const std::string &name)
Conitnues an aggregator declaration.
virtual void incArray(const std::string &l_i, const std::string &r_i) override
Add an instance to an array.
virtual void startSystem(const std::string &name) override
Tells the factory that we started declaring a model.
virtual void setRawCPFByFloatLines(const std::vector< float > &array) override
Gives the factory the CPF in its raw form.
virtual void startAttribute(const std::string &type, const std::string &name, bool scalar_atttr=false) override
Tells the factory that we start an attribute declaration.
virtual std::string cast(const PRMType &t) const
Returns the name of the cast descendant with PRMType t of this PRMClassElement.
NodeId add(PRMInstance< GUM_SCALAR > *i)
Add an PRMInstance to this system.
virtual std::string currentPackage() const override
const std::string & safeName() const
Returns the safe name of this PRMClassElement, if any.
virtual Size domainSize() const =0
PRMType * __retrieveCommonType(const std::vector< PRMClassElement< GUM_SCALAR > * > &elts)
Retrieve the common PRMType of a vector of PRMClassElement<GUM_SCALAR>.
void setRawCPFByColumns(const std::vector< GUM_SCALAR > &array)
Gives the factory the CPF in its raw form.
prm_type
Enumeration of the different types of objects handled by a PRM.
virtual PRMObject::prm_type currentType() const override
bool isInstance(const std::string &name) const
Returns true if an PRMInstance with the given name exists.
PRMInstance< GUM_SCALAR > & get(NodeId id)
Returns an PRMInstance given it's NodeId in the relational skeleton.
Factory which builds a PRM<GUM_SCALAR>.
const std::string & labelValue() const
See gum::PRMClassElement::elt_type().
std::string to_string(const Formula &f)
bool isMultiple() const
Return true if this slot chain contains at least one multiple reference slot.
DiscretizedVariable & addTick(const T_TICKS &aTick)
add a tick.
virtual std::string label(Idx i) const =0
get the indice-th label. This method is pure virtual.
AggregateType agg_type() const
Returns the aggregate of *this.
virtual const Potential< GUM_SCALAR > & cpf() const =0
See gum::PRMClassElement::cpf().
virtual void setCPFByRule(const std::vector< std::string > &labels, const std::vector< GUM_SCALAR > &values)
Fills the CPF using a rule.
<agrum/PRM/elements/funcAttribute.h>
PRMClassElement< GUM_SCALAR > & get(NodeId id)
See gum::prm::PRMClassElementContainer<GUM_SCALAR>::get(NodeId).
virtual void addArc(const std::string &tail, const std::string &head)
See gum::prm::PRMClassElementContainer<GUM_SCALAR>::addArc().
PRMSlotChain< GUM_SCALAR > * __buildSlotChain(PRMClassElementContainer< GUM_SCALAR > *start, const std::string &name)
This methods build a PRMSlotChain<GUM_SCALAR> given a starting element and a string.
A PRMSystem is a container of PRMInstance and describe a relational skeleton.
void __addParent(PRMClassElementContainer< GUM_SCALAR > *c, PRMAttribute< GUM_SCALAR > *agg, const std::string &name)
Add a parent to an attribute.
bool exists(const Key &k) const
Check the existence of k in the sequence.
Base class for all aGrUM's exceptions.
void instantiate()
Instantiate all the PRMInstance in this PRMSystem.
virtual PRMObject * getCurrent() override
virtual NodeId overload(PRMClassElement< GUM_SCALAR > *elt)
See gum::prm::overload(PRMClassElement<GUM_SCALAR>*).
std::vector< std::string > __packages
The prefix used for classes and types names. It is normally the namespace of the corresponding compil...
PRMFactory()
Default constructor.
This is a decoration of the DiscreteVariable class.
An PRMInterface is implemented by a Class<GUM_SCALAR> and defines a set of PRMReferenceSlot<GUM_SCALA...
virtual ClassElementType elt_type() const =0
Return the type of class element this object is.
virtual void endClass(bool checkImplementations=true) override
Tells the factory that we finished a class declaration.
virtual PRMObject * closeCurrent() override
Close current object being built.
Defines a discrete random variable over an integer interval.
A PRMSlotChain represents a sequence of gum::prm::PRMClassElement<GUM_SCALAR> where the n-1 first gum...
void setRawCPFByLines(const std::vector< GUM_SCALAR > &array)
Gives the factory the CPF in its raw form.
virtual NodeId add(PRMClassElement< GUM_SCALAR > *elt)=0
Add a PRMClassElement<GUM_SCALAR> to this PRMClassElementContainer.
Abstract base class for any element defined in a PRM.
virtual NodeId overload(PRMClassElement< GUM_SCALAR > *elt)=0
Add a PRMClassElement<GUM_SCALAR> which overload an inherited PRMClassElement<GUM_SCALAR>.
void __checkInterfaceImplementation(PRMClass< GUM_SCALAR > *c)
Check if c implements correctly all his interfaces.
Class for assigning/browsing values to tuples of discrete variables.
virtual PRMType & type()
See gum::PRMClassElement::type().
virtual void setOutputNode(const PRMClassElement< GUM_SCALAR > &elt, bool b)
Set the output flag value of id at b.
bool hasLabel() const
Returns true if the label is defined.
This class represents a Probabilistic Relational PRMSystem<GUM_SCALAR>.
std::string __addPrefix(const std::string &str) const
Adds __prefix to str iff __prefix != "".
virtual void startDiscreteType(const std::string &name, std::string super="") override
Start a discrete subtype declaration.
PRMClass< GUM_SCALAR > * __retrieveClass(const std::string &name) const
Returns a pointer on a class given it's name. Used when building models, meaning that the class name ...
virtual void endDiscretizedType() override
End the current discretized type declaration.
<agrum/PRM/classElementContainer.h>
PRMObject * __checkStack(Idx i, PRMObject::prm_type obj_type)
Return a pointer on a PRMObject at __stack.size() - i position after checking the type of the object ...
NodeId id() const
Returns the NodeId of this element in it's class DAG.
A PRMClass is an object of a PRM representing a fragment of a Bayesian Network which can be instantia...
GUM_SCALAR causalWeight(const DiscreteVariable &v) const
Copy of a multiDimICIModel.
bool isArray(const std::string &name) const
Returns true if an array with the given name exists.
void decomposePath(const std::string &path, std::vector< std::string > &v)
Decompose a string in a vector of strings using "." as separators.
virtual void endDiscreteType() override
End the current discrete type declaration.
virtual void continueAttribute(const std::string &name) override
Continues the declaration of an attribute.
static INLINE bool isSlotChain(const PRMClassElement< GUM_SCALAR > &elt)
Return true if obj is of type PRMSlotChain.
Header of gumRangeVariable.
Size Idx
Type for indexes.
void addParameter(const std::string &type, const std::string &name, double value) override
Add a parameter to the current class with a default value.
std::vector< List< std::string > *> __namespaces
Set of all declared namespaces.
void add(const DiscreteVariable &v) final
Adds a new variable in the Instantiation.
int __typeDepth(const PRMType *t)
Returns the inheritance depth of a PRMType.
virtual bool isClassOrInterface(const std::string &type) const override
virtual void addLabel(const std::string &l, std::string ext="") override
Add a label to the current discrete type.
PRMAttribute is a member of a Class in a PRM.
std::size_t Size
In aGrUM, hashed values are unsigned long int.
PRMClassElement< GUM_SCALAR > & lastElt()
Returns the last element of the slot chain, typically this is an gum::PRMAttribute or a gum::PRMAggre...
virtual void addArc(const std::string &tail, const std::string &head)=0
Add an arc between two PRMClassElement<GUM_SCALAR>.
value_type & insert(const Key &key, const Val &val)
Adds a new element (actually a copy of this element) into the hash table.
const std::string & name() const
returns the name of the variable
virtual void endSystem() override
Tells the factory that we finished declaring a model.
LabelizedVariable & addLabel(const std::string &aLabel)
add a label with a new index (we assume that we will NEVER remove a label)
bool empty() const noexcept
Indicates whether the hash table is empty.
void addArray(const std::string &array, PRMClassElementContainer< GUM_SCALAR > &type)
Add an array of instances in this system. If the array doesn't exists it is created.
virtual const DAG & containerDag() const
Returns the gum::DAG of this PRMClassElementContainer.
<agrum/PRM/elements/scalarAttribute.h>
Idx label() const
Returns the label's index on which this aggregate applies.
PRMInterface< GUM_SCALAR > * __retrieveInterface(const std::string &name) const
Returns a pointer on an interface given it's name. Used when building models, meaning that the interf...
PRM< GUM_SCALAR > * prm() const
Returns a pointer on the PRM<GUM_SCALAR> created by this factory.
virtual bool isArrayInCurrentSystem(const std::string &name) const override
void insert(const Key &k)
Inserts a new element into the set.
const Key & back() const
Returns the last element of the sequence.
void startAggregator(const std::string &name, const std::string &agg_type, const std::string &rv_type, const std::vector< std::string > ¶ms)
Start an aggregator declaration.
virtual void addParent(const std::string &name) override
Tells the factory that we add a parent to the current declared attribute.
#define GUM_ERROR(type, msg)
virtual void addTick(double tick) override
Add a tick to the current discretized type.
Sequence< PRMClassElement< GUM_SCALAR > *> & chain()
Return the sequence representing the chain of elements in this PRMSlotChain.
non-template interface-like parent for every PRM Factory
ClassElementType
Returns true if obj_ptr is of type PRMReferenceSlot.
bool __retrieveInputs(PRMClass< GUM_SCALAR > *c, const std::vector< std::string > &chains, std::vector< PRMClassElement< GUM_SCALAR > * > &inputs)
Retrieve inputs for an PRMAggregate.
void insert(const Key &k)
Insert an element at the end of the sequence.