124 lines
4.3 KiB
C
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_
|