2007-03-08 04:03:40 +08:00
|
|
|
/******************************************************************************
|
2016-11-08 02:46:33 +08:00
|
|
|
** Filename: mf.c
|
|
|
|
** Purpose: Micro-feature interface to flexible feature extractor.
|
|
|
|
** Author: Dan Johnson
|
|
|
|
** History: Thu May 24 09:08:38 1990, DSJ, Created.
|
2007-03-08 04:03:40 +08:00
|
|
|
**
|
2016-11-08 02:46:33 +08:00
|
|
|
** (c) Copyright Hewlett-Packard Company, 1988.
|
2007-03-08 04:03:40 +08:00
|
|
|
** 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.
|
|
|
|
******************************************************************************/
|
2014-09-13 04:41:19 +08:00
|
|
|
/*----------------------------------------------------------------------------
|
2007-03-08 04:03:40 +08:00
|
|
|
Include Files and Type Defines
|
2014-09-13 04:41:19 +08:00
|
|
|
----------------------------------------------------------------------------*/
|
2007-03-08 04:03:40 +08:00
|
|
|
#include "mf.h"
|
2010-11-24 02:34:14 +08:00
|
|
|
|
|
|
|
#include "featdefs.h"
|
|
|
|
#include "mfdefs.h"
|
2007-03-08 04:03:40 +08:00
|
|
|
#include "mfx.h"
|
2010-11-24 02:34:14 +08:00
|
|
|
|
2007-03-08 04:03:40 +08:00
|
|
|
#include <math.h>
|
|
|
|
|
2015-07-21 01:53:53 +08:00
|
|
|
/*----------------------------------------------------------------------------
|
2007-03-08 04:03:40 +08:00
|
|
|
Global Data Definitions and Declarations
|
2014-09-13 04:41:19 +08:00
|
|
|
----------------------------------------------------------------------------*/
|
|
|
|
/*----------------------------------------------------------------------------
|
2007-03-08 04:03:40 +08:00
|
|
|
Private Code
|
2014-09-13 04:41:19 +08:00
|
|
|
----------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
|
|
* Call the old micro-feature extractor and then copy
|
|
|
|
* the features into the new format. Then deallocate the
|
|
|
|
* old micro-features.
|
2016-11-08 02:46:33 +08:00
|
|
|
* @param Blob blob to extract micro-features from
|
2014-09-13 04:41:19 +08:00
|
|
|
* @param cn_denorm control parameter to feature extractor.
|
|
|
|
* @return Micro-features for Blob.
|
|
|
|
* @note Exceptions: none
|
|
|
|
* @note History: Wed May 23 18:06:38 1990, DSJ, Created.
|
2007-03-08 04:03:40 +08:00
|
|
|
*/
|
2015-07-21 05:42:58 +08:00
|
|
|
FEATURE_SET ExtractMicros(TBLOB* Blob, const DENORM& cn_denorm) {
|
2007-03-08 04:03:40 +08:00
|
|
|
int NumFeatures;
|
|
|
|
MICROFEATURES Features, OldFeatures;
|
|
|
|
FEATURE_SET FeatureSet;
|
|
|
|
FEATURE Feature;
|
|
|
|
MICROFEATURE OldFeature;
|
|
|
|
|
2015-05-13 06:22:34 +08:00
|
|
|
OldFeatures = BlobMicroFeatures(Blob, cn_denorm);
|
2016-12-13 00:21:24 +08:00
|
|
|
if (OldFeatures == nullptr)
|
|
|
|
return nullptr;
|
2007-03-08 04:03:40 +08:00
|
|
|
NumFeatures = count (OldFeatures);
|
|
|
|
FeatureSet = NewFeatureSet (NumFeatures);
|
|
|
|
|
|
|
|
Features = OldFeatures;
|
|
|
|
iterate(Features) {
|
2007-05-16 09:40:09 +08:00
|
|
|
OldFeature = (MICROFEATURE) first_node (Features);
|
2007-03-08 04:03:40 +08:00
|
|
|
Feature = NewFeature (&MicroFeatureDesc);
|
2009-03-11 03:03:06 +08:00
|
|
|
Feature->Params[MFDirection] = OldFeature[ORIENTATION];
|
|
|
|
Feature->Params[MFXPosition] = OldFeature[XPOSITION];
|
|
|
|
Feature->Params[MFYPosition] = OldFeature[YPOSITION];
|
|
|
|
Feature->Params[MFLength] = OldFeature[MFLENGTH];
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2010-11-24 02:34:14 +08:00
|
|
|
// Bulge features are deprecated and should not be used. Set to 0.
|
2009-03-11 03:03:06 +08:00
|
|
|
Feature->Params[MFBulge1] = 0.0f;
|
|
|
|
Feature->Params[MFBulge2] = 0.0f;
|
2010-11-24 02:34:14 +08:00
|
|
|
|
2012-03-03 01:31:24 +08:00
|
|
|
#ifndef _WIN32
|
2009-07-11 10:17:36 +08:00
|
|
|
// Assert that feature parameters are well defined.
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < Feature->Type->NumParams; i++) {
|
2012-10-09 09:28:37 +08:00
|
|
|
ASSERT_HOST(!isnan(Feature->Params[i]));
|
2009-07-11 10:17:36 +08:00
|
|
|
}
|
|
|
|
#endif
|
2010-11-24 02:34:14 +08:00
|
|
|
|
2007-03-08 04:03:40 +08:00
|
|
|
AddFeature(FeatureSet, Feature);
|
|
|
|
}
|
|
|
|
FreeMicroFeatures(OldFeatures);
|
2012-10-09 09:28:37 +08:00
|
|
|
return FeatureSet;
|
2007-03-08 04:03:40 +08:00
|
|
|
} /* ExtractMicros */
|