9. RANSAC_SD plugin
RANSAC_SD is a standard plugin of cloudComPy.
The availability of the plugin can be tested with the cloudComPy.isPluginRANSAC_SD() function:
isRANSAC_SD_available = cc.isPluginRANSAC_SD()
RANSAC_SD is a submodule of cloudCompy:
import cloudComPy as cc
# ...
if cc.isPluginRANSAC_SD():
    import cloudComPy.RANSAC_SD
    params = cc.RANSAC_SD.RansacParams()
    results = cc.RANSAC_SD.computeRANSAC_SD(cloud, params)
- class cloudComPy.RANSAC_SD.RansacParams
- RANSAC_SD parameters - __init__(self: _RANSAC_SD.RansacParams) None
- RANSAC_SD parameters default constructor 
 - property allowFitting
- Use Least Squares fitting on found shapes, default True. 
 - property allowSimplification
- Attempt to simplify shapes. Will attempt to convert torus, cones, spheres, cylinders into simpler shapes. For instance, cones may be simplified into cylinder, sphere or plane. Default True. 
 - property bitmapEpsilon
- Sampling resolution, should correspond to the average distance of neighbors points in data, default 0.001. 
 - property createCloudFromLeftOverPoints
- Save leftover points into a new cloud, default True. 
 - property epsilon
- Maximum distance if the samples to the ideal shape, default 0.005. 
 - getPrimEnabled(self: _RANSAC_SD.RansacParams, arg0: _RANSAC_SD.RANSAC_PRIMITIVE_TYPES) bool
- Check the type of primitive (plane, sphere, cylinder, cone, torus) enabled. By default, plane, sphere, cylinder are enabled. Types of primitive are from: - RANSAC_PRIMITIVE_TYPES.RPT_PLANE 
- RANSAC_PRIMITIVE_TYPES.RPT_SPHERE 
- RANSAC_PRIMITIVE_TYPES.RPT_CYLINDER 
- RANSAC_PRIMITIVE_TYPES.RPT_CONE 
- RANSAC_PRIMITIVE_TYPES.RPT_TORUS 
 - Parameters:
- rpt (RANSAC_PRIMITIVE_TYPES) – type of primitive 
- Returns:
- whether the type is enabled or not 
- Return type:
- bool 
 
 - property maxConeAngle_deg
- Maximum cone angle, default +infinity. 
 - property maxConeLength
- Maximum cone length, default +infinity. 
 - property maxConeRadius
- Maximum cone radius, default +infinity. 
 - property maxCylinderLength
- Maximum cylinder length, default +infinity. 
 - property maxCylinderRadius
- Maximum cylinder radius, default +infinity. 
 - property maxNormalDev_deg
- Maximum deviation from the ideal shape normal vector (in degrees), default 25. 
 - property maxSphereRadius
- Maximum sphere radius, default +infinity. 
 - property maxTorusMajorRadius
- Maximum tore major radius, default +infinity. 
 - property maxTorusMinorRadius
- Maximum tore minor radius, default +infinity. 
 - property minCylinderRadius
- Minimum cylinder radius, default -infinity. 
 - property minSphereRadius
- Minimum sphere radius, default -infinity. 
 - property minTorusMajorRadius
- Minimum tore major radius, default -infinity. 
 - property minTorusMinorRadius
- Minimum tore minor radius, default -infinity. 
 - optimizeForCloud(self: _RANSAC_SD.RansacParams, arg0: _cloudComPy.ccPointCloud) None
- Sets values for epsilon and bitmapEpsilon based on the cloud bounding box, maximum dimension. epsilon is set to 0.005 * maxDim, bitmapEpsilon is set to 0.01 * maxDim. - Parameters:
- cloud (ccPointCloud) – the cloud to be analyzed. 
 
 - property probability
- Probability that no better candidate was overlooked during the sampling, the lower the better, default 0.01 
 - property randomColor
- Set random color for each shape found, default True. 
 - setPrimEnabled(self: _RANSAC_SD.RansacParams, arg0: _RANSAC_SD.RANSAC_PRIMITIVE_TYPES, arg1: bool) None
- Define the type of primitive (plane, sphere, cylinder, cone, torus) enabled. By default, plane, sphere, cylinder are enabled. Types of primitive are from: - RANSAC_PRIMITIVE_TYPES.RPT_PLANE 
- RANSAC_PRIMITIVE_TYPES.RPT_SPHERE 
- RANSAC_PRIMITIVE_TYPES.RPT_CYLINDER 
- RANSAC_PRIMITIVE_TYPES.RPT_CONE 
- RANSAC_PRIMITIVE_TYPES.RPT_TORUS 
 - Parameters:
- rpt (RANSAC_PRIMITIVE_TYPES) – type of primitive 
- isEnabled (bool) – whether the type is enabled or not 
 
 
 - property supportPoints
- Minimal number of points required to define a primitive, default 500. 
 
- cloudComPy.RANSAC_SD.computeRANSAC_SD(arg0: _cloudComPy.ccPointCloud, arg1: _RANSAC_SD.RansacParams) tuple
- RANSAC Shape Detection is a simple interface to the automatic shape detection algorithm proposed by Ruwen Schnabel et al. of Bonn university (Efficient RANSAC for Point-Cloud Shape Detection). 
- cloudComPy.RANSAC_SD.initTrace_RANSAC_SD() None
- Debug trace must be initialized for each Python module. - Done in module init, following the value of environment variable _CCTRACE_ (“ON” if debug traces wanted)