191 lines
3.7 KiB
C
191 lines
3.7 KiB
C
#ifndef _LTS_CART_H
|
|
#define _LTS_CART_H
|
|
|
|
#include "CommonLx.h"
|
|
|
|
#define INPUT 0
|
|
#define OUTPUT 1
|
|
#define _LEFT 2
|
|
#define _RIGHT 3
|
|
|
|
#define OUTPUT_QUES_OFFSET 20000
|
|
#define RIGHT_QUES_OFFSET 10000
|
|
#define QUESTION_CODE_RANGE 1000
|
|
|
|
#define MAX_PRODUCTS 300
|
|
|
|
#define CLR_BIT(array, n) ((array)[(n)/32] &= ~(1<<((n)%32)))
|
|
#define SET_BIT(array, n) ((array)[(n)/32] |= (1<<((n)%32)))
|
|
#define TST_BIT(array, n) ((array)[(n)/32] & (1<<((n)%32)))
|
|
|
|
#define LONGEST_STR 1024
|
|
#define NULL_SYMBOL_ID 0
|
|
#define NO_SYMBOL -1
|
|
|
|
typedef unsigned char SYMBOL;
|
|
|
|
typedef struct
|
|
{
|
|
int n_symbols;
|
|
UNALIGNED int *sym_idx;
|
|
int n_bytes;
|
|
char *storage;
|
|
} LTS_SYMTAB;
|
|
|
|
typedef struct
|
|
{
|
|
SYMBOL *pIn;
|
|
SYMBOL *pOut;
|
|
} LTS_SAMPLE;
|
|
|
|
typedef struct
|
|
{
|
|
int n_feat;
|
|
int dim;
|
|
int **feature;
|
|
} LTS_FEATURE;
|
|
|
|
typedef struct t_node
|
|
{
|
|
float entropy_dec;
|
|
int n_samples;
|
|
int *count;
|
|
char *prod;
|
|
int index;
|
|
struct t_node *yes_child;
|
|
struct t_node *no_child;
|
|
} T_NODE;
|
|
|
|
#define NO_CHILD 0
|
|
#define IS_LEAF_NODE(x) ((x)->yes == NO_CHILD)
|
|
typedef struct
|
|
{
|
|
unsigned short yes; /* index to yes child, no child will always follow */
|
|
int idx; /* index to prod (for internal) and dist (for leaf) */
|
|
} LTS_NODE;
|
|
|
|
typedef struct
|
|
{
|
|
short id;
|
|
short cnt;
|
|
} LTS_PAIR;
|
|
|
|
typedef struct
|
|
{
|
|
int c_dists;
|
|
LTS_PAIR p_pair;
|
|
} LTS_DIST;
|
|
|
|
typedef unsigned short LTS_PROD;
|
|
|
|
#define PROD_NEG 0x8000
|
|
#define MAX_PROD 0x8ffc
|
|
#define PROD_TERM 0xfffe
|
|
#define QUES_TERM 0xffff
|
|
|
|
typedef struct
|
|
{
|
|
int n_nodes;
|
|
LTS_NODE *nodes;
|
|
LTS_DIST *p_dist;
|
|
int size_dist;
|
|
LTS_PROD *p_prod;
|
|
int size_prod;
|
|
} LTS_TREE;
|
|
|
|
#define MAX_ALT_STRINGS 64
|
|
#define INC_ALT_STRINGS 32
|
|
#define MAX_OUTPUT_STRINGS 10
|
|
#define MIN_OUT_PROB 0.01f
|
|
#define DEFAULT_PRUNE 0.1f
|
|
|
|
typedef struct
|
|
{
|
|
float prob;
|
|
char pstr[SP_MAX_PRON_LENGTH];
|
|
} LTS_OUT_PRON;
|
|
|
|
typedef struct
|
|
{
|
|
int num_prons;
|
|
char word[SP_MAX_WORD_LENGTH];
|
|
LTS_OUT_PRON pron[MAX_OUTPUT_STRINGS];
|
|
} LTS_OUTPUT;
|
|
|
|
typedef struct
|
|
{
|
|
float prob;
|
|
SYMBOL psym[SP_MAX_WORD_LENGTH];
|
|
} LTS_OUT_STRING;
|
|
|
|
typedef struct outresult
|
|
{
|
|
int num_strings;
|
|
int num_allocated_strings;
|
|
LTS_OUT_STRING **out_strings;
|
|
} LTS_OUT_RESULT;
|
|
|
|
typedef struct
|
|
{
|
|
LTS_SYMTAB *symbols;
|
|
LTS_FEATURE *features;
|
|
LTS_TREE **tree;
|
|
LTS_OUTPUT out;
|
|
const char *bogus_pron;
|
|
const char **single_letter_pron;
|
|
} LTS_FOREST;
|
|
|
|
typedef struct simp_question
|
|
{
|
|
char questype;
|
|
char context;
|
|
char offset;
|
|
short feature;
|
|
} SIMPLE_QUESTION;
|
|
|
|
#define QUES_DECODE(code, questype, context, offset, feature) \
|
|
{ \
|
|
int c = code; \
|
|
if (c > OUTPUT_QUES_OFFSET) { \
|
|
questype = OUTPUT; \
|
|
c -= OUTPUT_QUES_OFFSET; \
|
|
} \
|
|
else \
|
|
questype = INPUT; \
|
|
if (c > RIGHT_QUES_OFFSET) { \
|
|
context = _RIGHT; \
|
|
c -= RIGHT_QUES_OFFSET; \
|
|
} \
|
|
else \
|
|
context = _LEFT; \
|
|
offset = c / QUESTION_CODE_RANGE; \
|
|
feature = c % QUESTION_CODE_RANGE; \
|
|
}
|
|
|
|
#define SAMPLE_GET_CONTEXT(sample, questype, context, offset, id) { \
|
|
SYMBOL *ps, i; \
|
|
if ((questype) == INPUT) \
|
|
ps = (sample)->pIn; \
|
|
else \
|
|
ps = (sample)->pOut; \
|
|
if ((context) == _LEFT) { \
|
|
for (i = 0; i < (offset) && *ps != NULL_SYMBOL_ID; i++, ps--); \
|
|
id = *ps; \
|
|
} \
|
|
else { \
|
|
for (i = 0; i < (offset) && *ps != NULL_SYMBOL_ID; i++, ps++); \
|
|
id = *ps; \
|
|
} \
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
LTS_FOREST *LtscartReadData (LCID , PBYTE);
|
|
void LtscartFreeData (LTS_FOREST *l_forest);
|
|
HRESULT LtscartGetPron(LTS_FOREST *l_forest, char *word, LTS_OUTPUT **ppLtsOutput);
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif
|