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

boofcv.factory.feature.orientation.FactoryOrientationAlgs Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2017, 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.orientation;

import boofcv.abst.feature.orientation.ConfigAverageIntegral;
import boofcv.abst.feature.orientation.ConfigSiftOrientation;
import boofcv.abst.feature.orientation.ConfigSlidingIntegral;
import boofcv.abst.feature.orientation.OrientationIntegral;
import boofcv.alg.feature.orientation.*;
import boofcv.alg.feature.orientation.impl.*;
import boofcv.struct.image.*;


/**
 * @author Peter Abeles
 */
@SuppressWarnings({"unchecked"})
public class FactoryOrientationAlgs {

	public static >
	OrientationHistogram histogram( double objectToSample, int numAngles , int radius , boolean weighted ,
									   Class derivType )
	{
		OrientationHistogram ret;

		if( derivType == GrayF32.class ) {
			ret = (OrientationHistogram)new ImplOrientationHistogram_F32(objectToSample,numAngles,weighted);
		} else if( derivType == GrayS16.class ) {
			ret = (OrientationHistogram)new ImplOrientationHistogram_S16(objectToSample,numAngles,weighted);
		} else if( derivType == GrayS32.class ) {
			ret = (OrientationHistogram)new ImplOrientationHistogram_S32(objectToSample,numAngles,weighted);
		} else {
			throw new IllegalArgumentException("Unknown image type.");
		}

		ret.setObjectToSample(radius);

		return ret;
	}

	public static >
	OrientationImageAverage nogradient( double objectToSample , int radius , Class imageType )
	{
		OrientationImageAverage ret;

		if( imageType == GrayF32.class ) {
			ret = (OrientationImageAverage)new ImplOrientationImageAverage_F32(objectToSample,radius);
		} else if( imageType == GrayU8.class ) {
			ret = (OrientationImageAverage)new ImplOrientationImageAverage_U8(objectToSample,radius);
		} else {
			throw new IllegalArgumentException("Unknown image type.");
		}

		ret.setObjectRadius(radius);

		return ret;
	}

	public static >
	OrientationAverage average( double objectToSample, int radius , boolean weighted , Class derivType )
	{
		OrientationAverage ret;

		if( derivType == GrayF32.class ) {
			ret = (OrientationAverage)new ImplOrientationAverage_F32(objectToSample,weighted);
		} else if( derivType == GrayS16.class ) {
			ret = (OrientationAverage)new ImplOrientationAverage_S16(objectToSample,weighted);
		} else if( derivType == GrayS32.class ) {
			ret = (OrientationAverage)new ImplOrientationAverage_S32(objectToSample,weighted);
		} else {
			throw new IllegalArgumentException("Unknown image type.");
		}

		ret.setSampleRadius(radius);

		return ret;
	}

	public static >
	OrientationSlidingWindow sliding( double objectRadiusToScale, int numAngles, double windowSize ,
										 int radius , boolean weighted , Class derivType )
	{
		OrientationSlidingWindow ret;

		if( derivType == GrayF32.class ) {
			ret = (OrientationSlidingWindow)new ImplOrientationSlidingWindow_F32(objectRadiusToScale,numAngles,windowSize,weighted);
		} else if( derivType == GrayS16.class ) {
			ret = (OrientationSlidingWindow)new ImplOrientationSlidingWindow_S16(objectRadiusToScale,numAngles,windowSize,weighted);
		} else if( derivType == GrayS32.class ) {
			ret = (OrientationSlidingWindow)new ImplOrientationSlidingWindow_S32(objectRadiusToScale,numAngles,windowSize,weighted);
		} else {
			throw new IllegalArgumentException("Unknown image type.");
		}

		ret.setObjectRadius(radius);

		return ret;
	}

	/**
	 *
	 * @see ImplOrientationAverageGradientIntegral
	 *
	 * @param config Configuration for algorithm.
	 * @param integralType Type of image being processed.
	 * @return OrientationIntegral
	 */
	public static >
	OrientationIntegral average_ii( ConfigAverageIntegral config , Class integralType)
	{
		if( config == null )
			config = new ConfigAverageIntegral();

		return (OrientationIntegral)
				new ImplOrientationAverageGradientIntegral(config.objectRadiusToScale,
						config.radius,config.samplePeriod,config.sampleWidth,
						config.weightSigma ,integralType);
	}

	/**
	 * Estimates the orientation without calculating the image derivative.
	 *
	 * @see ImplOrientationImageAverageIntegral
	 *
	 * @param sampleRadius Radius of the region being considered in terms of samples. Typically 6.
	 * @param samplePeriod How often the image is sampled.  This number is scaled.  Typically 1.
	 * @param sampleWidth How wide of a kernel should be used to sample. Try 4
	 * @param weightSigma Sigma for weighting.  zero for unweighted.
	 * @param integralImage Type of image being processed.
	 * @return OrientationIntegral
	 */
	public static >
	OrientationIntegral image_ii( double objectRadiusToScale,
									  int sampleRadius , double samplePeriod , int sampleWidth,
									 double weightSigma , Class integralImage)
	{
		return (OrientationIntegral)
				new ImplOrientationImageAverageIntegral(objectRadiusToScale,
						sampleRadius,samplePeriod,sampleWidth,weightSigma,integralImage);
	}

	/**
	 * Estimates the orientation of a region by using a sliding window across the different potential
	 * angles.
	 *
	 * @see OrientationSlidingWindow
	 *
	 * @param config Configuration for algorithm.  If null defaults will be used.
	 * @param integralType Type of integral image being processed.
	 * @return OrientationIntegral
	 */
	public static >
	OrientationIntegral sliding_ii( ConfigSlidingIntegral config , Class integralType)
	{
		if( config == null )
			config = new ConfigSlidingIntegral();
		config.checkValidity();

		return (OrientationIntegral)
				new ImplOrientationSlidingWindowIntegral(config.objectRadiusToScale,config.samplePeriod,
						config.windowSize,config.radius,config.weightSigma, config.sampleWidth,integralType);
	}

	/**
	 * Estimates multiple orientations as specified in SIFT paper.
	 *
	 * @param config Configuration for algorithm.  If null defaults will be used.
	 * @param derivType Type of derivative image it takes as input
	 * @return OrientationHistogramSift
	 */
	public static >
	OrientationHistogramSift sift(ConfigSiftOrientation config , Class derivType ) {
		if( config == null )
			config = new ConfigSiftOrientation();
		config.checkValidity();

		return new OrientationHistogramSift(config.histogramSize,config.sigmaEnlarge,derivType);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy