All Downloads are FREE. Search and download functionalities are using the official Maven repository.

boofcv.factory.feature.detect.line.FactoryDetectLine Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2019, Peter Abeles. All Rights Reserved.
 *
 * This file is part of BoofCV (http://boofcv.org).
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package boofcv.factory.feature.detect.line;


import boofcv.abst.feature.detect.line.*;
import boofcv.abst.filter.binary.InputToBinary;
import boofcv.alg.feature.detect.line.HoughTransformBinary;
import boofcv.alg.feature.detect.line.HoughTransformGradient;
import boofcv.alg.filter.derivative.GImageDerivativeOps;
import boofcv.factory.filter.binary.ConfigThreshold;
import boofcv.factory.filter.binary.FactoryThresholdBinary;
import boofcv.factory.filter.binary.ThresholdType;
import boofcv.struct.image.ImageGray;

import javax.annotation.Nullable;

/**
 * Factory for creating high level implementations of {@link DetectLine} and {@Link DetectLineSegment}. For more access
 * to internal data structures see {@link FactoryDetectLineAlgs}.
 *
 * @author Peter Abeles
 */
public class FactoryDetectLine {

	/**
	 * Detects line segments inside an image using the {@link DetectLineSegmentsGridRansac} algorithm.
	 *
	 * @see DetectLineSegmentsGridRansac
	 *
	 * @param config Configuration for line detector
	 * @param imageType Type of single band input image.
	 * @return Line segment detector
	 */
	public static >
	DetectLineSegment lineRansac( @Nullable ConfigLineRansac config,
									 Class imageType ) {

		Class derivType = GImageDerivativeOps.getDerivativeType(imageType);

		return FactoryDetectLineAlgs.lineRansac(config,imageType,derivType);
	}

	/**
	 * Detects lines using a foot of norm parametrization and sub images to reduce degenerate
	 * configurations, see {@link DetectLineHoughFootSubimage} for details.
	 *
	 * @see DetectLineHoughFootSubimage
	 *
	 * @param config Configuration for line detector.  If null then default will be used.
	 * @param imageType input image type
	 * @return Line detector.
	 */
	public static >
	DetectLine houghLineFootSub(@Nullable ConfigHoughFootSubimage config , Class imageType ) {

		Class derivType = GImageDerivativeOps.getDerivativeType(imageType);

		DetectEdgeLines alg = FactoryDetectLineAlgs.houghFootSub(config,derivType);

		return new DetectEdgeLinesToLines(alg,imageType,derivType);
	}

	/**
	 * Used to find edges along the side of objects. Image gradient is found and thresholded. The pixel coordinate
	 * of each active pixel and its gradient is then used to estimate the parameter of a line.
	 * Uses {@link HoughTransformGradient} with {@link boofcv.alg.feature.detect.line.HoughParametersFootOfNorm}
	 *
	 * @param configHough Configuration for hough binary transform.
	 * @param configParam Configuration for polar parameters
	 * @param imageType type of input image
	 * @return Line detector.
	 */
	public static >
	DetectLine houghLineFoot(@Nullable ConfigHoughGradient configHough ,
								@Nullable ConfigParamFoot configParam , Class imageType )
	{
		if( configHough == null )
			configHough = new ConfigHoughGradient();

		if( configParam == null )
			configParam = new ConfigParamFoot();

		Class derivType = GImageDerivativeOps.getDerivativeType(imageType);
		HoughTransformGradient hough = FactoryDetectLineAlgs.houghLineFoot(configHough,configParam,derivType);
		HoughGradient_to_DetectLine detector = new HoughGradient_to_DetectLine(hough,imageType);
		detector.setThresholdEdge(configHough.thresholdEdge);
		return detector;
	}

	/**
	 * Used to find edges along the side of objects. Image gradient is found and thresholded. The pixel coordinate
	 * of each active pixel and its gradient is then used to estimate the parameter of a line.
	 * Uses {@link HoughTransformGradient} with {@link boofcv.alg.feature.detect.line.HoughParametersPolar}
	 *
	 * @param configHough Configuration for hough binary transform.
	 * @param configParam Configuration for polar parameters
	 * @param imageType type of input image
	 * @return Line detector.
	 */
	public static >
	DetectLine houghLinePolar( @Nullable ConfigHoughGradient configHough ,
								  @Nullable ConfigParamPolar configParam ,
								  Class imageType )
	{
		if( configHough == null )
			configHough = new ConfigHoughGradient();

		if( configParam == null )
			configParam = new ConfigParamPolar();

		Class derivType = GImageDerivativeOps.getDerivativeType(imageType);
		HoughTransformGradient hough = FactoryDetectLineAlgs.houghLinePolar(configHough,configParam,derivType);
		HoughGradient_to_DetectLine detector = new HoughGradient_to_DetectLine(hough,imageType);
		detector.setThresholdEdge(configHough.thresholdEdge);
		return detector;
	}

	/**
	 * Line detector which converts image into a binary one and assumes every pixel with a value of 1 belongs
	 * to a line. Uses {@link HoughTransformBinary} with {@link boofcv.alg.feature.detect.line.HoughParametersPolar}
	 *
	 * @param configHough Configuration for hough binary transform.
	 * @param configParam Configuration for polar parameters
	 * @param configThreshold Configuration for image thresholding
	 * @param imageType type of input image
	 * @return Line detector.
	 */
	public static >
	DetectLine houghLinePolar(@Nullable ConfigHoughBinary configHough ,
								 @Nullable ConfigParamPolar configParam ,
								 @Nullable ConfigThreshold configThreshold ,
								 Class imageType )
	{
		if( configHough == null )
			configHough = new ConfigHoughBinary();

		if( configParam == null )
			configParam = new ConfigParamPolar();

		if( configThreshold == null )
			configThreshold = ConfigThreshold.global(ThresholdType.GLOBAL_OTSU);

		HoughTransformBinary hough = FactoryDetectLineAlgs.houghLinePolar(configHough,configParam);
		InputToBinary thresholder = FactoryThresholdBinary.threshold(configThreshold,imageType);
		return new HoughBinary_to_DetectLine<>(hough,thresholder);
	}
}