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

boofcv.alg.background.BackgroundAlgorithmGmm 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.alg.background;

/**
 * 

* Background model in which each pixel is modeled as a Gaussian mixture model. The number of Gaussians in the * mixture is determined dynamically. If a pixel value is encountered which doesn't match any mixture then a * new Gaussian is added. Gaussians are removed when their weight becomes negative. See [1] for details. *

* *

Tuning Parameters:

*
    *
  • learningPeriod: Specifies how fast a Gaussian changes. Larger values is slower learning. Try 100
  • *
  • decayCoef: Adjusts how quickly a Gaussian's weight is reduced. Try 0.001
  • *
  • maxGaussian: Maximum number of Gaussian models. Try 10
  • *
  • initial variance The initial variance assigned to pixels when they are first observed. By default this is * Float.MIN_VALUE. *
* *

* [1] Zivkovic, Zoran. "Improved adaptive Gaussian mixture model for background subtraction." * In Pattern Recognition, 2004. ICPR 2004. Proceedings of the 17th International Conference on, * vol. 2, pp. 28-31. IEEE, 2004. *

* * @author Peter Abeles */ public interface BackgroundAlgorithmGmm { /** * Returns the initial variance assigned to a pixel * @return initial variance */ float getInitialVariance(); /** * Sets the initial variance assigned to a pixel * @param initialVariance initial variance */ void setInitialVariance(float initialVariance); /** * Returns the learning period. */ float getLearningPeriod(); /** * Specifies the learning rate * @param period Must be more than 0. */ void setLearningPeriod(float period); /** * Minimum value of a Gaussian's weight to be considered part of the background */ void setSignificantWeight( float value ); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy