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

boofcv.alg.geo.robust.GenerateHomographyLinear Maven / Gradle / Ivy

Go to download

BoofCV is an open source Java library for real-time computer vision and robotics applications.

There is a newer version: 1.1.7
Show newest version
/*
 * 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.alg.geo.robust;


import boofcv.abst.geo.Estimate1ofEpipolar;
import boofcv.factory.geo.FactoryMultiView;
import boofcv.struct.geo.AssociatedPair;
import georegression.struct.homography.Homography2D_F64;
import georegression.struct.homography.UtilHomography_F64;
import org.ddogleg.fitting.modelset.ModelFitter;
import org.ddogleg.fitting.modelset.ModelGenerator;
import org.ejml.data.DMatrixRMaj;

import java.util.List;

/**
 * Fits a homography to the observed points using linear algebra.  This provides an approximate solution.
 *
 * @author Peter Abeles
 */
public class GenerateHomographyLinear implements
		ModelGenerator ,
		ModelFitter
{

	Estimate1ofEpipolar alg;
	DMatrixRMaj H = new DMatrixRMaj(3,3);

	public GenerateHomographyLinear( boolean normalizeInput ) {
		alg = FactoryMultiView.homographyDLT(normalizeInput);
//		alg = FactoryMultiView.computeHomographyTLS();
	}

	@Override
	public boolean fitModel(List dataSet, Homography2D_F64 initial, Homography2D_F64 found) {
		if( !alg.process(dataSet,H) )
			return false;

		UtilHomography_F64.convert(H,found);
		return true;
	}

	@Override
	public boolean generate(List dataSet, Homography2D_F64 model ) {

		if( !alg.process(dataSet,H) )
			return false;

		UtilHomography_F64.convert(H,model);

		return true;
	}

	@Override
	public int getMinimumPoints() {
		return 4;
	}

	@Override
	public double getFitScore() {
		return 0;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy