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

boofcv.abst.shapes.polyline.SplitMergeLineRefine_to_PointsToPolyline Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2018, 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.abst.shapes.polyline;

import boofcv.alg.shapes.polyline.MinimizeEnergyPrune;
import boofcv.alg.shapes.polyline.RefinePolyLineCorner;
import boofcv.alg.shapes.polyline.splitmerge.SplitMergeLineFit;
import boofcv.alg.shapes.polyline.splitmerge.SplitMergeLineFitLoop;
import boofcv.alg.shapes.polyline.splitmerge.SplitMergeLineFitSegment;
import boofcv.factory.shape.ConfigSplitMergeLineFit;
import boofcv.struct.ConfigLength;
import georegression.geometry.UtilPolygons2D_F64;
import georegression.struct.point.Point2D_I32;
import georegression.struct.shapes.Polygon2D_F64;
import org.ddogleg.struct.GrowQueue_I32;

import java.util.List;

/**
 * Wrapper around {@link SplitMergeLineFit} and other refinement algorithms for {@link PointsToPolyline}.
 *
 * @author Peter Abeles
 */
@Deprecated
public class SplitMergeLineRefine_to_PointsToPolyline implements PointsToPolyline {

	// reject the number of sides found is greater than this amount
	int maxVertexes = Integer.MAX_VALUE;
	int minVertexes = 3;

	// standard split merge algorithm
	SplitMergeLineFit splitMerge;
	// refine corner location
	RefinePolyLineCorner refine;
	// removes extra corners
	private GrowQueue_I32 pruned = new GrowQueue_I32(); // corners after pruning
	private MinimizeEnergyPrune pruner;

	boolean convex = true;

	Polygon2D_F64 tmp = new Polygon2D_F64();

	public SplitMergeLineRefine_to_PointsToPolyline(ConfigSplitMergeLineFit config)
	{
		ConfigLength minimumSplit = config.minimumSide.copy();
		if( config.loop ) {
			splitMerge = new SplitMergeLineFitLoop(config.splitFraction, minimumSplit, config.iterations);
		} else {
			splitMerge = new SplitMergeLineFitSegment(config.splitFraction, minimumSplit, config.iterations);
		}

		if( config.refine > 0 ) {
			refine = new RefinePolyLineCorner(config.loop,config.refine);
		}

		if( config.pruneSplitPenalty > 0 ) {
			pruner = new MinimizeEnergyPrune(config.pruneSplitPenalty);
		}

		convex = config.convex;
		minVertexes = config.minimumSides;
		maxVertexes = config.maximumSides;
	}


	@Override
	public boolean process(List input, GrowQueue_I32 vertexes) {
		if (!splitMerge.process(input, vertexes)) {
			return false;
		}

		if (refine != null && !refine.fit(input, vertexes)) {
			return false;
		}

		if (pruner != null && pruner.prune(input, vertexes, pruned)) {
			vertexes.setTo(pruned);
		}

		if (vertexes.size > maxVertexes || vertexes.size < minVertexes)
			return false;

		tmp.vertexes.resize(vertexes.size);
		for (int i = 0; i < vertexes.size; i++) {
			Point2D_I32 p = input.get(vertexes.get(i));
			tmp.set(i, p.x, p.y);
		}

		return !convex || UtilPolygons2D_F64.isConvex(tmp);
	}

	@Override
	public void setMinimumSides(int minimum) {
		this.minVertexes = minimum;
	}

	@Override
	public int getMinimumSides() {
		return minVertexes;
	}

	@Override
	public void setMaximumSides(int maximum) {
		this.maxVertexes = maximum;
		// detect more than the max. Prune will reduce the number of corners later on
		splitMerge.setAbortSplits(maximum*2);
	}

	@Override
	public int getMaximumSides() {
		return maxVertexes;
	}

	@Override
	public boolean isLoop() {
		return splitMerge instanceof SplitMergeLineFitLoop;
	}

	@Override
	public void setConvex(boolean convex) {
		this.convex = convex;
	}

	@Override
	public boolean isConvex() {
		return convex;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy