tesseract/dict/states.h

113 lines
3.1 KiB
C
Raw Normal View History

/* -*-C-*-
********************************************************************************
*
* File: states.h (Formerly states.h)
* Description: Representations of search states
* Author: Mark Seaman, OCR Technology
* Created: Wed May 16 15:52:40 1990
* Modified: Tue May 21 16:26:21 1991 (Mark Seaman) marks@hpgrlt
* Language: C
* Package: N/A
* Status: Experimental (Do Not Distribute)
*
* (c) Copyright 1990, Hewlett-Packard Company.
** Licensed under the Apache License, Version 2.0 (the "License");
** you may not use this file except in compliance with the License.
** You may obtain a copy of the License at
** http://www.apache.org/licenses/LICENSE-2.0
** Unless required by applicable law or agreed to in writing, software
** distributed under the License is distributed on an "AS IS" BASIS,
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
** See the License for the specific language governing permissions and
** limitations under the License.
*
*********************************************************************************/
#ifndef STATES_H
#define STATES_H
/*----------------------------------------------------------------------
I n c l u d e s
----------------------------------------------------------------------*/
#include "general.h"
/*----------------------------------------------------------------------
T y p e s
----------------------------------------------------------------------*/
#define MAX_NUM_CHUNKS 64 /* Limit on pieces */
typedef struct
{
uinT32 part1;
uinT32 part2;
} STATE;
/** State variable for search */
typedef int *SEARCH_STATE;
/** State variable for search */
typedef uinT8 PIECES_STATE[MAX_NUM_CHUNKS + 2];
/*----------------------------------------------------------------------
F u n c t i o n s
----------------------------------------------------------------------*/
SEARCH_STATE bin_to_chunks(STATE *state, int num_joints);
void bin_to_pieces(STATE *state, int num_joints, PIECES_STATE pieces);
void insert_new_chunk(register STATE *state,
register int index,
int num_joints);
STATE *new_state(STATE *oldstate);
int ones_in_state(STATE *state, int num_joints);
void print_state(const char *label, STATE *state, int num_joints);
void set_n_ones(STATE *state, int n);
int compare_states(STATE *true_state, STATE *this_state, int *blob_index);
extern void free_state(STATE *);
/*
#if defined(__STDC__) || defined(__cplusplus)
# define _ARGS(s) s
#else
# define _ARGS(s) ()
#endif*/
/* states.c
void insert_new_chunk
_ARGS((STATE *state,
int index));
SEARCH_STATE bin_to_chunks
_ARGS((STATE *state,
int num_joints));
STATE *new_state
_ARGS((STATE *oldstate));
int ones_in_state
_ARGS((STATE *state,
int num_joints));
void print_state
_ARGS((char *label,
STATE *state,
int num_joints));
void set_n_ones
_ARGS((STATE *state,
int n));
int compare_states
_ARGS((
STATE *true_state,
STATE *this_state,
int* blob_index));
#undef _ARGS
*/
#endif