Исправление функции, которая находит трёхмерных поворот между двумя парами векторов
This commit is contained in:
parent
57280ac3f3
commit
2ce4b64ca3
7 changed files with 705 additions and 467 deletions
|
|
@ -113,28 +113,28 @@ inline void bgc_fp64_dual_quaternion_subtract(BGC_FP64_DualQuaternion* differenc
|
|||
|
||||
// ================== Multiply ================== //
|
||||
|
||||
inline void bgc_fp32_dual_quaternion_multiply(BGC_FP32_DualQuaternion* product, const BGC_FP32_DualQuaternion* multiplicand, const float multipier)
|
||||
inline void bgc_fp32_dual_quaternion_multiply_by_number(BGC_FP32_DualQuaternion* product, const BGC_FP32_DualQuaternion* multiplicand, const float multipier)
|
||||
{
|
||||
bgc_fp32_quaternion_multiply(&product->real, &multiplicand->real, multipier);
|
||||
bgc_fp32_quaternion_multiply(&product->dual, &multiplicand->dual, multipier);
|
||||
bgc_fp32_quaternion_multiply_by_number(&product->real, &multiplicand->real, multipier);
|
||||
bgc_fp32_quaternion_multiply_by_number(&product->dual, &multiplicand->dual, multipier);
|
||||
}
|
||||
|
||||
inline void bgc_fp64_dual_quaternion_multiply(BGC_FP64_DualQuaternion* product, const BGC_FP64_DualQuaternion* multiplicand, const double multipier)
|
||||
inline void bgc_fp64_dual_quaternion_multiply_by_number(BGC_FP64_DualQuaternion* product, const BGC_FP64_DualQuaternion* multiplicand, const double multipier)
|
||||
{
|
||||
bgc_fp64_quaternion_multiply(&product->real, &multiplicand->real, multipier);
|
||||
bgc_fp64_quaternion_multiply(&product->dual, &multiplicand->dual, multipier);
|
||||
bgc_fp64_quaternion_multiply_by_number(&product->real, &multiplicand->real, multipier);
|
||||
bgc_fp64_quaternion_multiply_by_number(&product->dual, &multiplicand->dual, multipier);
|
||||
}
|
||||
|
||||
// =================== Divide =================== //
|
||||
|
||||
inline void bgc_fp32_dual_quaternion_divide(BGC_FP32_DualQuaternion* quotient, const BGC_FP32_DualQuaternion* divident, const float divisor)
|
||||
inline void bgc_fp32_dual_quaternion_divide_by_number(BGC_FP32_DualQuaternion* quotient, const BGC_FP32_DualQuaternion* divident, const float divisor)
|
||||
{
|
||||
bgc_fp32_dual_quaternion_multiply(quotient, divident, 1.0f / divisor);
|
||||
bgc_fp32_dual_quaternion_multiply_by_number(quotient, divident, 1.0f / divisor);
|
||||
}
|
||||
|
||||
inline void bgc_fp64_dual_quaternion_divide(BGC_FP64_DualQuaternion* quotient, const BGC_FP64_DualQuaternion* divident, const double divisor)
|
||||
inline void bgc_fp64_dual_quaternion_divide_by_number(BGC_FP64_DualQuaternion* quotient, const BGC_FP64_DualQuaternion* divident, const double divisor)
|
||||
{
|
||||
bgc_fp64_dual_quaternion_multiply(quotient, divident, 1.0 / divisor);
|
||||
bgc_fp64_dual_quaternion_multiply_by_number(quotient, divident, 1.0 / divisor);
|
||||
}
|
||||
|
||||
// ================ Mean of Two ================= //
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue