regions-new.h
来自「markov random field in matlab code」· C头文件 代码 · 共 56 行
H
56 行
// (C) 2002 Marshall Tappen, MIT AI Lab
#ifndef _reg_h
#define _reg_h
#define FLOATTYPE float
#define UP 0
#define DOWN 1
#define LEFT 2
#define RIGHT 3
#include "MaxProdBP.h"
class MaxProdBP;
class OneNodeCluster
{
public:
OneNodeCluster();
//static const int UP = 0, DOWN = 1, LEFT = 2, RIGHT = 3;
static int numStates;
FLOATTYPE *receivedMsgs[4],
*nextRoundReceivedMsgs[4],
*localEv;
// FLOATTYPE *psi[4];
void ComputeMsgRight(FLOATTYPE *msgDest, int r, int c, MaxProdBP *mrf);
void ComputeMsgUp(FLOATTYPE *msgDest, int r, int c, MaxProdBP *mrf);
void ComputeMsgLeft(FLOATTYPE *msgDest, int r, int c, MaxProdBP *mrf);
void ComputeMsgDown(FLOATTYPE *msgDest, int r, int c, MaxProdBP *mrf);
void getBelief(FLOATTYPE *beliefVec);
int msgChange(FLOATTYPE thresh);
void deliverMsgs();
};
void initOneNodeMsgMem(OneNodeCluster *nodeArray, FLOATTYPE *memChunk, const int numNodes,
const int msgChunkSize);
void computeMessagesUpDown(OneNodeCluster *nodeArray, const int numCols, const int numRows,
const int currCol, const FLOATTYPE alpha, MaxProdBP *mrf);
void computeMessagesLeftRight(OneNodeCluster *nodeArray, const int numCols, const int numRows,
const int currRow, const FLOATTYPE alpha, MaxProdBP *mrf);
void computeOneNodeMessagesPeriodic(OneNodeCluster *nodeTopArray, OneNodeCluster *nodeBotArray,
const int numCols, const FLOATTYPE alpha);
#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?