2007-03-08 04:03:40 +08:00
|
|
|
/* -*-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
|
|
|
|
{
|
2008-04-22 08:42:51 +08:00
|
|
|
uinT32 part1;
|
|
|
|
uinT32 part2;
|
2007-03-08 04:03:40 +08:00
|
|
|
} STATE;
|
|
|
|
|
2010-07-27 21:23:23 +08:00
|
|
|
/** State variable for search */
|
|
|
|
typedef int *SEARCH_STATE;
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2010-07-27 21:23:23 +08:00
|
|
|
/** State variable for search */
|
2008-04-22 08:42:51 +08:00
|
|
|
typedef uinT8 PIECES_STATE[MAX_NUM_CHUNKS + 2];
|
2007-03-08 04:03:40 +08:00
|
|
|
|
|
|
|
/*----------------------------------------------------------------------
|
|
|
|
F u n c t i o n s
|
|
|
|
----------------------------------------------------------------------*/
|
2008-04-22 08:42:51 +08:00
|
|
|
SEARCH_STATE bin_to_chunks(STATE *state, int num_joints);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2008-04-22 08:42:51 +08:00
|
|
|
void bin_to_pieces(STATE *state, int num_joints, PIECES_STATE pieces);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
|
|
|
void insert_new_chunk(register STATE *state,
|
|
|
|
register int index,
|
|
|
|
int num_joints);
|
|
|
|
|
2008-04-22 08:42:51 +08:00
|
|
|
STATE *new_state(STATE *oldstate);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2008-04-22 08:42:51 +08:00
|
|
|
int ones_in_state(STATE *state, int num_joints);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2008-04-22 08:42:51 +08:00
|
|
|
void print_state(const char *label, STATE *state, int num_joints);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2008-04-22 08:42:51 +08:00
|
|
|
void set_n_ones(STATE *state, int n);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2008-04-22 08:42:51 +08:00
|
|
|
int compare_states(STATE *true_state, STATE *this_state, int *blob_index);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2008-04-22 08:42:51 +08:00
|
|
|
extern void free_state(STATE *);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
#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
|