aGrUM  0.20.3
a C++ library for (probabilistic) graphical models
gum::prm::PRMScalarAttribute< GUM_SCALAR > Class Template Reference

<agrum/PRM/elements/scalarAttribute.h> More...

#include <PRMScalarAttribute.h>

+ Inheritance diagram for gum::prm::PRMScalarAttribute< GUM_SCALAR >:
+ Collaboration diagram for gum::prm::PRMScalarAttribute< GUM_SCALAR >:

Public Member Functions

Constructor & destructor.
 PRMScalarAttribute (const std::string &name, const PRMType &type, MultiDimImplementation< GUM_SCALAR > *impl=new MultiDimArray< GUM_SCALAR >())
 Constructor used by gum::Class. More...
 
virtual ~PRMScalarAttribute ()
 Destructor. More...
 
Getters & setters
virtual PRMAttribute< GUM_SCALAR > * newFactory (const PRMClass< GUM_SCALAR > &c) const
 See gum::PRMClassElement::elt_type(). More...
 
virtual PRMAttribute< GUM_SCALAR > * copy (Bijection< const DiscreteVariable *, const DiscreteVariable * > bij) const
 See gum::PRMClassElement::elt_type(). More...
 
virtual void copyCpf (const Bijection< const DiscreteVariable *, const DiscreteVariable * > &bif, const PRMAttribute< GUM_SCALAR > &source)
 See gum::PRMClassElement::elt_type(). More...
 
virtual PRMClassElement< GUM_SCALAR >::ClassElementType elt_type () const
 See gum::PRMClassElement::elt_type(). More...
 
virtual PRMTypetype ()
 See gum::PRMClassElement::type(). More...
 
virtual const PRMTypetype () const
 See gum::PRMClassElement::type(). More...
 
virtual const Potential< GUM_SCALAR > & cpf () const
 See gum::PRMClassElement::cpf(). More...
 
virtual void addParent (const PRMClassElement< GUM_SCALAR > &elt)
 See gum::PRMClassElement::addParent_(). More...
 
virtual void addChild (const PRMClassElement< GUM_SCALAR > &elt)
 See gum::PRMClassElement::addChild_(). More...
 
virtual PRMAttribute< GUM_SCALAR > * getCastDescendant () const
 See gum::PRMClassElement::elt_type(). More...
 
virtual void setAsCastDescendant (PRMAttribute< GUM_SCALAR > *attr)
 See gum::PRMClassElement::elt_type(). More...
 
virtual void becomeCastDescendant (PRMType &subtype)
 See gum::PRMClassElement::elt_type(). More...
 
virtual void swap (const PRMType &old_type, const PRMType &new_type)
 Swap old_type with new_type in the PRMClassElement cpt. More...
 
Getters & setters
virtual void overload (PRMAttribute< GUM_SCALAR > *source)
 Set this as overload of source (necessayr to preserver internal pointers for MultiDims). More...
 
Getters & setters
NodeId id () const
 Returns the NodeId of this element in it's class DAG. More...
 
virtual void setId (NodeId id)
 Used to assign the id of this element. More...
 
virtual PRMObject::prm_type obj_type () const
 
Fast access to random variable's properties
const std::string & safeName () const
 Returns the safe name of this PRMClassElement, if any. More...
 
virtual std::string cast (const PRMType &t) const
 Returns the name of the cast descendant with PRMType t of this PRMClassElement. More...
 
Getters & setters.
const std::string & name () const
 Returns the name of this object. More...
 
void name (const std::string &name)
 Change the name of the PRM Object. More...
 
Operators
bool operator== (const PRMObject &obj) const
 To PRMObject are equal if they have the same name (which is unique). More...
 
bool operator!= (const PRMObject &obj) const
 To PRMObject are equal if they have the same name (which is unique). More...
 

Protected Attributes

std::string safeName_
 The safe name of this PRMClassElement. More...
 

Protected Member Functions

 PRMScalarAttribute (const PRMScalarAttribute &source)
 Copy constructor. Don't use it. More...
 
PRMScalarAttributeoperator= (const PRMScalarAttribute &from)
 Copy operator. Don't use it. More...
 
virtual PRMTypetype_ ()
 
virtual void type_ (PRMType *t)
 

Built-in type

enum  ClassElementType {
  prm_attribute, prm_aggregate, prm_refslot, prm_slotchain,
  prm_parameter
}
 Returns true if obj_ptr is of type PRMReferenceSlot. More...
 
static std::string enum2str (ClassElementType type)
 Returns true if obj_ptr is of type PRMReferenceSlot. More...
 
static INLINE bool isReferenceSlot (const PRMClassElement< GUM_SCALAR > &elt)
 Returns true if obj_ptr is of type PRMReferenceSlot. More...
 
