/usr/include/JAGS/graph/MixtureNode.h is in jags 4.1.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 | #ifndef MIXTURE_NODE_H_
#define MIXTURE_NODE_H_
#include <graph/DeterministicNode.h>
#include <map>
#include <vector>
namespace jags {
class Node;
class MixTab;
/**
* A MixMap is an STL map that associates an index value (a vector
* of unsigned integers) with a node.
*/
typedef std::map<std::vector<int>, Node const *> MixMap;
/**
* @short Node for mixture models.
*
* A mixture node copies its value from one of several parents, based
* on the current value of a vector of index nodes.
*
* In the BUGS language, mixture nodes are represented using nested
* indexing. For example, in the deterministic relation
*
* <pre>y[i] <- x[ind[i]]</pre>
*
* y[i] is a mixture node if ind[i] is unobserved. If the possible
* values of ind[i] are 1...M, then the parents of y[i] are ind[i],
* x[1], ... x[M].
*/
class MixtureNode : public DeterministicNode {
MixTab const *_table;
unsigned int _Nindex;
bool _discrete;
std::vector<Node const *> _active_parents;
void updateActive(unsigned int chain);
public:
/**
* Constructs a MixtureNode.
*
* @param index Vector of index nodes. These must be discrete-valued,
* scalar, and unobserved.
*
* @param nchain Number of chains
*
* @param map a MixMap object which associates each possible value
* of the index nodes with a single parent.
*/
MixtureNode(std::vector<Node const *> const &index,
unsigned int nchain, MixMap const &mixmap);
~MixtureNode();
/**
* Copies the value of the active parent
*/
void deterministicSample(unsigned int chain);
/**
* Returns a pointer to the currently active parent (i.e. the one
* determined by the current index values) in the given chain.
*/
Node const *activeParent(unsigned int chain) const;
/**
* Returns the number of index nodes.
*/
unsigned int index_size() const;
/**
* Returns a pointer to the MixTab
*/
MixTab const *mixTab() const;
/**
* A MixtureNode is discrete valued if all of its possible
* parents are discrete
*/
bool isDiscreteValued() const;
/**
* A MixtureNode preserves all closed classes if none of its index
* nodes are descendants of X. It is never fixed
*/
bool isClosed(std::set<Node const *> const &ancestors,
ClosedFuncClass fc, bool fixed) const;
/**
* This function always returns true. It ignores possible errors
* in the index nodes. This is because the deterministicSample
* member function already checks that the index value is valid
* and will throw an runtime error if it is not. Repeating these
* calculations in the checkParentValues function would therefore
* be redundant.
*/
bool checkParentValues(unsigned int chain) const;
/**
* Creates a name for the mixture node of the form.
*
* <pre>mixture(index=[p,q], parents=X[1,1,4]...X[2,3,4])</pre>
*
* Only the first and last parent nodes are listed to save space.
*
* Exceptionally, the name of a mixture node is not a reconstruction
* of its BUGS-language definition.
*/
std::string deparse(std::vector<std::string> const &parents) const;
//DeterministicNode *clone(std::vector<Node const *> const &parents) const;
};
bool isMixture(Node const *);
MixtureNode const * asMixture(Node const *);
} /* namespace jags */
#endif /* MIXTURE_NODE_H_ */
|