libsent/src/util/aptree.c File Reference

Patricia index tree for name lookup: data type = pointer. More...

#include <sent/stddefs.h>
#include <sent/ptree.h>

Go to the source code of this file.

Functions

static APATNODEnew_node ()
 Allocate a new node.
static void * aptree_search_data_r (APATNODE *node, char *str, int maxbitplace)
 Recursive function to search the data in the tree.
void * aptree_search_data (char *str, APATNODE *node)
 Search for the data whose key string matches the given string.
APATNODEaptree_make_root_node (void *data)
 Make a root node of a index tree.
static void aptree_add_entry_at (char *str, int bitloc, void *data, APATNODE **parentlink)
 Insert a new node to the existing index tree.
void aptree_add_entry (char *str, void *data, char *matchstr, APATNODE **rootnode)
 Insert a new node to the index tree.
static void aptree_remove_entry_r (APATNODE *now, APATNODE *up, APATNODE *up2, char *str, int maxbitplace, APATNODE **root)
 Recursive sunction to find and remove an entry.
void aptree_remove_entry (char *str, APATNODE **rootnode)
 Remove a node from the index tree.
void aptree_traverse_and_do (APATNODE *node, void(*callback)(void *))
 Recursive function to traverse index tree and execute the callback for all the existing data.
void free_aptree (APATNODE *node)
 Free all the sub nodes from specified node.


Detailed Description

Patricia index tree for name lookup: data type = pointer.

Author:
Akinobu LEE
Date:
Thu Feb 17 15:21:53 2005
Revision
1.1.1.1

Definition in file aptree.c.


Function Documentation

static APATNODE* new_node (  )  [static]

Allocate a new node.

Returns:
pointer to the new node.

Definition at line 35 of file aptree.c.

Referenced by aptree_add_entry_at(), aptree_make_root_node(), make_ptree(), ptree_add_entry_at(), and ptree_make_root_node().

static void* aptree_search_data_r ( APATNODE node,
char *  str,
int  maxbitplace 
) [static]

Recursive function to search the data in the tree.

Parameters:
node [in] current node.
Returns:
pointer to the found data

Definition at line 54 of file aptree.c.

Referenced by aptree_search_data().

void* aptree_search_data ( char *  str,
APATNODE node 
)

Search for the data whose key string matches the given string.

Parameters:
str [in] search key string
node [in] root node of index tree
Returns:
the exactly found data pointer, or the nearest one.

Definition at line 76 of file aptree.c.

Referenced by add_to_error(), cdset_lookup(), codebook_add(), codebook_lookup(), dens_add(), dens_lookup(), hmm_add_physical_to_logical(), hmm_add_pseudo_phones_sub(), htk_hmmdata_add(), htk_hmmdata_lookup_logical(), htk_hmmdata_lookup_physical(), make_hmm_basephone_list(), mark_word_edge(), new_str2phseq(), rdhmmlist(), regist_cdset(), remove_cdset(), state_add(), state_lookup(), trans_add(), trans_lookup(), var_add(), and var_lookup().

APATNODE* aptree_make_root_node ( void *  data  ) 

Make a root node of a index tree.

Parameters:
data [in] the first data
Returns:
the newly allocated root node.

Definition at line 97 of file aptree.c.

Referenced by add_to_error(), aptree_add_entry(), codebook_add(), dens_add(), hmm_add_physical_to_logical(), hmm_add_pseudo_phones_sub(), htk_hmmdata_add(), make_hmm_basephone_list(), rdhmmlist(), regist_cdset(), state_add(), trans_add(), and var_add().

static void aptree_add_entry_at ( char *  str,
int  bitloc,
void *  data,
APATNODE **  parentlink 
) [static]

Insert a new node to the existing index tree.

Parameters:
str [in] new key string
bitloc [in] bit branch to which this node will be added
data [in] new data pointer
parentlink [i/o] the parent node to which this node will be added

Definition at line 115 of file aptree.c.

Referenced by aptree_add_entry().

void aptree_add_entry ( char *  str,
void *  data,
char *  matchstr,
APATNODE **  rootnode 
)

Insert a new node to the index tree.

Parameters:
str [in] new key string
data [in] new data pointer
matchstr [in] the most matching data already exist in the index tree, as obtained by aptree_search_data()
rootnode [i/o] pointer to root index node

Definition at line 155 of file aptree.c.

Referenced by add_to_error(), codebook_add(), dens_add(), hmm_add_physical_to_logical(), hmm_add_pseudo_phones_sub(), htk_hmmdata_add(), make_hmm_basephone_list(), rdhmmlist(), regist_cdset(), state_add(), trans_add(), and var_add().

static void aptree_remove_entry_r ( APATNODE now,
APATNODE up,
APATNODE up2,
char *  str,
int  maxbitplace,
APATNODE **  root 
) [static]

Recursive sunction to find and remove an entry.

Parameters:
now [in] current node
up [in] parent node
up2 [in] parent parent node

Definition at line 178 of file aptree.c.

Referenced by aptree_remove_entry().

void aptree_remove_entry ( char *  str,
APATNODE **  rootnode 
)

Remove a node from the index tree.

Parameters:
str [in] existing key string (must exist in the index tree)
rootnode [i/o] pointer to root index node

Definition at line 224 of file aptree.c.

Referenced by remove_cdset().

void aptree_traverse_and_do ( APATNODE node,
void(*)(void *)  callback 
)

Recursive function to traverse index tree and execute the callback for all the existing data.

Parameters:
node [in] current node
callback [in] callback function

Definition at line 243 of file aptree.c.

Referenced by aptree_traverse_and_do(), count_all_phone(), free_cdset(), list_error(), print_all_basephone_detail(), print_all_basephone_name(), put_all_cdinfo(), test_interword_triphone(), triphone_callback_left(), and wt_tmix().

void free_aptree ( APATNODE node  ) 

Free all the sub nodes from specified node.

Parameters:
node [in] current node.

Definition at line 263 of file aptree.c.

Referenced by free_aptree(), free_cdset(), and hmminfo_free().


Generated on Tue Dec 18 16:01:40 2007 for Julius by  doxygen 1.5.4