TgINLINE TgVOID V(tgGM_Constructor_CI)( V(PCU_TgCIRCLE) psCI0 )
{
V(tgGM_Reset_CI)( psCI0 );
}
TgINLINE TgVOID V(tgGM_Reset_CI)( V(PCU_TgCIRCLE) psCI0 )
{
psCI0->m.m.vU = V(F_SETV_ELEM)( MKL(0.0), MKL(0.0), MKL(0.0) );
psCI0->m.m.vNormal = V(F_SETV_ELEM)( MKL(0.0), MKL(0.0), MKL(0.0) );
psCI0->m.m.vV = V(F_SETV_ELEM)( MKL(0.0), MKL(0.0), MKL(0.0) );
psCI0->m.m.vOrigin = V(F_SETP_ELEM)( MKL(0.0), MKL(0.0), MKL(0.0) );
psCI0->m_fRadius = MKL(0.0);
psCI0->m_fRadiusSq = MKL(0.0);
}
TgINLINE TYPE V(tgGM_Area_CI)( V(CPCU_TgCIRCLE) psCI1 )
{
return (F(KTgF_PI)*psCI1->m_fRadiusSq);
}
TgINLINE TgVOID V(tgGM_Sweep_BA_CI)( V(PCU_TgBOXAA) psBA0, V(CPCU_TgCIRCLE) psCI1, V(CPCU_TgVEC) pvDT )
{
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( pvDT ));
V(tgGM_BA_CI)( psBA0, psCI1 );
V(tgGM_Sweep_BA)( psBA0, pvDT );
}
TgINLINE TgBOOL V(tgGM_Is_Contained_CI)( V(CPCU_TgCIRCLE) psCI1, V(CPCU_TgVEC) pvS0 )
{
V(C_TgVEC) vDS = V(F_SUB_VV)( pvS0, &psCI1->m.m.vOrigin );
const TYPE tyDS_E0 = V(F_DOT_VV)( &vDS, &psCI1->m.m.vU );
const TYPE tyDS_E1 = V(F_DOT_VV)( &vDS, &psCI1->m.m.vV );
TgGEOM_ASSERT_PARAM(V(tgGM_Is_Valid_CI)( psCI1 ) && V(F_Is_Point_Valid)( pvS0 ));
return (tyDS_E0*tyDS_E0 + tyDS_E1*tyDS_E1 < psCI1->m_fRadiusSq);
}
TgINLINE TgVOID V(tgGM_TX_CI)( V(PCU_TgCIRCLE) psCI0, M34(CPCU_TgMAT) pxM0 )
{
TgGEOM_ASSERT_PARAM(!M34(F_NaN)( pxM0 ));
psCI0->m.m.vU = V(F_TX_V_34)( pxM0, &psCI0->m.m.vU );
psCI0->m.m.vNormal = V(F_TX_V_34)( pxM0, &psCI0->m.m.vNormal );
psCI0->m.m.vV = V(F_TX_V_34)( pxM0, &psCI0->m.m.vV );
psCI0->m.m.vOrigin = V(F_TX_P_34)( pxM0, &psCI0->m.m.vOrigin );
}
TgINLINE TgVOID V(tgGM_Copy_TX_CI)( V(PCU_TgCIRCLE) psCI0, V(CPCU_TgCIRCLE) psCI1, M34(CPCU_TgMAT) pxM0 )
{
TgGEOM_ASSERT_PARAM(V(tgGM_Is_Valid_CI)( psCI1 ) && !M34(F_NaN)( pxM0 ));
psCI0->m.m.vU = V(F_TX_V_34)( pxM0, &psCI1->m.m.vU );
psCI0->m.m.vNormal = V(F_TX_V_34)( pxM0, &psCI1->m.m.vNormal );
psCI0->m.m.vV = V(F_TX_V_34)( pxM0, &psCI1->m.m.vV );
psCI0->m.m.vOrigin = V(F_TX_P_34)( pxM0, &psCI1->m.m.vOrigin );
psCI0->m_fRadius = psCI1->m_fRadius;
psCI0->m_fRadiusSq = psCI1->m_fRadiusSq;
}
TgINLINE TgVOID V(tgGM_Init_CI)(
V(PCU_TgCIRCLE) psCI0, V(CPCU_TgVEC) pvU, V(CPCU_TgVEC) pvNM, V(CPCU_TgVEC) pvV, V(CPCU_TgVEC) pvOG, const TYPE tyRadius )
{
V(tgGM_Set_U_CI)( psCI0, pvU );
V(tgGM_Set_Normal_CI)( psCI0, pvNM );
V(tgGM_Set_V_CI)( psCI0, pvV );
V(tgGM_Set_Origin_CI)( psCI0, pvOG );
V(tgGM_Set_Radius_CI)( psCI0, tyRadius );
}
TgINLINE TgVOID V(tgGM_Init_3D_CI)( V(PCU_TgCIRCLE) psCI0, M34(CPCU_TgMAT) pxM0, const TYPE tyRadius )
{
V(tgGM_Set_3D_CI)( psCI0, pxM0 );
V(tgGM_Set_Radius_CI)( psCI0, tyRadius );
}
TgINLINE TgVOID V(tgGM_Copy_CI)( V(PCU_TgCIRCLE) psCI0, V(CPCU_TgCIRCLE) psCI1 )
{
TgGEOM_ASSERT_PARAM(V(tgGM_Is_Valid_CI)( psCI1 ));
psCI0->m.m.vU = psCI1->m.m.vU;
psCI0->m.m.vNormal = psCI1->m.m.vNormal;
psCI0->m.m.vV = psCI1->m.m.vV;
psCI0->m.m.vOrigin = psCI1->m.m.vOrigin;
psCI0->m_fRadius = psCI1->m_fRadius;
psCI0->m_fRadiusSq = psCI1->m_fRadiusSq;
}
TgINLINE TgVOID V(tgGM_Set_Origin_CI)( V(PCU_TgCIRCLE) psCI0, V(CPCU_TgVEC) pvS0 )
{
TgGEOM_ASSERT_PARAM(V(F_Is_Point_Valid)( pvS0 ));
psCI0->m.m.vOrigin = *pvS0;
}
TgINLINE TgVOID V(tgGM_Set_Axes_Unit_CI)( V(PCU_TgCIRCLE) psCI0, M34(CPCU_TgMAT) pxM0 )
{
V(C_TgVEC) vS0 = psCI0->m.avData[3];
TgGEOM_ASSERT_PARAM(!M34(F_NaN)( pxM0 ));
M34(F_TR)( &psCI0->m.xData, pxM0 );
psCI0->m.avData[3] = vS0;
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( psCI0->m.avData + 0 ) && F(tgCM_NR1)( V(F_LSQ)( psCI0->m.avData + 0 ) ));
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( psCI0->m.avData + 1 ) && F(tgCM_NR1)( V(F_LSQ)( psCI0->m.avData + 1 ) ));
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( psCI0->m.avData + 2 ) && F(tgCM_NR1)( V(F_LSQ)( psCI0->m.avData + 2 ) ));
}
TgINLINE TgVOID V(tgGM_Set_U_CI)( V(PCU_TgCIRCLE) psCI0, V(CPCU_TgVEC) pvU )
{
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( pvU ) && F(tgCM_NR1)( V(F_LSQ)( pvU ) ));
psCI0->m.m.vU = *pvU;
}
TgINLINE TgVOID V(tgGM_Set_Normal_CI)( V(PCU_TgCIRCLE) psCI0, V(CPCU_TgVEC) pvN )
{
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( pvN ) && F(tgCM_NR1)( V(F_LSQ)( pvN ) ));
psCI0->m.m.vNormal = *pvN;
}
TgINLINE TgVOID V(tgGM_Set_V_CI)( V(PCU_TgCIRCLE) psCI0, V(CPCU_TgVEC) pvV )
{
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( pvV ) && F(tgCM_NR1)( V(F_LSQ)( pvV ) ));
psCI0->m.m.vV = *pvV;
}
TgINLINE TgVOID V(tgGM_Set_3D_CI)( V(PCU_TgCIRCLE) psCI0, M34(CPCU_TgMAT) pxM0 )
{
TgGEOM_ASSERT_PARAM(!M34(F_NaN)( pxM0 ));
M34(F_TR)( &psCI0->m.xData, pxM0 );
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( psCI0->m.avData + 0 ) && F(tgCM_NR1)( V(F_LSQ)( psCI0->m.avData + 0 ) ));
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( psCI0->m.avData + 1 ) && F(tgCM_NR1)( V(F_LSQ)( psCI0->m.avData + 1 ) ));
TgGEOM_ASSERT_PARAM(V(F_Is_Vector_Valid)( psCI0->m.avData + 2 ) && F(tgCM_NR1)( V(F_LSQ)( psCI0->m.avData + 2 ) ));
TgGEOM_ASSERT_PARAM(V(F_Is_Point_Valid)( psCI0->m.avData + 3 ) );
}
TgINLINE TgVOID V(tgGM_Set_Radius_CI)( V(PCU_TgCIRCLE) psCI0, const TYPE tyRadius )
{
TgGEOM_ASSERT_PARAM(!F(tgCM_NaN)( tyRadius ) && tyRadius > MKL(0.0));
psCI0->m_fRadius = tyRadius;
psCI0->m_fRadiusSq = tyRadius*tyRadius;
}
TgINLINE V(CP_TgVEC) V(tgGM_Query_Origin_CI)( V(CPCU_TgCIRCLE) psCI1 )
{
return (&psCI1->m.m.vOrigin);
}
TgINLINE V(CP_TgVEC) V(tgGM_Query_U_CI)( V(CPCU_TgCIRCLE) psCI1 )
{
return (&psCI1->m.m.vU);
}
TgINLINE V(CP_TgVEC) V(tgGM_Query_Normal_CI)( V(CPCU_TgCIRCLE) psCI1 )
{
return (&psCI1->m.m.vNormal);
}
TgINLINE V(CP_TgVEC) V(tgGM_Query_V_CI)( V(CPCU_TgCIRCLE) psCI1 )
{
return (&psCI1->m.m.vV);
}
TgINLINE TYPE V(tgGM_Query_Radius_CI)( V(CPCU_TgCIRCLE) psCI1 )
{
return (psCI1->m_fRadius);
}
TgINLINE TYPE V(tgGM_Query_Radius_Sq_CI)( V(CPCU_TgCIRCLE) psCI1 )
{
return (psCI1->m_fRadiusSq);
}