2020-09-30 16:53:55 +02:00

124 lines
4.3 KiB
C++

//
// bnts.h: Definitions for the Belief Network Troubleshooting object.
//
#ifndef _BNTS_H_
#define _BNTS_H_
// BN system inclusions
#include "enumstd.h" // Standard enumeration declarations for the BN system
// 'BNTS_EXPORT' should only be defined in the project that builds the DLL
#ifdef BNTS_EXPORT
// We're building the DLL (exporting the class)
#define BNTS_RESIDENT __declspec(dllexport)
#else
// We're using the DLL (importing the class)
#define BNTS_RESIDENT __declspec(dllimport)
#endif
// Forward declaration of internal belief network class
class MBNETDSCTS; // the encapsulated BN class
class GNODEMBND; // Discrete nodes
class LTBNPROP; // Property list
class ZSTR;
typedef const char * SZC; // simple alias
typedef char * SZ;
typedef double REAL;
////////////////////////////////////////////////////////////////////////////////////////////
//
// class BNTS: the belief network troubleshooter
//
////////////////////////////////////////////////////////////////////////////////////////////
class BNTS_RESIDENT BNTS
{
public:
// CTOR and DTOR
BNTS ();
~ BNTS ();
////////////////////////////////////////////////////////////////////
// Model-level queries and functions
////////////////////////////////////////////////////////////////////
// Load and process a DSC-based model
BOOL BReadModel ( SZC szcFn, SZC szcFnError = NULL );
// Return the number of (pre-expansion) nodes in the model
int CNode ();
// Return the recommended nodes and, optionally, their values
BOOL BGetRecommendations ();
// Return TRUE if the state of information is impossible
BOOL BImpossible ();
// Return a property item string from the network
BOOL BNetPropItemStr ( SZC szcPropType, int index );
// Return a property item number from the network
BOOL BNetPropItemReal ( SZC szcPropType, int index, double & dbl );
////////////////////////////////////////////////////////////////////
// Operations involving the "Currrent Node": call NodeSetCurrent()
////////////////////////////////////////////////////////////////////
// Set the current node for other calls
BOOL BNodeSetCurrent( int inode );
// Get the current node
int INodeCurrent ();
// Return the index of a node given its symbolic name
int INode ( SZC szcNodeSymName );
// Return the label of the current node
ESTDLBL ELblNode ();
// Return the number of discrete states in the current node
int INodeCst ();
// Set the state of a node; use -1 to uninstatiate
BOOL BNodeSet ( int istate, bool bSet = true );
// Return the state of a node
int INodeState ();
// Return the name of a node's state
void NodeStateName ( int istate );
// Return the symbolic name of the node
void NodeSymName ();
// Return the full name of the node
void NodeFullName ();
// Return a property item string from the node
BOOL BNodePropItemStr ( SZC szcPropType, int index );
// Return a property item number from the node
BOOL BNodePropItemReal ( SZC szcPropType, int index, double & dbl );
// Return the belief for a node
void NodeBelief ();
// Return true if the network is loaded and correct
bool BValidNet () const;
// Return true if the current node is set
bool BValidNode () const;
// Discard the model and all components
void Clear();
////////////////////////////////////////////////////////////////////
// Accessors to the function result information
////////////////////////////////////////////////////////////////////
SZC SzcResult () const; // String answer
const REAL * RgReal () const; // Array of reals
const int * RgInt () const; // Array of Integers
int CReal () const; // Count of reals
int CInt () const; // Count of integers
protected:
MBNETDSCTS * _pmbnet; // The T/S DSC belief network
int _inodeCurrent; // The current node
protected:
MBNETDSCTS & Mbnet();
const MBNETDSCTS & Mbnet() const;
GNODEMBND * Pgndd ();
BOOL BGetPropItemStr ( LTBNPROP & ltprop,
SZC szcPropType,
int index,
ZSTR & zstr );
BOOL BGetPropItemReal ( LTBNPROP & ltprop,
SZC szcPropType,
int index,
double & dbl );
void ClearArrays ();
void ClearString ();
ZSTR & ZstrResult ();
};
#endif // _BNTS_H_