2007-03-08 04:03:40 +08:00
|
|
|
/******************************************************************************
|
|
|
|
** Filename: outfeat.c
|
|
|
|
** Purpose: Definition of outline-features.
|
|
|
|
** Author: Dan Johnson
|
|
|
|
** History: 11/13/90, DSJ, Created.
|
|
|
|
**
|
|
|
|
** (c) Copyright Hewlett-Packard Company, 1988.
|
|
|
|
** 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.
|
|
|
|
******************************************************************************/
|
|
|
|
/**----------------------------------------------------------------------------
|
|
|
|
Include Files and Type Defines
|
|
|
|
----------------------------------------------------------------------------**/
|
|
|
|
#include "outfeat.h"
|
|
|
|
#include "mfoutline.h"
|
|
|
|
#include "variables.h"
|
|
|
|
#include "sigmenu.h"
|
|
|
|
|
|
|
|
#include "ocrfeatures.h" //Debug
|
|
|
|
#include <stdio.h> //Debug
|
|
|
|
#include "efio.h" //Debug
|
|
|
|
//#include "christydbg.h"
|
|
|
|
|
|
|
|
/**----------------------------------------------------------------------------
|
|
|
|
Private Function Prototypes
|
|
|
|
----------------------------------------------------------------------------**/
|
|
|
|
/*
|
|
|
|
#if defined(__STDC__) || defined(__cplusplus)
|
|
|
|
# define _ARGS(s) s
|
|
|
|
#else
|
|
|
|
# define _ARGS(s) ()
|
|
|
|
#endif*/
|
|
|
|
|
|
|
|
/* /users/danj/wiseowl/src/danj/microfeatures/outfeat.c
|
|
|
|
void AddOutlineFeatureToSet
|
|
|
|
_ARGS((FPOINT *Start,
|
|
|
|
FPOINT *End,
|
|
|
|
FEATURE_SET FeatureSet));
|
|
|
|
|
|
|
|
void ConvertToOutlineFeatures
|
|
|
|
_ARGS((MFOUTLINE Outline,
|
|
|
|
FEATURE_SET FeatureSet));
|
|
|
|
|
|
|
|
void NormalizeOutlineX
|
|
|
|
_ARGS((FEATURE_SET FeatureSet));
|
|
|
|
|
|
|
|
#undef _ARGS
|
|
|
|
*/
|
|
|
|
/**----------------------------------------------------------------------------
|
|
|
|
Global Data Definitions and Declarations
|
|
|
|
----------------------------------------------------------------------------**/
|
|
|
|
/**----------------------------------------------------------------------------
|
|
|
|
Public Code
|
|
|
|
----------------------------------------------------------------------------**/
|
|
|
|
/*---------------------------------------------------------------------------*/
|
2007-05-16 09:30:20 +08:00
|
|
|
FEATURE_SET ExtractOutlineFeatures(TBLOB *Blob, LINE_STATS *LineStats) {
|
2007-03-08 04:03:40 +08:00
|
|
|
/*
|
|
|
|
** Parameters:
|
|
|
|
** Blob blob to extract pico-features from
|
|
|
|
** LineStats statistics on text row blob is in
|
|
|
|
** Globals: none
|
|
|
|
** Operation: Convert each segment in the outline to a feature
|
|
|
|
** and return the features.
|
|
|
|
** Return: Outline-features for Blob.
|
|
|
|
** Exceptions: none
|
|
|
|
** History: 11/13/90, DSJ, Created.
|
|
|
|
** 05/24/91, DSJ, Updated for either char or baseline normalize.
|
|
|
|
*/
|
|
|
|
LIST Outlines;
|
|
|
|
LIST RemainingOutlines;
|
|
|
|
MFOUTLINE Outline;
|
|
|
|
FEATURE_SET FeatureSet;
|
|
|
|
FLOAT32 XScale, YScale;
|
|
|
|
|
|
|
|
FeatureSet = NewFeatureSet (MAX_OUTLINE_FEATURES);
|
|
|
|
if (Blob == NULL)
|
|
|
|
return (FeatureSet);
|
|
|
|
|
|
|
|
Outlines = ConvertBlob (Blob);
|
|
|
|
|
2007-05-16 09:30:20 +08:00
|
|
|
NormalizeOutlines(Outlines, LineStats, &XScale, &YScale);
|
2007-03-08 04:03:40 +08:00
|
|
|
RemainingOutlines = Outlines;
|
2007-05-16 09:30:20 +08:00
|
|
|
iterate(RemainingOutlines) {
|
|
|
|
Outline = (MFOUTLINE) first_node (RemainingOutlines);
|
2007-03-08 04:03:40 +08:00
|
|
|
/*---------Debug--------------------------------------------------*
|
|
|
|
OFile = fopen ("f:/ims/debug/ofOutline.logCPP", "r");
|
|
|
|
if (OFile == NULL)
|
|
|
|
{
|
|
|
|
OFile = Efopen ("f:/ims/debug/ofOutline.logCPP", "w");
|
|
|
|
WriteOutline(OFile, Outline);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
fclose (OFile);
|
|
|
|
OFile = Efopen ("f:/ims/debug/ofOutline.logCPP", "a");
|
|
|
|
}
|
|
|
|
WriteOutline(OFile, Outline);
|
|
|
|
fclose (OFile);
|
|
|
|
*--------------------------------------------------------------------*/
|
2007-05-16 09:30:20 +08:00
|
|
|
ConvertToOutlineFeatures(Outline, FeatureSet);
|
2007-03-08 04:03:40 +08:00
|
|
|
}
|
|
|
|
if (NormMethod == baseline)
|
2007-05-16 09:30:20 +08:00
|
|
|
NormalizeOutlineX(FeatureSet);
|
2007-03-08 04:03:40 +08:00
|
|
|
/*---------Debug--------------------------------------------------*
|
|
|
|
File = fopen ("f:/ims/debug/ofFeatSet.logCPP", "r");
|
|
|
|
if (File == NULL)
|
|
|
|
{
|
|
|
|
File = Efopen ("f:/ims/debug/ofFeatSet.logCPP", "w");
|
|
|
|
WriteFeatureSet(File, FeatureSet);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
fclose (File);
|
|
|
|
File = Efopen ("f:/ims/debug/ofFeatSet.logCPP", "a");
|
|
|
|
}
|
|
|
|
WriteFeatureSet(File, FeatureSet);
|
|
|
|
fclose (File);
|
|
|
|
*--------------------------------------------------------------------*/
|
2007-05-16 09:30:20 +08:00
|
|
|
FreeOutlines(Outlines);
|
2007-03-08 04:03:40 +08:00
|
|
|
return (FeatureSet);
|
|
|
|
} /* ExtractOutlineFeatures */
|
|
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
2007-05-16 09:30:20 +08:00
|
|
|
void InitOutlineFXVars() {
|
2007-03-08 04:03:40 +08:00
|
|
|
//once contained a dummy
|
|
|
|
/*
|
|
|
|
** Parameters: none
|
|
|
|
** Globals: none
|
|
|
|
** Operation: Initialize the outline-feature extractor variables that can
|
|
|
|
** be tuned without recompiling.
|
|
|
|
** Return: none
|
|
|
|
** Exceptions: none
|
|
|
|
** History: 11/13/90, DSJ, Created.
|
|
|
|
*/
|
|
|
|
} /* InitOutlineFXVars */
|
|
|
|
|
|
|
|
|
|
|
|
/**----------------------------------------------------------------------------
|
|
|
|
Private Code
|
|
|
|
----------------------------------------------------------------------------**/
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
void AddOutlineFeatureToSet(FPOINT *Start,
|
|
|
|
FPOINT *End,
|
|
|
|
FEATURE_SET FeatureSet) {
|
|
|
|
/*
|
|
|
|
** Parameters:
|
|
|
|
** Start starting point of outline-feature
|
|
|
|
** End ending point of outline-feature
|
|
|
|
** FeatureSet set to add outline-feature to
|
|
|
|
** Globals: none
|
|
|
|
** Operation: This routine computes the midpoint between Start and
|
|
|
|
** End to obtain the x,y position of the outline-feature. It
|
|
|
|
** also computes the direction from Start to End as the
|
|
|
|
** direction of the outline-feature and the distance from
|
|
|
|
** Start to End as the length of the outline-feature.
|
|
|
|
** This feature is then
|
|
|
|
** inserted into the next feature slot in FeatureSet.
|
|
|
|
** Return: none (results are placed in FeatureSet)
|
|
|
|
** Exceptions: none
|
|
|
|
** History: 11/13/90, DSJ, Created.
|
|
|
|
*/
|
|
|
|
FEATURE Feature;
|
|
|
|
|
|
|
|
Feature = NewFeature (&OutlineFeatDesc);
|
2009-03-11 03:03:06 +08:00
|
|
|
Feature->Params[OutlineFeatDir] = NormalizedAngleFrom (Start, End, 1.0);
|
|
|
|
Feature->Params[OutlineFeatX] = AverageOf (Start->x, End->x);
|
|
|
|
Feature->Params[OutlineFeatY] = AverageOf (Start->y, End->y);
|
|
|
|
Feature->Params[OutlineFeatLength] = DistanceBetween (*Start, *End);
|
2007-05-16 09:30:20 +08:00
|
|
|
AddFeature(FeatureSet, Feature);
|
2007-03-08 04:03:40 +08:00
|
|
|
|
|
|
|
} /* AddOutlineFeatureToSet */
|
|
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
2007-05-16 09:30:20 +08:00
|
|
|
void ConvertToOutlineFeatures(MFOUTLINE Outline, FEATURE_SET FeatureSet) {
|
2007-03-08 04:03:40 +08:00
|
|
|
/*
|
|
|
|
** Parameters:
|
|
|
|
** Outline outline to extract outline-features from
|
|
|
|
** FeatureSet set of features to add outline-features to
|
|
|
|
** Globals: none
|
|
|
|
** Operation:
|
|
|
|
** This routine steps converts each section in the specified
|
|
|
|
** outline to a feature described by its x,y position, length
|
|
|
|
** and angle.
|
|
|
|
** Return: none (results are returned in FeatureSet)
|
|
|
|
** Exceptions: none
|
|
|
|
** History: 11/13/90, DSJ, Created.
|
|
|
|
** 5/24/91, DSJ, Added hidden edge capability.
|
|
|
|
*/
|
|
|
|
MFOUTLINE Next;
|
|
|
|
MFOUTLINE First;
|
|
|
|
FPOINT FeatureStart;
|
|
|
|
FPOINT FeatureEnd;
|
|
|
|
|
|
|
|
if (DegenerateOutline (Outline))
|
|
|
|
return;
|
|
|
|
|
|
|
|
First = Outline;
|
|
|
|
Next = First;
|
|
|
|
do {
|
2009-03-11 03:03:06 +08:00
|
|
|
CopyPoint (PointAt (Next)->Point, FeatureStart);
|
2007-03-08 04:03:40 +08:00
|
|
|
Next = NextPointAfter (Next);
|
|
|
|
|
|
|
|
/* note that an edge is hidden if the ending point of the edge is
|
|
|
|
marked as hidden. This situation happens because the order of
|
|
|
|
the outlines is reversed when they are converted from the old
|
|
|
|
format. In the old format, a hidden edge is marked by the
|
|
|
|
starting point for that edge. */
|
2009-03-11 03:03:06 +08:00
|
|
|
if (! (PointAt (Next)->Hidden)) {
|
|
|
|
CopyPoint (PointAt (Next)->Point, FeatureEnd);
|
2007-05-16 09:30:20 +08:00
|
|
|
AddOutlineFeatureToSet(&FeatureStart, &FeatureEnd, FeatureSet);
|
2007-03-08 04:03:40 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
while (Next != First);
|
|
|
|
} /* ConvertToOutlineFeatures */
|
|
|
|
|
|
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
2007-05-16 09:30:20 +08:00
|
|
|
void NormalizeOutlineX(FEATURE_SET FeatureSet) {
|
2007-03-08 04:03:40 +08:00
|
|
|
/*
|
|
|
|
** Parameters:
|
|
|
|
** FeatureSet outline-features to be normalized
|
|
|
|
** Globals: none
|
|
|
|
** Operation: This routine computes the weighted average x position
|
|
|
|
** over all of the outline-features in FeatureSet and then
|
|
|
|
** renormalizes the outline-features to force this average
|
|
|
|
** to be the x origin (i.e. x=0).
|
|
|
|
** Return: none (FeatureSet is changed)
|
|
|
|
** Exceptions: none
|
|
|
|
** History: 11/13/90, DSJ, Created.
|
|
|
|
*/
|
|
|
|
int i;
|
|
|
|
FEATURE Feature;
|
|
|
|
FLOAT32 Length;
|
|
|
|
FLOAT32 TotalX = 0.0;
|
|
|
|
FLOAT32 TotalWeight = 0.0;
|
|
|
|
FLOAT32 Origin;
|
|
|
|
|
2009-03-11 03:03:06 +08:00
|
|
|
if (FeatureSet->NumFeatures <= 0)
|
2007-03-08 04:03:40 +08:00
|
|
|
return;
|
|
|
|
|
2009-03-11 03:03:06 +08:00
|
|
|
for (i = 0; i < FeatureSet->NumFeatures; i++) {
|
|
|
|
Feature = FeatureSet->Features[i];
|
|
|
|
Length = Feature->Params[OutlineFeatLength];
|
|
|
|
TotalX += Feature->Params[OutlineFeatX] * Length;
|
2007-03-08 04:03:40 +08:00
|
|
|
TotalWeight += Length;
|
|
|
|
}
|
|
|
|
Origin = TotalX / TotalWeight;
|
|
|
|
|
2009-03-11 03:03:06 +08:00
|
|
|
for (i = 0; i < FeatureSet->NumFeatures; i++) {
|
|
|
|
Feature = FeatureSet->Features[i];
|
|
|
|
Feature->Params[OutlineFeatX] -= Origin;
|
2007-03-08 04:03:40 +08:00
|
|
|
}
|
|
|
|
} /* NormalizeOutlineX */
|