static INLINE bool isAttribute (const PRMClassElement< GUM_SCALAR > &elt)
 Returns true if obj_ptr is of type PRMAttribute. More...
 
static INLINE bool isAggregate (const PRMClassElement< GUM_SCALAR > &elt)
 Return true if obj is of type PRMAggregate. More...
 
static INLINE bool isSlotChain (const PRMClassElement< GUM_SCALAR > &elt)
 Return true if obj is of type PRMSlotChain. More...
 
static INLINE bool isParameter (const PRMClassElement< GUM_SCALAR > &elt)
 Return true if obj is of type PRMParameter. More...
 

Built-in types.

enum  prm_type : char {
  prm_type::ALL, prm_type::CLASS, prm_type::PRM_INTERFACE, prm_type::CLASS_ELT,
  prm_type::TYPE, prm_type::SYSTEM, prm_type::INSTANCE
}
 Enumeration of the different types of objects handled by a PRM. More...
 
static std::string enum2str (prm_type type)
 Returns the string representation of a PRMObject. More...
 
static std::string LEFT_CAST ()
 Enumeration of the different types of objects handled by a PRM. More...
 
static std::string RIGHT_CAST ()
 Enumeration of the different types of objects handled by a PRM. More...
 
static INLINE bool isClass (const PRMObject &obj)
 Returns true if obj_ptr is of type Class. More...
 
static INLINE bool isInterface (const PRMObject &obj)
 Returns true if obj_ptr is of type PRMInterface. More...
 
static INLINE bool isInstance (const PRMObject &obj)
 Returns true if obj_ptr is of type PRMInstance. More...
 

Detailed Description

template<typename GUM_SCALAR>
class gum::prm::PRMScalarAttribute< GUM_SCALAR >

<agrum/PRM/elements/scalarAttribute.h>

PRMScalarAttribute is a member of a Class in a PRM.

A PRMScalarAttribute is defined by its name, its containing class, its type and by a Conditional Probability Function (aka CPF but represented by a Potential).

An attribute in a PRM is the equivalent of a random variable in a bayesian network.

This class is constructed by a gum::PRMFactory and is deleted by its gum::Class.

Built-in copies (copy constructor and copy operator) are illegal due to various problems raised by redondant information.

See also
PRM PRMFactory Class PRMClassElement PRMType Potential

Definition at line 66 of file PRMScalarAttribute.h.

Member Enumeration Documentation

◆ ClassElementType

template<typename GUM_SCALAR>
enum gum::prm::PRMClassElement::ClassElementType
inherited

Returns true if obj_ptr is of type PRMReferenceSlot.

Enumerator
prm_attribute 
prm_aggregate 
prm_refslot 
prm_slotchain 
prm_parameter 

Definition at line 94 of file PRMClassElement.h.

◆ prm_type

enum gum::prm::PRMObject::prm_type : char
stronginherited

Enumeration of the different types of objects handled by a PRM.

The "all" type is used to tell that we want any kind of PRMType (useful with iterators for example). No PRMObject will ever have "all" as type.

Enumerator
ALL 
CLASS 
PRM_INTERFACE 
CLASS_ELT 
TYPE 
SYSTEM 
INSTANCE 

Definition at line 68 of file PRMObject.h.

68  : char
69  {
70  ALL,
71  CLASS,
72  PRM_INTERFACE,
73  CLASS_ELT,
74  TYPE,
75  SYSTEM,
76  INSTANCE
77  };

Constructor & Destructor Documentation

◆ PRMScalarAttribute() [1/2]

template<typename GUM_SCALAR >
gum::prm::PRMScalarAttribute< GUM_SCALAR >::PRMScalarAttribute ( const std::string &  name,
const PRMType type,
MultiDimImplementation< GUM_SCALAR > *  impl = new MultiDimArray< GUM_SCALAR >() 
)

Constructor used by gum::Class.

This will create an PRMAttribute with only one variable: type and with the given implementation.

Parameters
nameThe name of this PRMAttribute.
typeThe type of this PRMAttribute, it is copied.
implThe MultiDimImplementation used by the internal Potential of this PRMAttribute. it will be deleted after the call of ~PRMAttribute.

Definition at line 40 of file PRMScalarAttribute_tpl.h.

43  :
44  PRMAttribute< GUM_SCALAR >(name),
45  _type_(new PRMType(type)), _cpf_(new Potential< GUM_SCALAR >(impl)) {
46  GUM_CONSTRUCTOR(PRMScalarAttribute);
47  _cpf_->add(_type_->variable());
48 
50  }
const std::string & name() const
Returns the name of this object.
Definition: PRMObject_inl.h:34
PRMType * _type_
The random variable type of this attribute.
virtual PRMType & type()
See gum::PRMClassElement::type().
std::string safeName_
The safe name of this PRMClassElement.
static std::string LEFT_CAST()
Enumeration of the different types of objects handled by a PRM.
Definition: PRMObject.h:79
const std::string & name() const
returns the name of the variable
static std::string RIGHT_CAST()
Enumeration of the different types of objects handled by a PRM.
Definition: PRMObject.h:80
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.
PRMScalarAttribute(const std::string &name, const PRMType &type, MultiDimImplementation< GUM_SCALAR > *impl=new MultiDimArray< GUM_SCALAR >())
Constructor used by gum::Class.

◆ ~PRMScalarAttribute()

template<typename GUM_SCALAR >
gum::prm::PRMScalarAttribute< GUM_SCALAR >::~PRMScalarAttribute ( )
virtual

Destructor.

Definition at line 62 of file PRMScalarAttribute_tpl.h.

62  {
63  GUM_DESTRUCTOR(PRMScalarAttribute);
64  delete _cpf_;
65  delete _type_;
66  }
PRMType * _type_
The random variable type of this attribute.
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.
PRMScalarAttribute(const std::string &name, const PRMType &type, MultiDimImplementation< GUM_SCALAR > *impl=new MultiDimArray< GUM_SCALAR >())
Constructor used by gum::Class.

◆ PRMScalarAttribute() [2/2]

template<typename GUM_SCALAR >
gum::prm::PRMScalarAttribute< GUM_SCALAR >::PRMScalarAttribute ( const PRMScalarAttribute< GUM_SCALAR > &  source)
protected

Copy constructor. Don't use it.

Definition at line 53 of file PRMScalarAttribute_tpl.h.

54  :
55  PRMAttribute< GUM_SCALAR >(source),
56  _type_(0), _cpf_(0) {
57  GUM_CONS_CPY(PRMScalarAttribute);
58  GUM_ERROR(FatalError, "Illegal call to the copy constructor of gum::ScalarAttribute")
59  }
PRMType * _type_
The random variable type of this attribute.
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.
PRMScalarAttribute(const std::string &name, const PRMType &type, MultiDimImplementation< GUM_SCALAR > *impl=new MultiDimArray< GUM_SCALAR >())
Constructor used by gum::Class.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51

Member Function Documentation

◆ addChild()

template<typename GUM_SCALAR >
INLINE void gum::prm::PRMScalarAttribute< GUM_SCALAR >::addChild ( const PRMClassElement< GUM_SCALAR > &  elt)
virtual

See gum::PRMClassElement::addChild_().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Reimplemented in gum::prm::PRMFuncAttribute< GUM_SCALAR >.

Definition at line 155 of file PRMScalarAttribute_tpl.h.

155 {}

◆ addParent()

template<typename GUM_SCALAR >
INLINE void gum::prm::PRMScalarAttribute< GUM_SCALAR >::addParent ( const PRMClassElement< GUM_SCALAR > &  elt)
virtual

See gum::PRMClassElement::addParent_().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Reimplemented in gum::prm::PRMFuncAttribute< GUM_SCALAR >.

Definition at line 142 of file PRMScalarAttribute_tpl.h.

142  {
143  try {
144  _cpf_->add(elt.type().variable());
145  } catch (DuplicateElement&) {
146  GUM_ERROR(DuplicateElement, elt.name() << " as parent of " << this->name())
147  } catch (OperationNotAllowed&) {
148  GUM_ERROR(OperationNotAllowed, elt.name() << " of wrong type as parent of " << this->name())
149  }
150  }
const std::string & name() const
Returns the name of this object.
Definition: PRMObject_inl.h:34
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51

◆ becomeCastDescendant()

template<typename GUM_SCALAR >
void gum::prm::PRMScalarAttribute< GUM_SCALAR >::becomeCastDescendant ( PRMType subtype)
virtual

See gum::PRMClassElement::elt_type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 198 of file PRMScalarAttribute_tpl.h.

198  {
199  delete _cpf_;
200  _cpf_ = new Potential< GUM_SCALAR >();
201  _cpf_->add(type().variable());
202  _cpf_->add(subtype.variable());
203 
204  Instantiation inst(*_cpf_);
205 
206  for (inst.setFirst(); !inst.end(); inst.inc()) {
207  auto my_pos = inst.pos(subtype.variable());
208  if (subtype.label_map()[my_pos] == inst.pos(type().variable())) {
209  _cpf_->set(inst, 1);
210  } else {
211  _cpf_->set(inst, 0);
212  }
213  }
214  }
virtual PRMType & type()
See gum::PRMClassElement::type().
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.

◆ cast()

template<typename GUM_SCALAR >
INLINE std::string gum::prm::PRMClassElement< GUM_SCALAR >::cast ( const PRMType t) const
virtualinherited

Returns the name of the cast descendant with PRMType t of this PRMClassElement.

Parameters
tThe type in which we want to cast this PRMClassElement.
Exceptions
OperationNotAllowedIf the cast is impossible.

Definition at line 71 of file PRMClassElement_tpl.h.

71  {
72  if (type().isSubTypeOf(t)) {
73  return PRMObject::LEFT_CAST() + t.name() + PRMObject::RIGHT_CAST() + name();
74  } else {
75  GUM_ERROR(OperationNotAllowed, "illegal cast")
76  }
77  }
const std::string & name() const
Returns the name of this object.
Definition: PRMObject_inl.h:34
virtual PRMType & type()=0
Return a reference over the gum::PRMType of this class element.
static std::string LEFT_CAST()
Enumeration of the different types of objects handled by a PRM.
Definition: PRMObject.h:79
static std::string RIGHT_CAST()
Enumeration of the different types of objects handled by a PRM.
Definition: PRMObject.h:80
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51

◆ copy()

template<typename GUM_SCALAR >
PRMAttribute< GUM_SCALAR > * gum::prm::PRMScalarAttribute< GUM_SCALAR >::copy ( Bijection< const DiscreteVariable *, const DiscreteVariable * >  bij) const
virtual

See gum::PRMClassElement::elt_type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 77 of file PRMScalarAttribute_tpl.h.

78  {
79  auto copy = new PRMScalarAttribute< GUM_SCALAR >(this->name(), this->type());
80 
81  if (!bij.existsFirst(&(type().variable()))) {
82  bij.insert(&(type().variable()), &(copy->type().variable()));
83  }
84 
85  delete copy->_cpf_;
86  copy->_cpf_ = copyPotential(bij, cpf());
87 
88  return copy;
89  }
const std::string & name() const
Returns the name of this object.
Definition: PRMObject_inl.h:34
virtual PRMType & type()
See gum::PRMClassElement::type().
virtual const Potential< GUM_SCALAR > & cpf() const
See gum::PRMClassElement::cpf().
Potential< GUM_SCALAR > * copyPotential(const Bijection< const DiscreteVariable *, const DiscreteVariable * > &bij, const Potential< GUM_SCALAR > &source)
Returns a copy of a Potential after applying a bijection over the variables in source.
Definition: utils_prm_tpl.h:29
virtual PRMAttribute< GUM_SCALAR > * copy(Bijection< const DiscreteVariable *, const DiscreteVariable * > bij) const
See gum::PRMClassElement::elt_type().

◆ copyCpf()

template<typename GUM_SCALAR >
void gum::prm::PRMScalarAttribute< GUM_SCALAR >::copyCpf ( const Bijection< const DiscreteVariable *, const DiscreteVariable * > &  bif,
const PRMAttribute< GUM_SCALAR > &  source 
)
virtual

See gum::PRMClassElement::elt_type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 92 of file PRMScalarAttribute_tpl.h.

94  {
95  delete _cpf_;
96  _cpf_ = new Potential< GUM_SCALAR >();
97 
98  for (auto var: source.cpf().variablesSequence()) {
99  _cpf_->add(*(bij.second(var)));
100  }
101 
102  Instantiation inst(*_cpf_), jnst(source.cpf());
103 
104  for (inst.setFirst(), jnst.setFirst(); !(inst.end() || jnst.end()); inst.inc(), jnst.inc()) {
105  _cpf_->set(inst, source.cpf().get(jnst));
106  }
107 
108  GUM_ASSERT(inst.end() && jnst.end());
109  GUM_ASSERT(_cpf_->contains(_type_->variable()));
110  GUM_ASSERT(!_cpf_->contains(source.type().variable()));
111  }
PRMType * _type_
The random variable type of this attribute.
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.

◆ cpf()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::prm::PRMScalarAttribute< GUM_SCALAR >::cpf ( ) const
virtual

See gum::PRMClassElement::cpf().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 136 of file PRMScalarAttribute_tpl.h.

136  {
137  return *_cpf_;
138  }
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.

◆ elt_type()

template<typename GUM_SCALAR >
INLINE PRMClassElement< GUM_SCALAR >::ClassElementType gum::prm::PRMScalarAttribute< GUM_SCALAR >::elt_type ( ) const
virtual

See gum::PRMClassElement::elt_type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 121 of file PRMScalarAttribute_tpl.h.

121  {
122  return this->prm_attribute;
123  }

◆ enum2str() [1/2]

static std::string gum::prm::PRMObject::enum2str ( prm_type  type)
inlinestaticinherited

Returns the string representation of a PRMObject.

Definition at line 83 of file PRMObject.h.

