Back to FabImage Library website
You are here: Start » Function Reference » Computer Vision » HandEyeCalibration Calibration » EstimateAffine3DTransform

EstimateAffine3DTransform
Header: | FIL.h |
---|---|
Namespace: | fil |
Module: | Calibration |
Computes optimal affine transformation between two 3D point sets.
Syntax
C++
C#
void fil::EstimateAffine3DTransform ( const ftl::Array<fil::Point3D>& inSrcpt, const ftl::Array<fil::Point3D>& inDstpt, float inRansacThreshold, float inConfidence, fil::Matrix& outTransform, ftl::Array<int>& outOutliers, int& outValue )
Parameters
Name | Type | Range | Default | Description | |
---|---|---|---|---|---|
![]() |
inSrcpt | const Array<Point3D>& | List of 3D points in the source coordinate system. | ||
![]() |
inDstpt | const Array<Point3D>& | List of 3D points in the destination coordinate system. | ||
![]() |
inRansacThreshold | float | 3.0f | Maximum reprojection error in the RANSAC algorithm to consider a point as an inlier. | |
![]() |
inConfidence | float | 0.0 - 1.0 | 0.99f | Confidence level, between 0 and 1, for the estimated transformation. Anything between 0.95 and 0.99 is usually good enough. Values too close to 1 can slow down the estimation significantly. Values lower than 0.8-0.9 can result in an incorrectly estimated transformation. |
![]() |
outTransform | Matrix& | Estimated affine transformation matrix. | ||
![]() |
outOutliers | Array<int>& | Output vector indicating which points are outliers (1-inlier, 0-outlier). | ||
![]() |
outValue | int& |
Errors
List of possible exceptions:
Error type | Description |
---|---|
DomainError | EstimateAffine3DTransform failed to find a solution. |
DomainError | Input arrays must have at least 4 points in EstimateAffine3DTransform. |
DomainError | Input arrays must have the same number of points in EstimateAffine3DTransform. |