/** @brief Implementation of the different yet better algorithm which is called GSOC, as it was implemented during GSOC and was not originated from any paper.
This algorithm demonstrates better performance on CDNET 2014 dataset compared to other algorithms in OpenCV.
parser=argparse.ArgumentParser(description='Evaluate all background subtractors using Change Detection 2014 dataset')
parser.add_argument('--dataset_path',help='Path to the directory with dataset. It may contain multiple inner directories. It will be scanned recursively.',required=True)
parser.add_argument('--algorithm',help='Test particular algorithm instead of all.')
assertlen(dataset_dirs)>0,("Passed directory must contain at least one sequence from the Change Detection dataset. There is no relevant directories in %s. Check that this directory is correct."%(args.dataset_path))
* This file also contains implementation of the different yet better algorithm which is called GSOC, as it was implemented during GSOC and was not originated from any paper.
*
*/
#include "precomp.hpp"
#include <opencv2/calib3d.hpp>
#include <iostream>
namespacecv
{
namespacebgsegm
{
namespace
{
constfloatLSBPtau=0.05f;
#ifdef _MSC_VER
#include <intrin.h>
#pragma intrinsic(__popcnt)
#endif
inlineuint32_tLSBPDist32(uint32_tn){
#if defined(__GNUC__) || defined(__clang__)
return__builtin_popcount(n);
#elif defined(_MSC_VER)
return__popcnt(n);
#else
// Taken from http://graphics.stanford.edu/~seander/bithacks.html#CountBitsSetParallel