83  {
84  switch (type) {
85  case prm_type::CLASS:
86  return "PRMType::CLASS";
87 
89  return "PRMType::CLASS_ELT";
90 
91  case prm_type::TYPE:
92  return "PRMType::TYPE";
93 
94  case prm_type::SYSTEM:
95  return "PRMType::SYSTEM";
96 
97  case prm_type::INSTANCE:
98  return "PRMType::INSTANCE";
99 
101  return "PRMType::PRM_INTERFACE";
102 
103  default:
104  return "unknown";
105  }
106  }

◆ enum2str() [2/2]

template<typename GUM_SCALAR>
static std::string gum::prm::PRMClassElement< GUM_SCALAR >::enum2str ( ClassElementType  type)
inlinestaticinherited

Returns true if obj_ptr is of type PRMReferenceSlot.

Definition at line 103 of file PRMClassElement.h.

103  {
104  switch (type) {
105  case prm_attribute:
106  return "prm_attribute";
107 
108  case prm_aggregate:
109  return "prm_aggregate";
110 
111  case prm_refslot:
112  return "prm_refslot";
113 
114  case prm_slotchain:
115  return "prm_slotchain";
116 
117  case prm_parameter:
118  return "prm_parameter";
119 
120  default:
121  return "unknown";
122  }
123  }
virtual PRMType & type()=0
Return a reference over the gum::PRMType of this class element.

◆ getCastDescendant()

template<typename GUM_SCALAR >
PRMAttribute< GUM_SCALAR > * gum::prm::PRMScalarAttribute< GUM_SCALAR >::getCastDescendant ( ) const
virtual

See gum::PRMClassElement::elt_type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 158 of file PRMScalarAttribute_tpl.h.

158  {
159  PRMScalarAttribute< GUM_SCALAR >* cast = 0;
160 
161  try {
162  cast = new PRMScalarAttribute< GUM_SCALAR >(this->name(), type().superType());
163  } catch (NotFound&) {
164  GUM_ERROR(OperationNotAllowed, "this ScalarAttribute can not have cast descendant")
165  }
166 
167  cast->addParent(*this);
168  const DiscreteVariable& my_var = type().variable();
169  DiscreteVariable& cast_var = cast->type().variable();
170  Instantiation inst(cast->cpf());
171 
172  for (inst.setFirst(); !inst.end(); inst.inc()) {
173  if (type().label_map()[inst.val(my_var)] == inst.val(cast_var)) {
174  cast->cpf().set(inst, 1);
175  } else {
176  cast->cpf().set(inst, 0);
177  }
178  }
179 
180  return cast;
181  }
PRMType & superType()
Returns the super type of this type.
Definition: PRMType_inl.h:35
DiscreteVariable & variable()
Return a reference on the DiscreteVariable contained in this.
Definition: PRMType_inl.h:44
const std::string & name() const
Returns the name of this object.
Definition: PRMObject_inl.h:34
virtual PRMType & type()
See gum::PRMClassElement::type().
virtual std::string cast(const PRMType &t) const
Returns the name of the cast descendant with PRMType t of this PRMClassElement.
const std::vector< Idx > & label_map() const
Returns the vector in which the i-th element is the Idx of the super type&#39;s label for the i-th label ...
Definition: PRMType_inl.h:88
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51

◆ id()

template<typename GUM_SCALAR >
INLINE NodeId gum::prm::PRMClassElement< GUM_SCALAR >::id ( ) const
inherited

Returns the NodeId of this element in it's class DAG.

Definition at line 51 of file PRMClassElement_tpl.h.

51  {
52  return _id_;
53  }
NodeId _id_
The node&#39;s id of this element.

◆ isAggregate()

template<typename GUM_SCALAR>
static INLINE bool gum::prm::PRMClassElement< GUM_SCALAR >::isAggregate ( const PRMClassElement< GUM_SCALAR > &  elt)
inlinestaticinherited

Return true if obj is of type PRMAggregate.

Definition at line 136 of file PRMClassElement.h.

136  {
137  return elt.elt_type() == prm_aggregate;
138  }

◆ isAttribute()

template<typename GUM_SCALAR>
static INLINE bool gum::prm::PRMClassElement< GUM_SCALAR >::isAttribute ( const PRMClassElement< GUM_SCALAR > &  elt)
inlinestaticinherited

Returns true if obj_ptr is of type PRMAttribute.

Definition at line 131 of file PRMClassElement.h.

131  {
132  return elt.elt_type() == prm_attribute;
133  }

◆ isClass()

static INLINE bool gum::prm::PRMObject::isClass ( const PRMObject obj)
inlinestaticinherited

Returns true if obj_ptr is of type Class.

Definition at line 109 of file PRMObject.h.

References gum::prm::PRMObject::PRMObject().

109 { return obj.obj_type() == prm_type::CLASS; }
+ Here is the call graph for this function:

◆ isInstance()

static INLINE bool gum::prm::PRMObject::isInstance ( const PRMObject obj)
inlinestaticinherited

