Back to FabImage Library website
You are here: Start » Function Reference » Computer Vision » Shape Fitting 3D » FitCircleToEdges3D

FitCircleToEdges3D
Header: | FIL.h |
---|---|
Namespace: | fil |
Module: | Vision3DStandard |
Performs a series of 1D edge detections and finds a circle that best matches the detected points.
Applications: Precise detection of a circular object or hole, whose rough location is known beforehand.
Syntax
C++
C#
void fil::FitCircleToEdges3D ( const fil::Surface& inSurface, const CircleFittingMap& inFittingMap, const EdgeScanParams3D& inEdgeScanParams, fil::Selection::Type inEdgeSelection, ftl::Optional<const fil::LocalBlindness&> inLocalBlindness, ftl::Optional<int> inMaxProfileGapWidth, float inMaxIncompleteness, fil::CircleFittingMethod::Type inFittingMethod, ftl::Optional<fil::MEstimator::Type> inOutlierSuppression, ftl::Conditional<fil::Circle3D>& outCircle, ftl::Optional<ftl::Array<ftl::Conditional<fil::SurfaceEdge1D>>&> outEdges = ftl::NIL, ftl::Optional<ftl::Conditional<fil::Profile>&> outDeviationProfile = ftl::NIL, ftl::Optional<ftl::Array<fil::Point3D>&> outInliers = ftl::NIL, ftl::Optional<ftl::Array<fil::Profile>&> outHeightProfiles = ftl::NIL, ftl::Optional<ftl::Array<fil::Profile>&> outResponseProfiles = ftl::NIL )
Parameters
Name | Type | Range | Default | Description | |
---|---|---|---|---|---|
![]() |
inSurface | const Surface& | Surface to fit the circle to | ||
![]() |
inFittingMap | const CircleFittingMap& | Input fitting map | ||
![]() |
inEdgeScanParams | const EdgeScanParams3D& | Parameters controlling the edge extraction process | ||
![]() |
inEdgeSelection | Selection::Type | SelectionBest | Selection mode of edges | |
![]() |
inLocalBlindness | Optional<const LocalBlindness&> | NIL | Defines conditions in which weaker edges can be detected in the vicinity of stronger edges | |
![]() |
inMaxProfileGapWidth | Optional<int> | 0 - ![]() |
1 | Maximal number of consecutive not existing profile points |
![]() |
inMaxIncompleteness | float | 0.0 - 0.999 | 0.1f | Maximal fraction of edge points not found |
![]() |
inFittingMethod | CircleFittingMethod::Type | AlgebraicTaubin | Method used to fit a circle | |
![]() |
inOutlierSuppression | Optional<MEstimator::Type> | NIL | Selects a method for ignoring incorrectly detected points | |
![]() |
outCircle | Conditional<Circle3D>& | Fitted circle or nothing if the fitting fails | ||
![]() |
outEdges | Optional<Array<Conditional<SurfaceEdge1D>>&> | NIL | Found edges | |
![]() |
outDeviationProfile | Optional<Conditional<Profile>&> | NIL | Profile of distances between the actual circle points and the corresponding reference circle points | |
![]() |
outInliers | Optional<Array<Point3D>&> | NIL | Points matching the fitting Circle | |
![]() |
outHeightProfiles | Optional<Array<Profile>&> | NIL | Extracted surface height profiles | |
![]() |
outResponseProfiles | Optional<Array<Profile>&> | NIL | Profiles of the edge (derivative) operator response |
Optional Outputs
The computation of following outputs can be switched off by passing value ftl::NIL
to these parameters: outEdges, outDeviationProfile, outInliers, outHeightProfiles, outResponseProfiles.
Read more about Optional Outputs.
Hardware Acceleration
This operation supports automatic parallelization for multicore and multiprocessor systems.