17f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* 27f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * Copyright (C) 2008 The Android Open Source Project 37f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * 47f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 57f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * you may not use this file except in compliance with the License. 67f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * You may obtain a copy of the License at 77f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * 87f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 97f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * 107f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * Unless required by applicable law or agreed to in writing, software 117f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 127f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 137f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * See the License for the specific language governing permissions and 147f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project * limitations under the License. 157f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project */ 167f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 177f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- includes ----------------------------------------------------------- */ 187f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 197f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#include "b_TensorEm/Cluster3D.h" 207f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#include "b_BasicEm/Math.h" 217f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#include "b_BasicEm/Memory.h" 227f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#include "b_BasicEm/Functions.h" 237f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 247f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 257f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 267f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 277f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 287f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ auxiliary functions } ---------------------------------------- */ 297f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 307f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 317f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 327f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 337f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 347f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 357f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 367f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ constructor / destructor } ----------------------------------- */ 377f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 387f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 397f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 407f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 417f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 427f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bts_Cluster3D_init( struct bbs_Context* cpA, 437f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Cluster3D* ptrA ) 447f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 457f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->mspE = NULL; 467f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->vecArrE = NULL; 477f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->allocatedSizeE = 0; 487f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE = 0; 497f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->bbpE = 0; 507f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 517f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 527f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 537f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 547f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bts_Cluster3D_exit( struct bbs_Context* cpA, 557f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Cluster3D* ptrA ) 567f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 577f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_MemSeg_free( cpA, ptrA->mspE, ptrA->vecArrE ); 587f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->vecArrE = NULL; 597f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->mspE = NULL; 607f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->allocatedSizeE = 0; 617f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE = 0; 627f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->bbpE = 0; 637f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 647f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 657f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 667f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 677f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 687f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 697f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ operators } -------------------------------------------------- */ 707f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 717f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 727f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 737f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 747f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 757f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bts_Cluster3D_copy( struct bbs_Context* cpA, 767f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Cluster3D* ptrA, 777f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* srcPtrA ) 787f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 797f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#ifdef DEBUG1 807f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->allocatedSizeE < srcPtrA->sizeE ) 817f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 827f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_ERROR0( "void bts_Cluster3D_copy( struct bts_Cluster2D* ptrA, const struct bts_Cluster2D* srcPtrA ): allocated size too low in destination cluster" ); 837f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return; 847f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 857f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#endif 867f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 877f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_memcpy16( ptrA->vecArrE, srcPtrA->vecArrE, bbs_SIZEOF16( struct bts_Int16Vec3D ) * srcPtrA->sizeE ); 887f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 897f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->bbpE = srcPtrA->bbpE; 907f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE = srcPtrA->sizeE; 917f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 927f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 937f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 947f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 957f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectflag bts_Cluster3D_equal( struct bbs_Context* cpA, 967f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* ptrA, 977f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* srcPtrA ) 987f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 997f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 iL; 1007f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Int16Vec3D* src1L = ptrA->vecArrE; 1017f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Int16Vec3D* src2L = srcPtrA->vecArrE; 1027f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1037f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->sizeE != srcPtrA->sizeE ) return FALSE; 1047f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->bbpE != srcPtrA->bbpE ) return FALSE; 1057f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1067f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project for( iL = ptrA->sizeE; iL > 0; iL-- ) 1077f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 1087f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ( src1L->xE != src2L->xE ) || 1097f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ( src1L->yE != src2L->yE ) || 1107f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ( src1L->zE != src2L->zE ) ) return FALSE; 1117f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project src1L++; 1127f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project src2L++; 1137f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 1147f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1157f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return TRUE; 1167f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 1177f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1187f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 1197f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1207f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 1217f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 1227f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ query functions } -------------------------------------------- */ 1237f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 1247f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 1257f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1267f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 1277f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1287f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectstruct bts_Flt16Vec3D bts_Cluster3D_center( struct bbs_Context* cpA, 1297f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* ptrA ) 1307f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 1317f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Int16Vec3D* vecPtrL = ptrA->vecArrE; 1327f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 iL; 1337f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 xL = 0; 1347f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 yL = 0; 1357f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 zL = 0; 1367f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1377f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->sizeE == 0 ) return bts_Flt16Vec3D_create16( 0, 0, 0, 0 ); 1387f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1397f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project for( iL = ptrA->sizeE; iL > 0; iL-- ) 1407f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 1417f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project xL += vecPtrL->xE; 1427f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project yL += vecPtrL->yE; 1437f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project zL += vecPtrL->zE; 1447f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL++; 1457f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 1467f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1477f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project xL = ( ( ( xL << 1 ) / ( int32 )ptrA->sizeE ) + 1 ) >> 1; 1487f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project yL = ( ( ( yL << 1 ) / ( int32 )ptrA->sizeE ) + 1 ) >> 1; 1497f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project zL = ( ( ( zL << 1 ) / ( int32 )ptrA->sizeE ) + 1 ) >> 1; 1507f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1517f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return bts_Flt16Vec3D_create16( ( int16 )xL, ( int16 )yL, ( int16 )zL, ( int16 )ptrA->bbpE ); 1527f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 1537f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1547f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 1557f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1567f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectstruct bts_Int16Rect bts_Cluster3D_boundingBox( struct bbs_Context* cpA, 1577f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* ptrA ) 1587f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 1597f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Int16Vec3D* vecPtrL = ptrA->vecArrE; 1607f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 iL; 1617f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 xMinL = 65536; /*( 1 << 16 )*/ 1627f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 yMinL = 65536; /*( 1 << 16 )*/ 1637f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 xMaxL = 0; 1647f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 yMaxL = 0; 1657f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1667f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->sizeE == 0 ) return bts_Int16Rect_create( 0, 0, 0, 0 ); 1677f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1687f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project for( iL = ptrA->sizeE; iL > 0; iL-- ) 1697f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 1707f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project xMinL = bbs_min( xMinL, vecPtrL->xE ); 1717f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project yMinL = bbs_min( yMinL, vecPtrL->yE ); 1727f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project xMaxL = bbs_max( xMaxL, vecPtrL->xE ); 1737f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project yMaxL = bbs_max( yMaxL, vecPtrL->yE ); 1747f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL++; 1757f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 1767f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1777f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return bts_Int16Rect_create( ( int16 )xMinL, ( int16 )yMinL, ( int16 )xMaxL, ( int16 )yMaxL ); 1787f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 1797f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1807f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 1817f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 1827f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectint32 bts_Cluster3D_int32X( struct bbs_Context* cpA, 1837f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* ptrA, 1847f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 indexA, int32 bbpA ) 1857f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 1867f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 shiftL = bbpA - ptrA->bbpE; 1877f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#ifdef DEBUG2 1887f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( indexA >= ptrA->sizeE ) 1897f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 1907f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_ERROR2( "int32 bts_Cluster2D_int32X( .... )\n" 1917f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project "indexA = %i is out of range [0,%i]", 1927f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project indexA, 1937f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE - 1 ); 1947f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return 0; 1957f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 1967f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#endif 1977f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( shiftL >= 0 ) 1987f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 1997f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return ( int32 ) ptrA->vecArrE[ indexA ].xE << shiftL; 2007f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2017f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project else 2027f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2037f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return ( ( ( int32 ) ptrA->vecArrE[ indexA ].xE >> ( -shiftL - 1 ) ) + 1 ) >> 1; 2047f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2057f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 2067f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2077f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 2087f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2097f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectint32 bts_Cluster3D_int32Y( struct bbs_Context* cpA, 2107f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* ptrA, 2117f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 indexA, 2127f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 bbpA ) 2137f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 2147f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 shiftL = bbpA - ptrA->bbpE; 2157f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#ifdef DEBUG2 2167f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( indexA >= ptrA->sizeE ) 2177f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2187f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_ERROR2( "int32 bts_Cluster2D_int32Y( .... )\n" 2197f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project "indexA = %i is out of range [0,%i]", 2207f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project indexA, 2217f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE - 1 ); 2227f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return 0; 2237f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2247f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#endif 2257f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( shiftL >= 0 ) 2267f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2277f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return ( int32 ) ptrA->vecArrE[ indexA ].yE << shiftL; 2287f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2297f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project else 2307f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2317f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return ( ( ( int32 ) ptrA->vecArrE[ indexA ].yE >> ( -shiftL - 1 ) ) + 1 ) >> 1; 2327f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2337f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 2347f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2357f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 2367f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2377f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectint32 bts_Cluster3D_int32Z( struct bbs_Context* cpA, 2387f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* ptrA, 2397f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 indexA, 2407f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 bbpA ) 2417f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 2427f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 shiftL = bbpA - ptrA->bbpE; 2437f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#ifdef DEBUG2 2447f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( indexA >= ptrA->sizeE ) 2457f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2467f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_ERROR2( "int32 bts_Cluster2D_int32Z( .... )\n" 2477f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project "indexA = %i is out of range [0,%i]", 2487f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project indexA, 2497f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE - 1 ); 2507f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return 0; 2517f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2527f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project#endif 2537f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( shiftL >= 0 ) 2547f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2557f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return ( int32 ) ptrA->vecArrE[ indexA ].zE << shiftL; 2567f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2577f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project else 2587f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2597f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return ( ( ( int32 ) ptrA->vecArrE[ indexA ].zE >> ( -shiftL - 1 ) ) + 1 ) >> 1; 2607f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2617f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 2627f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2637f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 2647f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2657f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 2667f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 2677f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ modify functions } ------------------------------------------- */ 2687f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 2697f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 2707f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2717f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 2727f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2737f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bts_Cluster3D_create( struct bbs_Context* cpA, 2747f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Cluster3D* ptrA, 2757f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 sizeA, 2767f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bbs_MemSeg* mspA ) 2777f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 2787f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( bbs_Context_error( cpA ) ) return; 2797f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->mspE == NULL ) 2807f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2817f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE = 0; 2827f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->allocatedSizeE = 0; 2837f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->vecArrE = NULL; 2847f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2857f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2867f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->sizeE == sizeA ) return; 2877f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2887f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->vecArrE != 0 ) 2897f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 2907f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_ERROR0( "void bts_Cluster3D_create( const struct bts_Cluster3D*, uint32 ):\n" 2917f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project "object has already been created and cannot be resized." ); 2927f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return; 2937f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 2947f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 2957f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->vecArrE = bbs_MemSeg_alloc( cpA, mspA, sizeA * bbs_SIZEOF16( struct bts_Int16Vec3D ) ); 2967f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( bbs_Context_error( cpA ) ) return; 2977f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE = sizeA; 2987f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->allocatedSizeE = sizeA; 2997f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( !mspA->sharedE ) ptrA->mspE = mspA; 3007f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 3017f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3027f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 3037f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3047f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bts_Cluster3D_size( struct bbs_Context* cpA, 3057f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Cluster3D* ptrA, 3067f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 sizeA ) 3077f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 3087f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->allocatedSizeE < sizeA ) 3097f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 3107f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_ERROR2( "void bts_Cluster3D_size( struct bts_Cluster3D* ptrA, uint32 sizeA ):\n" 3117f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project "Allocated size (%i) of cluster is smaller than requested size (%i).", 3127f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->allocatedSizeE, 3137f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project sizeA ); 3147f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return; 3157f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 3167f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE = sizeA; 3177f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 3187f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3197f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 3207f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3217f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectvoid bts_Cluster3D_transform( struct bbs_Context* cpA, 3227f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Cluster3D* ptrA, 3237f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Flt16Alt3D altA ) 3247f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 3257f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Int16Vec3D* vecPtrL = ptrA->vecArrE; 3267f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 iL; 3277f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3287f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 x0L = altA.vecE.xE; 3297f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 y0L = altA.vecE.yE; 3307f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 z0L = altA.vecE.zE; 3317f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3327f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 shiftL = altA.matE.bbpE + ptrA->bbpE - altA.vecE.bbpE; 3337f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3347f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( shiftL < 0 ) 3357f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 3367f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project x0L = ( ( x0L >> ( -shiftL - 1 ) ) + 1 ) >> 1; 3377f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project y0L = ( ( y0L >> ( -shiftL - 1 ) ) + 1 ) >> 1; 3387f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project z0L = ( ( z0L >> ( -shiftL - 1 ) ) + 1 ) >> 1; 3397f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 3407f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project else 3417f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 3427f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project x0L <<= shiftL; 3437f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project y0L <<= shiftL; 3447f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project z0L <<= shiftL; 3457f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 3467f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3477f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( altA.matE.bbpE > 0 ) 3487f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 3497f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project x0L += (int32)1 << ( altA.matE.bbpE - 1 ); 3507f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project y0L += (int32)1 << ( altA.matE.bbpE - 1 ); 3517f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project z0L += (int32)1 << ( altA.matE.bbpE - 1 ); 3527f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 3537f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3547f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project for( iL = ptrA->sizeE; iL > 0; iL-- ) 3557f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 3567f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 xL = vecPtrL->xE; 3577f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 yL = vecPtrL->yE; 3587f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project int32 zL = vecPtrL->zE; 3597f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL->xE = ( x0L + xL * altA.matE.xxE + yL * altA.matE.xyE + zL * altA.matE.xzE ) >> altA.matE.bbpE; 3607f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL->yE = ( y0L + xL * altA.matE.yxE + yL * altA.matE.yyE + zL * altA.matE.yzE ) >> altA.matE.bbpE; 3617f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL->zE = ( z0L + xL * altA.matE.zxE + yL * altA.matE.zyE + zL * altA.matE.zzE ) >> altA.matE.bbpE; 3627f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL++; 3637f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 3647f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 3657f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3667f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 3677f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3687f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectstruct bts_Flt16Vec3D bts_Cluster3D_centerFree( struct bbs_Context* cpA, 3697f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Cluster3D* ptrA ) 3707f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 3717f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Flt16Vec3D centerL = bts_Cluster3D_center( cpA, ptrA ); 3727f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Int16Vec3D* vecPtrL = ptrA->vecArrE; 3737f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 iL; 3747f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3757f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project for( iL = ptrA->sizeE; iL > 0; iL-- ) 3767f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 3777f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL->xE -= centerL.xE; 3787f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL->yE -= centerL.yE; 3797f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL->zE -= centerL.zE; 3807f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project vecPtrL++; 3817f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 3827f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3837f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return centerL; 3847f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 3857f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3867f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 3877f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3887f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 3897f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 3907f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ I/O } -------------------------------------------------------- */ 3917f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 3927f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 3937f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3947f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 3957f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 3967f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectuint32 bts_Cluster3D_memSize( struct bbs_Context* cpA, 3977f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D *ptrA ) 3987f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 3997f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return bbs_SIZEOF16( uint32 ) 4007f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project + bbs_SIZEOF16( uint32 ) /* version */ 4017f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project + bbs_SIZEOF16( ptrA->sizeE ) 4027f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project + bbs_SIZEOF16( ptrA->bbpE ) 4037f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project + bbs_SIZEOF16( struct bts_Int16Vec3D ) * ptrA->sizeE; 4047f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 4057f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4067f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 4077f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4087f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectuint32 bts_Cluster3D_memWrite( struct bbs_Context* cpA, 4097f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const struct bts_Cluster3D* ptrA, 4107f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint16* memPtrA ) 4117f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 4127f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 memSizeL = bts_Cluster3D_memSize( cpA, ptrA ); 4137f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memWrite32( &memSizeL, memPtrA ); 4147f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memWriteUInt32( bts_CLUSTER3D_VERSION, memPtrA ); 4157f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memWrite32( &ptrA->sizeE, memPtrA ); 4167f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memWrite32( &ptrA->bbpE, memPtrA ); 4177f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memWrite16Arr( cpA, ptrA->vecArrE, 4187f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE * bbs_SIZEOF16( struct bts_Int16Vec3D ), 4197f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA ); 4207f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return memSizeL; 4217f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 4227f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4237f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 4247f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4257f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Projectuint32 bts_Cluster3D_memRead( struct bbs_Context* cpA, 4267f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bts_Cluster3D* ptrA, 4277f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project const uint16* memPtrA, 4287f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project struct bbs_MemSeg* mspA ) 4297f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project{ 4307f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 memSizeL; 4317f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 sizeL; 4327f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project uint32 versionL; 4337f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( bbs_Context_error( cpA ) ) return 0; 4347f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memRead32( &memSizeL, memPtrA ); 4357f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memReadVersion32( cpA, &versionL, bts_CLUSTER3D_VERSION, memPtrA ); 4367f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memRead32( &sizeL, memPtrA ); 4377f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memRead32( &ptrA->bbpE, memPtrA ); 4387f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4397f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( ptrA->allocatedSizeE < sizeL ) 4407f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 4417f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bts_Cluster3D_create( cpA, ptrA, sizeL, mspA ); 4427f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 4437f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project else 4447f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 4457f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bts_Cluster3D_size( cpA, ptrA, sizeL ); 4467f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 4477f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4487f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4497f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_memcpy16( ptrA->vecArrE, memPtrA, bbs_SIZEOF16( struct bts_Int16Vec3D ) * ptrA->sizeE ); 4507f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA += bbs_memRead16Arr( cpA, ptrA->vecArrE, 4517f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project ptrA->sizeE * bbs_SIZEOF16( struct bts_Int16Vec3D ), 4527f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project memPtrA ); 4537f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4547f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project if( memSizeL != bts_Cluster3D_memSize( cpA, ptrA ) ) 4557f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project { 4567f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project bbs_ERR0( bbs_ERR_CORRUPT_DATA, "uint32 bts_Cluster3D_memRead( const struct bts_Cluster3D* ptrA, const void* memPtrA ):\n" 4577f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project "size mismatch" ); 4587f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return 0; 4597f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project } 4607f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project return memSizeL; 4617f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project} 4627f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4637f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 4647f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4657f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 4667f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 4677f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ---- \ghd{ exec functions } --------------------------------------------- */ 4687f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* */ 4697f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 4707f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4717f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ------------------------------------------------------------------------- */ 4727f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 4737f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project/* ========================================================================= */ 4747f81d9b6fa7f2ec161b682622db577a28c90b49fThe Android Open Source Project 475