Returns true if obj_ptr is of type PRMInstance.

Definition at line 117 of file PRMObject.h.

References gum::prm::PRMObject::PRMObject().

117  {
118  return obj.obj_type() == prm_type::INSTANCE;
119  }
+ Here is the call graph for this function:

◆ isInterface()

static INLINE bool gum::prm::PRMObject::isInterface ( const PRMObject obj)
inlinestaticinherited

Returns true if obj_ptr is of type PRMInterface.

Definition at line 112 of file PRMObject.h.

References gum::prm::PRMObject::PRMObject().

112  {
113  return obj.obj_type() == prm_type::PRM_INTERFACE;
114  }
+ Here is the call graph for this function:

◆ isParameter()

template<typename GUM_SCALAR>
static INLINE bool gum::prm::PRMClassElement< GUM_SCALAR >::isParameter ( const PRMClassElement< GUM_SCALAR > &  elt)
inlinestaticinherited

Return true if obj is of type PRMParameter.

Definition at line 146 of file PRMClassElement.h.

146  {
147  return elt.elt_type() == prm_parameter;
148  }

◆ isReferenceSlot()

template<typename GUM_SCALAR>
static INLINE bool gum::prm::PRMClassElement< GUM_SCALAR >::isReferenceSlot ( const PRMClassElement< GUM_SCALAR > &  elt)
inlinestaticinherited

Returns true if obj_ptr is of type PRMReferenceSlot.

Definition at line 126 of file PRMClassElement.h.

126  {
127  return elt.elt_type() == prm_refslot;
128  }

◆ isSlotChain()

template<typename GUM_SCALAR>
static INLINE bool gum::prm::PRMClassElement< GUM_SCALAR >::isSlotChain ( const PRMClassElement< GUM_SCALAR > &  elt)
inlinestaticinherited

Return true if obj is of type PRMSlotChain.

Definition at line 141 of file PRMClassElement.h.

141  {
142  return elt.elt_type() == prm_slotchain;
143  }

◆ LEFT_CAST()

static std::string gum::prm::PRMObject::LEFT_CAST ( )
inlinestaticinherited

Enumeration of the different types of objects handled by a PRM.

The "all" type is used to tell that we want any kind of PRMType (useful with iterators for example). No PRMObject will ever have "all" as type.

Definition at line 79 of file PRMObject.h.

79 { return "("; }

◆ name() [1/2]

INLINE const std::string & gum::prm::PRMObject::name ( ) const
inherited

Returns the name of this object.

Definition at line 34 of file PRMObject_inl.h.

References gum::prm::ParamScopeData< GUM_SCALAR >::ParamScopeData().

34 { return _name_; }
std::string _name_
Definition: PRMObject.h:205
+ Here is the call graph for this function:

◆ name() [2/2]

INLINE void gum::prm::PRMObject::name ( const std::string &  name)
inherited

Change the name of the PRM Object.

Warning
Don't do this unless you know what you are doing !

Definition at line 38 of file PRMObject_inl.h.

References gum::prm::ParamScopeData< GUM_SCALAR >::ParamScopeData().

38 { _name_ = name; }
const std::string & name() const
Returns the name of this object.
Definition: PRMObject_inl.h:34
std::string _name_
Definition: PRMObject.h:205
+ Here is the call graph for this function:

◆ newFactory()

template<typename GUM_SCALAR >
PRMAttribute< GUM_SCALAR > * gum::prm::PRMScalarAttribute< GUM_SCALAR >::newFactory ( const PRMClass< GUM_SCALAR > &  c) const
virtual

See gum::PRMClassElement::elt_type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 70 of file PRMScalarAttribute_tpl.h.

70  {
71  auto impl = static_cast< MultiDimImplementation< GUM_SCALAR >* >(
72  this->cpf().content()->newFactory());
73  return new PRMScalarAttribute< GUM_SCALAR >(this->name(), this->type(), impl);
74  }
const std::string & name() const
Returns the name of this object.
Definition: PRMObject_inl.h:34
virtual PRMType & type()
See gum::PRMClassElement::type().
virtual const Potential< GUM_SCALAR > & cpf() const
See gum::PRMClassElement::cpf().

◆ obj_type()

template<typename GUM_SCALAR >
INLINE PRMObject::prm_type gum::prm::PRMClassElement< GUM_SCALAR >::obj_type ( ) const
virtualinherited
See also
gum::PRMObject::obj_type().

Implements gum::prm::PRMObject.

Definition at line 56 of file PRMClassElement_tpl.h.

◆ operator!=()

INLINE bool gum::prm::PRMObject::operator!= ( const PRMObject obj) const
inherited

To PRMObject are equal if they have the same name (which is unique).

Definition at line 46 of file PRMObject_inl.h.

References gum::prm::ParamScopeData< GUM_SCALAR >::ParamScopeData().

46 { return _name_ != obj.name(); }
std::string _name_
Definition: PRMObject.h:205
+ Here is the call graph for this function:

◆ operator=()

template<typename GUM_SCALAR >
PRMScalarAttribute< GUM_SCALAR > & gum::prm::PRMScalarAttribute< GUM_SCALAR >::operator= ( const PRMScalarAttribute< GUM_SCALAR > &  from)
protected

Copy operator. Don't use it.

Definition at line 115 of file PRMScalarAttribute_tpl.h.

115  {
116  GUM_ERROR(FatalError, "Illegal call to the copy operator of gum::ScalarAttribute")
117  }
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51

◆ operator==()

INLINE bool gum::prm::PRMObject::operator== ( const PRMObject obj) const
inherited

To PRMObject are equal if they have the same name (which is unique).

Definition at line 42 of file PRMObject_inl.h.

References gum::prm::ParamScopeData< GUM_SCALAR >::ParamScopeData().

42 { return _name_ == obj.name(); }
std::string _name_
Definition: PRMObject.h:205
+ Here is the call graph for this function:

◆ overload()

template<typename GUM_SCALAR>
void gum::prm::PRMAttribute< GUM_SCALAR >::overload ( PRMAttribute< GUM_SCALAR > *  source)
virtualinherited

Set this as overload of source (necessayr to preserver internal pointers for MultiDims).

Definition at line 51 of file PRMAttribute_tpl.h.

51  {
52  auto old_type = this->type_();
53  this->type_(source->type_());
54  source->type_(old_type);
55  }
virtual PRMType * type_()=0

◆ RIGHT_CAST()

static std::string gum::prm::PRMObject::RIGHT_CAST ( )
inlinestaticinherited

Enumeration of the different types of objects handled by a PRM.

The "all" type is used to tell that we want any kind of PRMType (useful with iterators for example). No PRMObject will ever have "all" as type.

Definition at line 80 of file PRMObject.h.

80 { return ")"; }

◆ safeName()

template<typename GUM_SCALAR >
INLINE const std::string & gum::prm::PRMClassElement< GUM_SCALAR >::safeName ( ) const
inherited

Returns the safe name of this PRMClassElement, if any.

This will only work if this PRMClassElement is an PRMAttribute or an PRMAggregate.

Returns
Returns the safe name of this PRMClassElement.
Exceptions
NotFound&Raised if this PRMClassElement does not have any safe name.

Definition at line 66 of file PRMClassElement_tpl.h.

66  {
67  return safeName_;
68  }
std::string safeName_
The safe name of this PRMClassElement.

◆ setAsCastDescendant()

template<typename GUM_SCALAR >
void gum::prm::PRMScalarAttribute< GUM_SCALAR >::setAsCastDescendant ( PRMAttribute< GUM_SCALAR > *  attr)
virtual

See gum::PRMClassElement::elt_type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 184 of file PRMScalarAttribute_tpl.h.

184  {
185  try {
186  type().setSuper(cast->type());
187  } catch (OperationNotAllowed&) {
188  GUM_ERROR(OperationNotAllowed, "this ScalarAttribute can not have cast descendant")
189  } catch (TypeError&) {
190  std::stringstream msg;
191  msg << type().name() << " is not a subtype of " << cast->type().name();
192  GUM_ERROR(TypeError, msg.str())
193  }
194  cast->becomeCastDescendant(type());
195  }
const std::string & name() const
Returns the name of this object.
Definition: PRMType_inl.h:65
void setSuper(PRMType &t)
Changes the PRMType of this PRMType super.
Definition: PRMType_inl.h:77
virtual PRMType & type()
See gum::PRMClassElement::type().
virtual std::string cast(const PRMType &t) const
Returns the name of the cast descendant with PRMType t of this PRMClassElement.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51

◆ setId()

template<typename GUM_SCALAR >
INLINE void gum::prm::PRMClassElement< GUM_SCALAR >::setId ( NodeId  id)
virtualinherited

Used to assign the id of this element.

Definition at line 61 of file PRMClassElement_tpl.h.

61  {
62  _id_ = id;
63  }
NodeId _id_
The node&#39;s id of this element.
NodeId id() const
Returns the NodeId of this element in it&#39;s class DAG.

◆ swap()

template<typename GUM_SCALAR >
void gum::prm::PRMScalarAttribute< GUM_SCALAR >::swap ( const PRMType old_type,
const PRMType new_type 
)
virtual

Swap old_type with new_type in the PRMClassElement cpt.

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 217 of file PRMScalarAttribute_tpl.h.

