Добавление position3 и aффинного преобразования

This commit is contained in:
andrey 2026-01-26 20:00:12 +07:00
parent fd7c6c91cd
commit d8347656c7
7 changed files with 375 additions and 0 deletions

13
basic-geometry/affine3.c Normal file
View file

@ -0,0 +1,13 @@
#include "affine3.h"
extern inline void bgc_affine3_reset_fp32(BgcAffine3FP32 * affine);
extern inline void bgc_affine3_reset_fp64(BgcAffine3FP64 * affine);
extern inline void bgc_affine3_make_fp32(const BgcMatrix3x3FP32 * distortion, const BgcVector3FP32 * shift, BgcAffine3FP32 * affine);
extern inline void bgc_affine3_make_fp64(const BgcMatrix3x3FP64 * distortion, const BgcVector3FP64 * shift, BgcAffine3FP64 * affine);
extern inline void bgc_affine3_transform_point_fp32(const BgcAffine3FP32 * affine, const BgcVector3FP32 * initial_point, BgcVector3FP32 * transformed_point);
extern inline void bgc_affine3_transform_point_fp64(const BgcAffine3FP64 * affine, const BgcVector3FP64 * initial_point, BgcVector3FP64 * transformed_point);
extern inline void bgc_affine3_transform_vector_fp32(const BgcAffine3FP32 * affine, const BgcVector3FP32 * initial_vector, BgcVector3FP32 * transformed_vector);
extern inline void bgc_affine3_transform_vector_fp64(const BgcAffine3FP64 * affine, const BgcVector3FP64 * initial_vector, BgcVector3FP64 * transformed_vector);