/*
* Copyright (C) 2008 The Android Open Source Project
*
* 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.
*/
/* ---- includes ----------------------------------------------------------- */
#include "b_BasicEm/Functions.h"
#include "b_TensorEm/VectorMap.h"
#include "b_TensorEm/MapSequence.h"
#include "b_TensorEm/Normalizer.h"
#include "b_TensorEm/Alt.h"
#include "b_TensorEm/Mat.h"
#include "b_TensorEm/SubVecMap.h"
/* ------------------------------------------------------------------------- */
/* ========================================================================= */
/* */
/* ---- \ghd{ auxiliary functions } ---------------------------------------- */
/* */
/* ========================================================================= */
/* ------------------------------------------------------------------------- */
/* ========================================================================= */
/* */
/* ---- \ghd{ constructor / destructor } ----------------------------------- */
/* */
/* ========================================================================= */
/* ------------------------------------------------------------------------- */
void bts_VectorMap_init( struct bbs_Context* cpA,
struct bts_VectorMap* ptrA )
{
ptrA->typeE = 0;
ptrA->vpMapE = NULL;
}
/* ------------------------------------------------------------------------- */
void bts_VectorMap_exit( struct bbs_Context* cpA,
struct bts_VectorMap* ptrA )
{
ptrA->typeE = 0;
ptrA->vpMapE = NULL;
}
/* ------------------------------------------------------------------------- */
/* ========================================================================= */
/* */
/* ---- \ghd{ operators } -------------------------------------------------- */
/* */
/* ========================================================================= */
/* ------------------------------------------------------------------------- */
void bts_VectorMap_copy( struct bbs_Context* cpA,
struct bts_VectorMap* ptrA,
const struct bts_VectorMap* srcPtrA )
{
ptrA->typeE = srcPtrA->typeE;
ptrA->vpMapE = srcPtrA->vpMapE;
}
/* ------------------------------------------------------------------------- */
flag bts_VectorMap_equal( struct bbs_Context* cpA,
const struct bts_VectorMap* ptrA,
const struct bts_VectorMap* srcPtrA )
{
if( ptrA->typeE != srcPtrA->typeE ) return FALSE;
if( ptrA->vpMapE != srcPtrA->vpMapE ) return FALSE;
return TRUE;
}
/* ------------------------------------------------------------------------- */
/* ========================================================================= */
/* */
/* ---- \ghd{ query functions } -------------------------------------------- */
/* */
/* ========================================================================= */
/* ------------------------------------------------------------------------- */
/* ========================================================================= */
/* */
/* ---- \ghd{ modify functions } ------------------------------------------- */
/* */
/* ========================================================================= */
/* ------------------------------------------------------------------------- */
/* ========================================================================= */
/* */
/* ---- \ghd{ I/O } -------------------------------------------------------- */
/* */
/* ========================================================================= */
/* ------------------------------------------------------------------------- */
uint32 bts_VectorMap_memSize( struct bbs_Context* cpA,
const struct bts_VectorMap* ptrA )
{
uint32 memSizeL = 0;
memSizeL += bbs_SIZEOF16( ptrA->typeE );
return memSizeL;
}
/* ------------------------------------------------------------------------- */
uint32 bts_VectorMap_memWrite( struct bbs_Context* cpA,
const struct bts_VectorMap* ptrA,
uint16* memPtrA )
{
uint32 memSizeL = bts_VectorMap_memSize( cpA, ptrA );
memPtrA += bbs_memWrite32( &ptrA->typeE, memPtrA );
return memSizeL;
}
/* ------------------------------------------------------------------------- */
uint32 bts_VectorMap_memRead( struct bbs_Context* cpA,
struct bts_VectorMap* ptrA,
const uint16* memPtrA )
{
if( bbs_Context_error( cpA ) ) return 0;
memPtrA += bbs_memRead32( &ptrA->typeE, memPtrA );
return bts_VectorMap_memSize( cpA, ptrA );
}
/* ------------------------------------------------------------------------- */
/* ========================================================================= */
/* */
/* ---- \ghd{ exec functions } --------------------------------------------- */
/* */
/* ========================================================================= */
/* ------------------------------------------------------------------------- */
void bts_vectorMapInit( struct bbs_Context* cpA,
struct bts_VectorMap* ptrA,
enum bts_VectorMapType typeA )
{
switch( typeA )
{
case bts_VM_MAP_SEQUENCE: bts_MapSequence_init( cpA, ( struct bts_MapSequence* )ptrA ); return;
case bts_VM_NORMALIZER: bts_Normalizer_init( cpA, ( struct bts_Normalizer* )ptrA ); return;
case bts_VM_MAT: bts_Mat_init( cpA, ( struct bts_Mat* )ptrA ); return;
case bts_VM_ALT: bts_Alt_init( cpA, ( struct bts_Alt* )ptrA ); return;
case bts_VM_SUB_VEC_MAP: bts_SubVecMap_init( cpA, ( struct bts_SubVecMap* )ptrA ); return;
default: bbs_ERROR0( "bts_vectorMapInit: invalid type" );
}
}
/* ------------------------------------------------------------------------- */
void bts_vectorMapExit( struct bbs_Context* cpA,
struct bts_VectorMap* ptrA )
{
switch( ptrA->typeE )
{
case bts_VM_MAP_SEQUENCE: bts_MapSequence_exit( cpA, ( struct bts_MapSequence* )ptrA ); return;
case bts_VM_NORMALIZER: bts_Normalizer_exit( cpA, ( struct bts_Normalizer* )ptrA ); return;
case bts_VM_MAT: bts_Mat_exit( cpA, ( struct bts_Mat* )ptrA ); return;
case bts_VM_ALT: bts_Alt_exit( cpA, ( struct bts_Alt* )ptrA ); return;
case bts_VM_SUB_VEC_MAP: bts_SubVecMap_exit( cpA, ( struct bts_SubVecMap* )ptrA ); return;
default: bbs_ERROR0( "bts_vectorMapExit: invalid type" );
}
}
/* ------------------------------------------------------------------------- */
uint32 bts_vectorMapMemSize( struct bbs_Context* cpA,
const struct bts_VectorMap* ptrA )
{
switch( ptrA->typeE )
{
case bts_VM_MAP_SEQUENCE: return bts_MapSequence_memSize( cpA, ( struct bts_MapSequence* )ptrA );
case bts_VM_NORMALIZER: return bts_Normalizer_memSize( cpA, ( struct bts_Normalizer* )ptrA );
case bts_VM_MAT: return bts_Mat_memSize( cpA, ( struct bts_Mat* )ptrA );
case bts_VM_ALT: return bts_Alt_memSize( cpA, ( struct bts_Alt* )ptrA );
case bts_VM_SUB_VEC_MAP: return bts_SubVecMap_memSize( cpA, ( struct bts_SubVecMap* )ptrA );
default: bbs_ERROR0( "bts_vectorMapExit: invalid type" );
}
return 0;
}
/* ------------------------------------------------------------------------- */
uint32 bts_vectorMapMemWrite( struct bbs_Context* cpA,
const struct bts_VectorMap* ptrA, uint16* memPtrA )
{
switch( ptrA->typeE )
{
case bts_VM_MAP_SEQUENCE: return bts_MapSequence_memWrite( cpA, ( struct bts_MapSequence* )ptrA, memPtrA );
case bts_VM_NORMALIZER: return bts_Normalizer_memWrite( cpA, ( struct bts_Normalizer* )ptrA, memPtrA );
case bts_VM_MAT: return bts_Mat_memWrite( cpA, ( struct bts_Mat* )ptrA, memPtrA );
case bts_VM_ALT: return bts_Alt_memWrite( cpA, ( struct bts_Alt* )ptrA, memPtrA );
case bts_VM_SUB_VEC_MAP: return bts_SubVecMap_memWrite( cpA, ( struct bts_SubVecMap* )ptrA, memPtrA );
default: bbs_ERROR0( "bts_vectorMapMemWrite: invalid type" );
}
return 0;
}
/* ------------------------------------------------------------------------- */
uint32 bts_vectorMapMemRead( struct bbs_Context* cpA,
struct bts_VectorMap* ptrA,
const uint16* memPtrA,
struct bbs_MemTbl* mtpA )
{
switch( ptrA->typeE )
{
case bts_VM_MAP_SEQUENCE: return bts_MapSequence_memRead( cpA, ( struct bts_MapSequence* )ptrA, memPtrA, mtpA );
case bts_VM_NORMALIZER: return bts_Normalizer_memRead( cpA, ( struct bts_Normalizer* )ptrA, memPtrA, mtpA );
case bts_VM_MAT: return bts_Mat_memRead( cpA, ( struct bts_Mat* )ptrA, memPtrA, mtpA );
case bts_VM_ALT: return bts_Alt_memRead( cpA, ( struct bts_Alt* )ptrA, memPtrA, mtpA );
case bts_VM_SUB_VEC_MAP: return bts_SubVecMap_memRead( cpA, ( struct bts_SubVecMap* )ptrA, memPtrA, mtpA );
default: bbs_ERROR0( "bts_vectorMapMemRead: invalid type" );
}
return 0;
}
/* ------------------------------------------------------------------------- */
uint32 bts_vectorMapSizeOf16( struct bbs_Context* cpA, enum bts_VectorMapType typeA )
{
switch( typeA )
{
case bts_VM_MAP_SEQUENCE: return bbs_SIZEOF16( struct bts_MapSequence );
case bts_VM_NORMALIZER: return bbs_SIZEOF16( struct bts_Normalizer );
case bts_VM_MAT: return bbs_SIZEOF16( struct bts_Mat );
case bts_VM_ALT: return bbs_SIZEOF16( struct bts_Alt );
case bts_VM_SUB_VEC_MAP: return bbs_SIZEOF16( struct bts_SubVecMap );
default: bbs_ERROR0( "bts_vectorMapSizeOf16: invalid type" );
}
return 0;
}
/* ------------------------------------------------------------------------- */
/* ========================================================================= */