217  {
218  if (&(old_type) == _type_) {
219  GUM_ERROR(OperationNotAllowed, "Cannot replace attribute own type")
220  }
221  if (old_type->domainSize() != new_type->domainSize()) {
222  GUM_ERROR(OperationNotAllowed, "Cannot replace types with difference domain size")
223  }
224  if (!_cpf_->contains(old_type.variable())) {
225  GUM_ERROR(NotFound, "could not find variable " + old_type.name())
226  }
227 
228  auto old = _cpf_;
229 
230  _cpf_ = new Potential< GUM_SCALAR >();
231 
232  for (auto var: old->variablesSequence()) {
233  if (var != &(old_type.variable())) {
234  _cpf_->add(*var);
235  } else {
236  _cpf_->add(new_type.variable());
237  }
238  }
239 
240  Instantiation inst(_cpf_), jnst(old);
241 
242  for (inst.setFirst(), jnst.setFirst(); !(inst.end() || jnst.end()); inst.inc(), jnst.inc()) {
243  _cpf_->set(inst, old->get(jnst));
244  }
245 
246  delete old;
247 
248  GUM_ASSERT(inst.end() && jnst.end());
249  GUM_ASSERT(_cpf_->contains(_type_->variable()));
250  GUM_ASSERT(_cpf_->contains(new_type.variable()));
251  GUM_ASSERT(!_cpf_->contains(old_type.variable()));
252  }
PRMType * _type_
The random variable type of this attribute.
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51

◆ type() [1/2]

template<typename GUM_SCALAR >
INLINE PRMType & gum::prm::PRMScalarAttribute< GUM_SCALAR >::type ( )
virtual

See gum::PRMClassElement::type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 126 of file PRMScalarAttribute_tpl.h.

126  {
127  return *_type_;
128  }
PRMType * _type_
The random variable type of this attribute.

◆ type() [2/2]

template<typename GUM_SCALAR >
INLINE const PRMType & gum::prm::PRMScalarAttribute< GUM_SCALAR >::type ( ) const
virtual

See gum::PRMClassElement::type().

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 131 of file PRMScalarAttribute_tpl.h.

131  {
132  return *_type_;
133  }
PRMType * _type_
The random variable type of this attribute.

◆ type_() [1/2]

template<typename GUM_SCALAR >
PRMType * gum::prm::PRMScalarAttribute< GUM_SCALAR >::type_ ( )
protectedvirtual

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 255 of file PRMScalarAttribute_tpl.h.

255  {
256  return _type_;
257  }
PRMType * _type_
The random variable type of this attribute.

◆ type_() [2/2]

template<typename GUM_SCALAR >
void gum::prm::PRMScalarAttribute< GUM_SCALAR >::type_ ( PRMType t)
protectedvirtual

Implements gum::prm::PRMAttribute< GUM_SCALAR >.

Definition at line 260 of file PRMScalarAttribute_tpl.h.

260  {
261  if (_type_->variable().domainSize() != t->variable().domainSize()) {
262  GUM_ERROR(OperationNotAllowed, "Cannot replace types with difference domain size")
263  }
264  auto old = _cpf_;
265 
266  _cpf_ = new Potential< GUM_SCALAR >();
267 
268  for (auto var: old->variablesSequence()) {
269  if (var != &(_type_->variable())) {
270  _cpf_->add(*var);
271  } else {
272  _cpf_->add(t->variable());
273  }
274  }
275 
276  Instantiation inst(_cpf_), jnst(old);
277 
278  for (inst.setFirst(), jnst.setFirst(); !(inst.end() || jnst.end()); inst.inc(), jnst.inc()) {
279  _cpf_->set(inst, old->get(jnst));
280  }
281 
282  delete old;
283 
284  _type_ = t;
285 
286  GUM_ASSERT(_cpf_->contains(_type_->variable()));
287  GUM_ASSERT(inst.end() && jnst.end());
288  }
PRMType * _type_
The random variable type of this attribute.
virtual Size domainSize() const =0
Potential< GUM_SCALAR > * _cpf_
A pointer on the Potential of this attribute.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51

Member Data Documentation

◆ _cpf_

template<typename GUM_SCALAR >
Potential< GUM_SCALAR >* gum::prm::PRMScalarAttribute< GUM_SCALAR >::_cpf_
private

A pointer on the Potential of this attribute.

Definition at line 152 of file PRMScalarAttribute.h.

◆ _type_

template<typename GUM_SCALAR >
PRMType* gum::prm::PRMScalarAttribute< GUM_SCALAR >::_type_
private

The random variable type of this attribute.

Definition at line 149 of file PRMScalarAttribute.h.

◆ safeName_

template<typename GUM_SCALAR>
std::string gum::prm::PRMClassElement< GUM_SCALAR >::safeName_
protectedinherited

The safe name of this PRMClassElement.

Definition at line 265 of file PRMClassElement.h.


The documentation for this class was generated from the following files: