Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv_contrib
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv_contrib
Commits
8c90b54f
Commit
8c90b54f
authored
Aug 20, 2014
by
jaco
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Pull Request mandatory changes 2
parent
255d83ac
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
75 additions
and
909 deletions
+75
-909
kyheader.hpp
modules/saliency/include/opencv2/saliency/kyheader.hpp
+0
-293
saliencySpecializedClasses.hpp
...y/include/opencv2/saliency/saliencySpecializedClasses.hpp
+58
-57
CmFile.hpp
modules/saliency/src/BING/CmFile.hpp
+1
-1
CmShow.hpp
modules/saliency/src/BING/CmShow.hpp
+1
-1
CmTimer.hpp
modules/saliency/src/BING/CmTimer.hpp
+2
-0
FilterTIG.cpp
modules/saliency/src/BING/FilterTIG.cpp
+3
-3
objectnessBING.cpp
modules/saliency/src/BING/objectnessBING.cpp
+10
-9
FilterTIG.hpp
modules/saliency/src/FilterTIG.hpp
+0
-98
ValStructVec.hpp
modules/saliency/src/ValStructVec.hpp
+0
-154
kyheader.hpp
modules/saliency/src/kyheader.hpp
+0
-293
No files found.
modules/saliency/include/opencv2/saliency/kyheader.hpp
deleted
100644 → 0
View file @
255d83ac
/*M///////////////////////////////////////////////////////////////////////////////////////
//
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
//
// By downloading, copying, installing or using the software you agree to this license.
// If you do not agree to this license, do not download, install,
// copy or use the software.
//
//
// License Agreement
// For Open Source Computer Vision Library
//
// Copyright (C) 2014, OpenCV Foundation, all rights reserved.
// Third party copyrights are property of their respective owners.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// * Redistribution's of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// * Redistribution's in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// * The name of the copyright holders may not be used to endorse or promote products
// derived from this software without specific prior written permission.
//
// This software is provided by the copyright holders and contributors "as is" and
// any express or implied warranties, including, but not limited to, the implied
// warranties of merchantability and fitness for a particular purpose are disclaimed.
// In no event shall the Intel Corporation or contributors be liable for any direct,
// indirect, incidental, special, exemplary, or consequential damages
// (including, but not limited to, procurement of substitute goods or services;
// loss of use, data, or profits; or business interruption) however caused
// and on any theory of liability, whether in contract, strict liability,
// or tort (including negligence or otherwise) arising in any way out of
// the use of this software, even if advised of the possibility of such damage.
//
//M*/
#ifndef KYHEADER_H
#define KYHEADER_H
#include <assert.h>
#include <string>
#include <vector>
#include <functional>
#include <list>
#include <algorithm>
#include <iostream>
#include <cmath>
#include <time.h>
#include <fstream>
#include <stdint.h>
//#include <omp.h>
// TODO: reference additional headers your program requires here
//#include "LibLinear/linear.h"
//#include <opencv2/opencv.hpp>
#include "opencv2/core.hpp"
#define CV_VERSION_ID CVAUX_STR(CV_MAJOR_VERSION) CVAUX_STR(CV_MINOR_VERSION) CVAUX_STR(CV_SUBMINOR_VERSION)
#ifdef _DEBUG
#define cvLIB(name) "opencv_" name CV_VERSION_ID "d"
#else
#define cvLIB(name) "opencv_" name CV_VERSION_ID
#endif
//#pragma comment( lib, cvLIB("core"))
//#pragma comment( lib, cvLIB("imgproc"))
//#pragma comment( lib, cvLIB("highgui"))
#ifdef WIN32
/* windows stuff */
#else
typedef
unsigned
long
DWORD
;
typedef
unsigned
short
WORD
;
typedef
unsigned
int
UNINT32
;
typedef
bool
BOOL
;
typedef
void
*
HANDLE
;
#endif
#ifndef _MSC_VER
typedef
unsigned
char
BYTE
;
#else
#include <windows.h>
#endif
namespace
cv
{
namespace
saliency
{
typedef
std
::
vector
<
int
>
vecI
;
typedef
const
std
::
string
CStr
;
typedef
const
cv
::
Mat
CMat
;
typedef
std
::
vector
<
std
::
string
>
vecS
;
typedef
std
::
vector
<
cv
::
Mat
>
vecM
;
typedef
std
::
vector
<
float
>
vecF
;
typedef
std
::
vector
<
double
>
vecD
;
enum
{
CV_FLIP_BOTH
=
-
1
,
CV_FLIP_VERTICAL
=
0
,
CV_FLIP_HORIZONTAL
=
1
};
#define _S(str) ((str).c_str())
#define CHK_IND(p) ((p).x >= 0 && (p).x < _w && (p).y >= 0 && (p).y < _h)
#define CV_Assert_(expr, args) \
{\
if(!(expr)) {\
String msg = cv::format args; \
printf("%s in %s:%d\n", msg.c_str(), __FILE__, __LINE__); \
cv::error(cv::Exception(CV_StsAssert, msg, __FUNCTION__, __FILE__, __LINE__) ); }\
}
// Return -1 if not in the list
template
<
typename
T
>
static
inline
int
findFromList
(
const
T
&
word
,
const
std
::
vector
<
T
>
&
strList
)
{
//TODO delete test code
//cout << "\n\n" << "word" <<" "<< word << endl;
for
(
int
i
=
0
;
i
<
strList
.
size
();
i
++
)
{
//cout <<"test word:"<< word << " " << endl;
//cout << "Size w " << word.size() << " Size L "<< strList[i].size() << endl;
}
std
::
vector
<
cv
::
String
>::
iterator
it
=
std
::
find
(
strList
.
begin
(),
strList
.
end
(),
word
);
if
(
it
==
strList
.
end
()
)
{
return
-
1
;
}
else
{
int
index
=
it
-
strList
.
begin
();
return
index
;
//vector<String>::iterator index = std::distance( strList.begin(), it );
//cout << "index" <<" "<< index << endl;
//return int( index );
}
}
/*template<typename T>
static inline int findFromList(const string &word, const vector<T> &strList) {
//for(int i=0; i<strList.size(); i++){
//cout <<"element: " <<strList[i]<<" "<<word << endl;
//if (std::strcmp(word.c_str(),strList[i].c_str())==0) return i;
}
return -1;
}
*/
template
<
typename
T
>
inline
T
sqr
(
T
x
)
{
return
x
*
x
;
}
// out of range risk for T = byte, ...
template
<
class
T
,
int
D
>
inline
T
vecSqrDist
(
const
cv
::
Vec
<
T
,
D
>
&
v1
,
const
cv
::
Vec
<
T
,
D
>
&
v2
)
{
T
s
=
0
;
for
(
int
i
=
0
;
i
<
D
;
i
++
)
s
+=
sqr
(
v1
[
i
]
-
v2
[
i
]
);
return
s
;
}
// out of range risk for T = byte, ...
template
<
class
T
,
int
D
>
inline
T
vecDist
(
const
cv
::
Vec
<
T
,
D
>
&
v1
,
const
cv
::
Vec
<
T
,
D
>
&
v2
)
{
return
sqrt
(
vecSqrDist
(
v1
,
v2
)
);
}
// out of range risk for T = byte, ...
inline
cv
::
Rect
Vec4i2Rect
(
cv
::
Vec4i
&
v
)
{
return
cv
::
Rect
(
cv
::
Point
(
v
[
0
]
-
1
,
v
[
1
]
-
1
),
cv
::
Point
(
v
[
2
],
v
[
3
]
)
);
}
/*
#ifdef __WIN32
#define INT64 long long
#else
#define INT64 long
typedef unsigned long UINT64_;
//#define UINT64 unsigned long
#endif
*/
#if defined(_MSC_VER)
# include <intrin.h>
# define POPCNT(x) __popcnt(x)
# define POPCNT64(x) __popcnt64(x)
#endif
#if defined(__GNUC__)
# define POPCNT(x) __builtin_popcount(x)
# define POPCNT64(x) __builtin_popcountll(x)
#endif
inline
int
popcnt64
(
register
uint64_t
u
)
{
u
=
(
u
&
0x5555555555555555
)
+
(
(
u
>>
1
)
&
0x5555555555555555
);
u
=
(
u
&
0x3333333333333333
)
+
(
(
u
>>
2
)
&
0x3333333333333333
);
u
=
(
u
&
0x0f0f0f0f0f0f0f0f
)
+
(
(
u
>>
4
)
&
0x0f0f0f0f0f0f0f0f
);
u
=
(
u
&
0x00ff00ff00ff00ff
)
+
(
(
u
>>
8
)
&
0x00ff00ff00ff00ff
);
u
=
(
u
&
0x0000ffff0000ffff
)
+
(
(
u
>>
16
)
&
0x0000ffff0000ffff
);
u
=
(
u
&
0x00000000ffffffff
)
+
(
(
u
>>
32
)
&
0x00000000ffffffff
);
return
(
int
)
u
;
}
inline
int
popcnt
(
register
uint32_t
u
)
{
u
=
(
u
&
0x55555555
)
+
(
(
u
>>
1
)
&
0x55555555
);
u
=
(
u
&
0x33333333
)
+
(
(
u
>>
2
)
&
0x33333333
);
u
=
(
u
&
0x0f0f0f0f
)
+
(
(
u
>>
4
)
&
0x0f0f0f0f
);
u
=
(
u
&
0x00ff00ff
)
+
(
(
u
>>
8
)
&
0x00ff00ff
);
u
=
(
u
&
0x0000ffff
)
+
(
(
u
>>
16
)
&
0x0000ffff
);
return
(
int
)
u
;
}
inline
int
popcnt64_nibble
(
register
uint64_t
u
)
{
static
const
uint8_t
Table
[]
=
{
0
,
1
,
1
,
2
,
1
,
2
,
2
,
3
,
1
,
2
,
2
,
3
,
2
,
3
,
3
,
4
};
int
c
=
0
;
while
(
u
)
{
c
+=
Table
[
u
&
0xf
];
u
>>=
4
;
}
return
(
int
)
c
;
}
inline
int
popcnt_nibble
(
register
uint32_t
u
)
{
static
const
uint8_t
Table
[]
=
{
0
,
1
,
1
,
2
,
1
,
2
,
2
,
3
,
1
,
2
,
2
,
3
,
2
,
3
,
3
,
4
};
int
c
=
0
;
while
(
u
)
{
c
+=
Table
[
u
&
0xf
];
u
>>=
4
;
}
return
(
int
)
c
;
}
inline
int
popcnt64_byte
(
register
uint64_t
u
)
{
#define B2(k) k, k+1, k+1, k+2
#define B4(k) B2(k), B2(k+1), B2(k+1), B2(k+2)
#define B6(k) B4(k), B4(k+1), B4(k+1), B4(k+2)
static
const
uint8_t
Table
[]
=
{
B6
(
0
),
B6
(
1
),
B6
(
1
),
B6
(
2
)
};
#undef B6
#undef B4
#undef B2
int
c
=
0
;
while
(
u
)
{
c
+=
Table
[
u
&
0xff
];
u
>>=
8
;
}
return
(
int
)
c
;
}
inline
int
popcnt_byte
(
register
uint32_t
u
)
{
#define B2(k) k, k+1, k+1, k+2
#define B4(k) B2(k), B2(k+1), B2(k+1), B2(k+2)
#define B6(k) B4(k), B4(k+1), B4(k+1), B4(k+2)
static
const
uint8_t
Table
[]
=
{
B6
(
0
),
B6
(
1
),
B6
(
1
),
B6
(
2
)
};
#undef B6
#undef B4
#undef B2
int
c
=
0
;
while
(
u
)
{
c
+=
Table
[
u
&
0xff
];
u
>>=
8
;
}
return
(
int
)
c
;
}
}
}
/////
#endif // KYHEADER_H
modules/saliency/include/opencv2/saliency/saliencySpecializedClasses.hpp
View file @
8c90b54f
...
...
@@ -42,7 +42,7 @@
#ifndef __OPENCV_SALIENCY_SPECIALIZED_CLASSES_HPP__
#define __OPENCV_SALIENCY_SPECIALIZED_CLASSES_HPP__
#include "opencv2/saliency/kyheader.hpp"
//
#include "opencv2/saliency/kyheader.hpp"
#include <cstdio>
#include <string>
#include <iostream>
...
...
@@ -60,7 +60,7 @@ namespace saliency
*/
class
CV_EXPORTS
StaticSaliencySpectralResidual
:
public
StaticSaliency
{
public
:
public
:
//StaticSaliencySpectralResidual( const StaticSaliencySpectralResidual::Params ¶meters = StaticSaliencySpectralResidual::Params() );
StaticSaliencySpectralResidual
();
...
...
@@ -69,7 +69,7 @@ class CV_EXPORTS StaticSaliencySpectralResidual : public StaticSaliency
void
read
(
const
FileNode
&
fn
);
void
write
(
FileStorage
&
fs
)
const
;
protected
:
protected
:
bool
computeSaliencyImpl
(
const
InputArray
image
,
OutputArray
saliencyMap
);
AlgorithmInfo
*
info
()
const
;
CV_PROP_RW
int
resImWidth
;
...
...
@@ -90,18 +90,18 @@ class CV_EXPORTS StaticSaliencySpectralResidual : public StaticSaliency
class
CV_EXPORTS
MotionSaliencyBinWangApr2014
:
public
MotionSaliency
{
public
:
public
:
MotionSaliencyBinWangApr2014
();
~
MotionSaliencyBinWangApr2014
();
void
setImagesize
(
int
W
,
int
H
);
bool
init
();
protected
:
protected
:
bool
computeSaliencyImpl
(
const
InputArray
image
,
OutputArray
saliencyMap
);
AlgorithmInfo
*
info
()
const
;
private
:
private
:
// classification (and adaptation) functions
bool
fullResolutionDetection
(
const
Mat
&
image
,
Mat
&
highResBFMask
);
...
...
@@ -117,12 +117,12 @@ class CV_EXPORTS MotionSaliencyBinWangApr2014 : public MotionSaliency
//bool decisionThresholdAdaptation();
// changing structure
std
::
vector
<
Ptr
<
Mat
>
>
backgroundModel
;
// The vector represents the background template T0---TK of reference paper.
std
::
vector
<
Ptr
<
Mat
>
>
backgroundModel
;
// The vector represents the background template T0---TK of reference paper.
// Matrices are two-channel matrix. In the first layer there are the B (background value)
// for each pixel. In the second layer, there are the C (efficacy) value for each pixel
Mat
potentialBackground
;
// Two channel Matrix. For each pixel, in the first level there are the Ba value (potential background value)
// and in the secon level there are the Ca value, the counter for each potential value.
Mat
epslonPixelsValue
;
// epslon threshold
Mat
potentialBackground
;
// Two channel Matrix. For each pixel, in the first level there are the Ba value (potential background value)
// and in the secon level there are the Ca value, the counter for each potential value.
Mat
epslonPixelsValue
;
// epslon threshold
//Mat activityPixelsValue; // Activity level of each pixel
//vector<Mat> noisePixelMask; // We define a ‘noise-pixel’ as a pixel that has been classified as a foreground pixel during the full resolution
// detection process,however, after the low resolution detection, it has become a
...
...
@@ -130,19 +130,19 @@ class CV_EXPORTS MotionSaliencyBinWangApr2014 : public MotionSaliency
//fixed parameter
bool
neighborhoodCheck
;
int
N_DS
;
// Number of template to be downsampled and used in lowResolutionDetection function
int
N_DS
;
// Number of template to be downsampled and used in lowResolutionDetection function
//Ptr<Size> imgSize;
int
imageWidth
;
// Width of input image
int
imageHeight
;
//Height of input image
int
K
;
// Number of background model template
int
N
;
// NxN is the size of the block for downsampling in the lowlowResolutionDetection
float
alpha
;
// Learning rate
int
L0
,
L1
;
// Upper-bound values for C0 and C1 (efficacy of the first two template (matrices) of backgroundModel
int
thetaL
;
// T0, T1 swap threshold
int
thetaA
;
// Potential background value threshold
int
gamma
;
// Parameter that controls the time that the newly updated long-term background value will remain in the
// long-term template, regardless of any subsequent background changes. A relatively large (eg gamma=3) will
//restrain the generation of ghosts.
int
imageWidth
;
// Width of input image
int
imageHeight
;
//Height of input image
int
K
;
// Number of background model template
int
N
;
// NxN is the size of the block for downsampling in the lowlowResolutionDetection
float
alpha
;
// Learning rate
int
L0
,
L1
;
// Upper-bound values for C0 and C1 (efficacy of the first two template (matrices) of backgroundModel
int
thetaL
;
// T0, T1 swap threshold
int
thetaA
;
// Potential background value threshold
int
gamma
;
// Parameter that controls the time that the newly updated long-term background value will remain in the
// long-term template, regardless of any subsequent background changes. A relatively large (eg gamma=3) will
//restrain the generation of ghosts.
//int Ainc; // Activity Incrementation;
//int Bmax; // Upper-bound value for pixel activity
//int Bth; // Max activity threshold
...
...
@@ -160,7 +160,7 @@ class CV_EXPORTS MotionSaliencyBinWangApr2014 : public MotionSaliency
*/
class
CV_EXPORTS
ObjectnessBING
:
public
Objectness
{
public
:
public
:
ObjectnessBING
();
~
ObjectnessBING
();
...
...
@@ -172,30 +172,30 @@ class CV_EXPORTS ObjectnessBING : public Objectness
void
setTrainingPath
(
std
::
string
trainingPath
);
void
setBBResDir
(
std
::
string
resultsDir
);
protected
:
protected
:
bool
computeSaliencyImpl
(
const
InputArray
image
,
OutputArray
objectnessBoundingBox
);
AlgorithmInfo
*
info
()
const
;
private
:
private
:
class
FilterTIG
{
public
:
void
update
(
C
Mat
&
w
);
public
:
void
update
(
Mat
&
w
);
// For a W by H gradient magnitude map, find a W-7 by H-7 CV_32F matching score map
Mat
matchTemplate
(
const
cv
::
Mat
&
mag1u
);
Mat
matchTemplate
(
const
Mat
&
mag1u
);
float
dot
(
const
int64_t
tig1
,
const
int64_t
tig2
,
const
int64_t
tig4
,
const
int64_t
tig8
);
public
:
void
reconstruct
(
cv
::
Mat
&
w
);
// For illustration purpose
public
:
void
reconstruct
(
Mat
&
w
);
// For illustration purpose
private
:
static
const
int
NUM_COMP
=
2
;
// Number of components
static
const
int
D
=
64
;
// Dimension of TIG
int64_t
_bTIGs
[
NUM_COMP
];
// Binary TIG features
float
_coeffs1
[
NUM_COMP
];
// Coefficients of binary TIG features
private
:
static
const
int
NUM_COMP
=
2
;
// Number of components
static
const
int
D
=
64
;
// Dimension of TIG
int64_t
_bTIGs
[
NUM_COMP
];
// Binary TIG features
float
_coeffs1
[
NUM_COMP
];
// Coefficients of binary TIG features
// For efficiently deals with different bits in CV_8U gradient map
float
_coeffs2
[
NUM_COMP
],
_coeffs4
[
NUM_COMP
],
_coeffs8
[
NUM_COMP
];
...
...
@@ -220,8 +220,8 @@ class CV_EXPORTS ObjectnessBING : public Objectness
void
append
(
const
ValStructVec
<
VT
,
ST
>
&
newVals
,
int
startV
=
0
);
std
::
vector
<
ST
>
structVals
;
// struct values
int
sz
;
// size of the value struct vector
std
::
vector
<
std
::
pair
<
VT
,
int
>
>
valIdxes
;
// Indexes after sort
int
sz
;
// size of the value struct vector
std
::
vector
<
std
::
pair
<
VT
,
int
>
>
valIdxes
;
// Indexes after sort
bool
smaller
()
{
return
true
;
...
...
@@ -237,27 +237,27 @@ class CV_EXPORTS ObjectnessBING : public Objectness
};
double
_base
,
_logBase
;
// base for window size quantization
int
_W
;
// As described in the paper: #Size, Size(_W, _H) of feature window.
int
_NSS
;
// Size for non-maximal suppress
int
_maxT
,
_minT
,
_numT
;
// The minimal and maximal dimensions of the template
int
_W
;
// As described in the paper: #Size, Size(_W, _H) of feature window.
int
_NSS
;
// Size for non-maximal suppress
int
_maxT
,
_minT
,
_numT
;
// The minimal and maximal dimensions of the template
int
_Clr
;
//
int
_Clr
;
//
static
const
char
*
_clrName
[
3
];
// Names and paths to read model and to store results
std
::
string
_modelName
,
_bbResDir
,
_trainingPath
,
_resultsDir
;
vecI
_svmSzIdxs
;
// Indexes of active size. It's equal to _svmFilters.size() and _svmReW1f.rows
Mat
_svmFilter
;
// Filters learned at stage I, each is a _H by _W CV_32F matrix
FilterTIG
_tigF
;
// TIG filter
Mat
_svmReW1f
;
// Re-weight parameters learned at stage II.
std
::
vector
<
int
>
_svmSzIdxs
;
// Indexes of active size. It's equal to _svmFilters.size() and _svmReW1f.rows
Mat
_svmFilter
;
// Filters learned at stage I, each is a _H by _W CV_32F matrix
FilterTIG
_tigF
;
// TIG filter
Mat
_svmReW1f
;
// Re-weight parameters learned at stage II.
// List of the rectangles' objectness value, in the same order as
// the vector<Vec4i> objectnessBoundingBox returned by the algorithm (in computeSaliencyImpl function)
std
::
vector
<
float
>
objectnessValues
;
//vector<Vec4i> objectnessBoundingBox;
private
:
private
:
// functions
inline
static
float
LoG
(
float
x
,
float
y
,
float
delta
)
...
...
@@ -272,12 +272,12 @@ class CV_EXPORTS ObjectnessBING : public Objectness
void
setColorSpace
(
int
clr
=
MAXBGR
);
// Load trained model.
int
loadTrainedModel
(
std
::
string
modelName
=
""
);
// Return -1, 0, or 1 if partial, none, or all loaded
int
loadTrainedModel
(
std
::
string
modelName
=
""
);
// Return -1, 0, or 1 if partial, none, or all loaded
// Get potential bounding boxes, each of which is represented by a Vec4i for (minX, minY, maxX, maxY).
// The trained model should be prepared before calling this function: loadTrainedModel() or trainStageI() + trainStageII().
// Use numDet to control the final number of proposed bounding boxes, and number of per size (scale and aspect ratio)
void
getObjBndBoxes
(
C
Mat
&
img3u
,
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
int
numDetPerSize
=
120
);
void
getObjBndBoxes
(
Mat
&
img3u
,
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
int
numDetPerSize
=
120
);
void
getObjBndBoxesForSingleImage
(
Mat
img
,
ValStructVec
<
float
,
Vec4i
>
&
boxes
,
int
numDetPerSize
);
bool
filtersLoaded
()
...
...
@@ -285,16 +285,16 @@ class CV_EXPORTS ObjectnessBING : public Objectness
int
n
=
(
int
)
_svmSzIdxs
.
size
();
return
n
>
0
&&
_svmReW1f
.
size
()
==
Size
(
2
,
n
)
&&
_svmFilter
.
size
()
==
Size
(
_W
,
_W
);
}
void
predictBBoxSI
(
CMat
&
mag3u
,
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
vecI
&
sz
,
int
NUM_WIN_PSZ
=
100
,
bool
fast
=
true
);
void
predictBBoxSII
(
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
const
vecI
&
sz
);
void
predictBBoxSI
(
Mat
&
mag3u
,
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
std
::
vector
<
int
>
&
sz
,
int
NUM_WIN_PSZ
=
100
,
bool
fast
=
true
);
void
predictBBoxSII
(
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
const
std
::
vector
<
int
>
&
sz
);
// Calculate the image gradient: center option as in VLFeat
void
gradientMag
(
C
Mat
&
imgBGR3u
,
Mat
&
mag1u
);
void
gradientMag
(
Mat
&
imgBGR3u
,
Mat
&
mag1u
);
static
void
gradientRGB
(
C
Mat
&
bgr3u
,
Mat
&
mag1u
);
static
void
gradientGray
(
C
Mat
&
bgr3u
,
Mat
&
mag1u
);
static
void
gradientHSV
(
C
Mat
&
bgr3u
,
Mat
&
mag1u
);
static
void
gradientXY
(
CMat
&
x1i
,
C
Mat
&
y1i
,
Mat
&
mag1u
);
static
void
gradientRGB
(
Mat
&
bgr3u
,
Mat
&
mag1u
);
static
void
gradientGray
(
Mat
&
bgr3u
,
Mat
&
mag1u
);
static
void
gradientHSV
(
Mat
&
bgr3u
,
Mat
&
mag1u
);
static
void
gradientXY
(
Mat
&
x1i
,
Mat
&
y1i
,
Mat
&
mag1u
);
static
inline
int
bgrMaxDist
(
const
Vec3b
&
u
,
const
Vec3b
&
v
)
{
...
...
@@ -308,11 +308,12 @@ class CV_EXPORTS ObjectnessBING : public Objectness
}
//Non-maximal suppress
static
void
nonMaxSup
(
C
Mat
&
matchCost1f
,
ValStructVec
<
float
,
Point
>
&
matchCost
,
int
NSS
=
1
,
int
maxPoint
=
50
,
bool
fast
=
true
);
static
void
nonMaxSup
(
Mat
&
matchCost1f
,
ValStructVec
<
float
,
Point
>
&
matchCost
,
int
NSS
=
1
,
int
maxPoint
=
50
,
bool
fast
=
true
);
};
}
/* namespace saliency */
}
/* namespace saliency */
}
/* namespace cv */
#endif
modules/saliency/src/BING/CmFile.hpp
View file @
8c90b54f
...
...
@@ -49,7 +49,7 @@
#include <stdlib.h>
#include <sys/stat.h>
#include <dirent.h>
#include "
opencv2/saliency
/kyheader.hpp"
#include "
BING
/kyheader.hpp"
#endif
namespace
cv
...
...
modules/saliency/src/BING/CmShow.hpp
View file @
8c90b54f
...
...
@@ -42,7 +42,7 @@
#ifndef __OPENCV_CM_SHOW_HPP__
#define __OPENCV_CM_SHOW_HPP__
#include "
opencv2/saliency
/kyheader.hpp"
#include "
BING
/kyheader.hpp"
namespace
cv
{
...
...
modules/saliency/src/BING/CmTimer.hpp
View file @
8c90b54f
...
...
@@ -42,6 +42,8 @@
#ifndef __OPENCV_CM_TIMER_HPP__
#define __OPENCV_CM_TIMER_HPP__
#include "BING/kyheader.hpp"
namespace
cv
{
namespace
saliency
...
...
modules/saliency/src/BING/FilterTIG.cpp
View file @
8c90b54f
...
...
@@ -67,7 +67,7 @@ float ObjectnessBING::FilterTIG::dot( const int64_t tig1, const int64_t tig2, co
return
_coeffs1
[
0
]
*
(
bc01
+
bc02
+
bc04
+
bc08
)
+
_coeffs1
[
1
]
*
(
bc11
+
bc12
+
bc14
+
bc18
);
}
void
ObjectnessBING
::
FilterTIG
::
update
(
C
Mat
&
w1f
)
void
ObjectnessBING
::
FilterTIG
::
update
(
Mat
&
w1f
)
{
CV_Assert
(
w1f
.
cols
*
w1f
.
rows
==
D
&&
w1f
.
type
()
==
CV_32F
&&
w1f
.
isContinuous
()
);
float
b
[
D
],
residuals
[
D
];
...
...
@@ -149,5 +149,5 @@ Mat ObjectnessBING::FilterTIG::matchTemplate( const Mat &mag1u )
return
matchCost1f
;
}
}
// namespace saliency
}
// namespace cv
}
// namespace saliency
}
// namespace cv
modules/saliency/src/BING/objectnessBING.cpp
View file @
8c90b54f
...
...
@@ -41,6 +41,7 @@
#include "precomp.hpp"
#include "BING/kyheader.hpp"
#include "CmTimer.hpp"
#include "CmFile.hpp"
...
...
@@ -126,7 +127,7 @@ int ObjectnessBING::loadTrainedModel( std::string modelName ) // Return -1, 0,
return
1
;
}
void
ObjectnessBING
::
predictBBoxSI
(
CMat
&
img3u
,
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
vecI
&
sz
,
int
NUM_WIN_PSZ
,
bool
fast
)
void
ObjectnessBING
::
predictBBoxSI
(
Mat
&
img3u
,
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
std
::
vector
<
int
>
&
sz
,
int
NUM_WIN_PSZ
,
bool
fast
)
{
const
int
numSz
=
(
int
)
_svmSzIdxs
.
size
();
const
int
imgW
=
img3u
.
cols
,
imgH
=
img3u
.
rows
;
...
...
@@ -173,7 +174,7 @@ void ObjectnessBING::predictBBoxSI( CMat &img3u, ValStructVec<float, Vec4i> &val
}
void
ObjectnessBING
::
predictBBoxSII
(
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
const
vecI
&
sz
)
void
ObjectnessBING
::
predictBBoxSII
(
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
const
std
::
vector
<
int
>
&
sz
)
{
int
numI
=
valBoxes
.
size
();
for
(
int
i
=
0
;
i
<
numI
;
i
++
)
...
...
@@ -190,7 +191,7 @@ void ObjectnessBING::predictBBoxSII( ValStructVec<float, Vec4i> &valBoxes, const
// Get potential bounding boxes, each of which is represented by a Vec4i for (minX, minY, maxX, maxY).
// The trained model should be prepared before calling this function: loadTrainedModel() or trainStageI() + trainStageII().
// Use numDet to control the final number of proposed bounding boxes, and number of per size (scale and aspect ratio)
void
ObjectnessBING
::
getObjBndBoxes
(
C
Mat
&
img3u
,
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
int
numDetPerSize
)
void
ObjectnessBING
::
getObjBndBoxes
(
Mat
&
img3u
,
ValStructVec
<
float
,
Vec4i
>
&
valBoxes
,
int
numDetPerSize
)
{
//CV_Assert_(filtersLoaded() , ("SVM filters should be initialized before getting object proposals\n"));
vecI
sz
;
...
...
@@ -199,7 +200,7 @@ void ObjectnessBING::getObjBndBoxes( CMat &img3u, ValStructVec<float, Vec4i> &va
return
;
}
void
ObjectnessBING
::
nonMaxSup
(
C
Mat
&
matchCost1f
,
ValStructVec
<
float
,
Point
>
&
matchCost
,
int
NSS
,
int
maxPoint
,
bool
fast
)
void
ObjectnessBING
::
nonMaxSup
(
Mat
&
matchCost1f
,
ValStructVec
<
float
,
Point
>
&
matchCost
,
int
NSS
,
int
maxPoint
,
bool
fast
)
{
const
int
_h
=
matchCost1f
.
rows
,
_w
=
matchCost1f
.
cols
;
Mat
isMax1u
=
Mat
::
ones
(
_h
,
_w
,
CV_8U
),
costSmooth1f
;
...
...
@@ -249,7 +250,7 @@ void ObjectnessBING::nonMaxSup( CMat &matchCost1f, ValStructVec<float, Point> &m
}
}
void
ObjectnessBING
::
gradientMag
(
C
Mat
&
imgBGR3u
,
Mat
&
mag1u
)
void
ObjectnessBING
::
gradientMag
(
Mat
&
imgBGR3u
,
Mat
&
mag1u
)
{
switch
(
_Clr
)
{
...
...
@@ -267,7 +268,7 @@ void ObjectnessBING::gradientMag( CMat &imgBGR3u, Mat &mag1u )
}
}
void
ObjectnessBING
::
gradientRGB
(
C
Mat
&
bgr3u
,
Mat
&
mag1u
)
void
ObjectnessBING
::
gradientRGB
(
Mat
&
bgr3u
,
Mat
&
mag1u
)
{
const
int
H
=
bgr3u
.
rows
,
W
=
bgr3u
.
cols
;
Mat
Ix
(
H
,
W
,
CV_32S
),
Iy
(
H
,
W
,
CV_32S
);
...
...
@@ -303,7 +304,7 @@ void ObjectnessBING::gradientRGB( CMat &bgr3u, Mat &mag1u )
gradientXY
(
Ix
,
Iy
,
mag1u
);
}
void
ObjectnessBING
::
gradientGray
(
C
Mat
&
bgr3u
,
Mat
&
mag1u
)
void
ObjectnessBING
::
gradientGray
(
Mat
&
bgr3u
,
Mat
&
mag1u
)
{
Mat
g1u
;
cvtColor
(
bgr3u
,
g1u
,
COLOR_BGR2GRAY
);
...
...
@@ -335,7 +336,7 @@ void ObjectnessBING::gradientGray( CMat &bgr3u, Mat &mag1u )
gradientXY
(
Ix
,
Iy
,
mag1u
);
}
void
ObjectnessBING
::
gradientHSV
(
C
Mat
&
bgr3u
,
Mat
&
mag1u
)
void
ObjectnessBING
::
gradientHSV
(
Mat
&
bgr3u
,
Mat
&
mag1u
)
{
Mat
hsv3u
;
cvtColor
(
bgr3u
,
hsv3u
,
COLOR_BGR2HSV
);
...
...
@@ -367,7 +368,7 @@ void ObjectnessBING::gradientHSV( CMat &bgr3u, Mat &mag1u )
gradientXY
(
Ix
,
Iy
,
mag1u
);
}
void
ObjectnessBING
::
gradientXY
(
CMat
&
x1i
,
C
Mat
&
y1i
,
Mat
&
mag1u
)
void
ObjectnessBING
::
gradientXY
(
Mat
&
x1i
,
Mat
&
y1i
,
Mat
&
mag1u
)
{
const
int
H
=
x1i
.
rows
,
W
=
x1i
.
cols
;
mag1u
.
create
(
H
,
W
,
CV_8U
);
...
...
modules/saliency/src/FilterTIG.hpp
deleted
100644 → 0
View file @
255d83ac
/*M///////////////////////////////////////////////////////////////////////////////////////
//
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
//
// By downloading, copying, installing or using the software you agree to this license.
// If you do not agree to this license, do not download, install,
// copy or use the software.
//
//
// License Agreement
// For Open Source Computer Vision Library
//
// Copyright (C) 2014, OpenCV Foundation, all rights reserved.
// Third party copyrights are property of their respective owners.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// * Redistribution's of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// * Redistribution's in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// * The name of the copyright holders may not be used to endorse or promote products
// derived from this software without specific prior written permission.
//
// This software is provided by the copyright holders and contributors "as is" and
// any express or implied warranties, including, but not limited to, the implied
// warranties of merchantability and fitness for a particular purpose are disclaimed.
// In no event shall the Intel Corporation or contributors be liable for any direct,
// indirect, incidental, special, exemplary, or consequential damages
// (including, but not limited to, procurement of substitute goods or services;
// loss of use, data, or profits; or business interruption) however caused
// and on any theory of liability, whether in contract, strict liability,
// or tort (including negligence or otherwise) arising in any way out of
// the use of this software, even if advised of the possibility of such damage.
//
//M*/
#ifndef __OPENCV_FILTER_TIG_HPP__
#define __OPENCV_FILTER_TIG_HPP__
#include "src/kyheader.hpp"
namespace
cv
{
namespace
saliency
{
class
FilterTIG
{
public
:
void
update
(
CMat
&
w
);
// For a W by H gradient magnitude map, find a W-7 by H-7 CV_32F matching score map
cv
::
Mat
matchTemplate
(
const
cv
::
Mat
&
mag1u
);
inline
float
dot
(
const
int64_t
tig1
,
const
int64_t
tig2
,
const
int64_t
tig4
,
const
int64_t
tig8
);
public
:
void
reconstruct
(
cv
::
Mat
&
w
);
// For illustration purpose
private
:
static
const
int
NUM_COMP
=
2
;
// Number of components
static
const
int
D
=
64
;
// Dimension of TIG
int64_t
_bTIGs
[
NUM_COMP
];
// Binary TIG features
float
_coeffs1
[
NUM_COMP
];
// Coefficients of binary TIG features
// For efficiently deals with different bits in CV_8U gradient map
float
_coeffs2
[
NUM_COMP
],
_coeffs4
[
NUM_COMP
],
_coeffs8
[
NUM_COMP
];
};
inline
float
FilterTIG
::
dot
(
const
int64_t
tig1
,
const
int64_t
tig2
,
const
int64_t
tig4
,
const
int64_t
tig8
)
{
int64_t
bcT1
=
(
int64_t
)
POPCNT64
(
tig1
);
int64_t
bcT2
=
(
int64_t
)
POPCNT64
(
tig2
);
int64_t
bcT4
=
(
int64_t
)
POPCNT64
(
tig4
);
int64_t
bcT8
=
(
int64_t
)
POPCNT64
(
tig8
);
int64_t
bc01
=
(
int64_t
)
(
POPCNT64
(
_bTIGs
[
0
]
&
tig1
)
<<
1
)
-
bcT1
;
int64_t
bc02
=
(
int64_t
)
(
(
POPCNT64
(
_bTIGs
[
0
]
&
tig2
)
<<
1
)
-
bcT2
)
<<
1
;
int64_t
bc04
=
(
int64_t
)
(
(
POPCNT64
(
_bTIGs
[
0
]
&
tig4
)
<<
1
)
-
bcT4
)
<<
2
;
int64_t
bc08
=
(
int64_t
)
(
(
POPCNT64
(
_bTIGs
[
0
]
&
tig8
)
<<
1
)
-
bcT8
)
<<
3
;
int64_t
bc11
=
(
int64_t
)
(
POPCNT64
(
_bTIGs
[
1
]
&
tig1
)
<<
1
)
-
bcT1
;
int64_t
bc12
=
(
int64_t
)
(
(
POPCNT64
(
_bTIGs
[
1
]
&
tig2
)
<<
1
)
-
bcT2
)
<<
1
;
int64_t
bc14
=
(
int64_t
)
(
(
POPCNT64
(
_bTIGs
[
1
]
&
tig4
)
<<
1
)
-
bcT4
)
<<
2
;
int64_t
bc18
=
(
int64_t
)
(
(
POPCNT64
(
_bTIGs
[
1
]
&
tig8
)
<<
1
)
-
bcT8
)
<<
3
;
return
_coeffs1
[
0
]
*
(
bc01
+
bc02
+
bc04
+
bc08
)
+
_coeffs1
[
1
]
*
(
bc11
+
bc12
+
bc14
+
bc18
);
}
}
/* namespace saliency */
}
/* namespace cv */
#endif //__OPENCV_FILTER_TIG_HPP__
modules/saliency/src/ValStructVec.hpp
deleted
100644 → 0
View file @
255d83ac
/*M///////////////////////////////////////////////////////////////////////////////////////
//
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
//
// By downloading, copying, installing or using the software you agree to this license.
// If you do not agree to this license, do not download, install,
// copy or use the software.
//
//
// License Agreement
// For Open Source Computer Vision Library
//
// Copyright (C) 2014, OpenCV Foundation, all rights reserved.
// Third party copyrights are property of their respective owners.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// * Redistribution's of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// * Redistribution's in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// * The name of the copyright holders may not be used to endorse or promote products
// derived from this software without specific prior written permission.
//
// This software is provided by the copyright holders and contributors "as is" and
// any express or implied warranties, including, but not limited to, the implied
// warranties of merchantability and fitness for a particular purpose are disclaimed.
// In no event shall the Intel Corporation or contributors be liable for any direct,
// indirect, incidental, special, exemplary, or consequential damages
// (including, but not limited to, procurement of substitute goods or services;
// loss of use, data, or profits; or business interruption) however caused
// and on any theory of liability, whether in contract, strict liability,
// or tort (including negligence or otherwise) arising in any way out of
// the use of this software, even if advised of the possibility of such damage.
//
//M*/
#ifndef __OPENCV_VAL_STRUCT_VEC_HPP__
#define __OPENCV_VAL_STRUCT_VEC_HPP__
/************************************************************************/
/* A value struct vector that supports efficient sorting */
/************************************************************************/
namespace
cv
{
namespace
saliency
{
template
<
typename
VT
,
typename
ST
>
struct
ValStructVec
{
ValStructVec
()
{
clear
();
}
inline
int
size
()
const
{
return
sz
;
}
inline
void
clear
()
{
sz
=
0
;
structVals
.
clear
();
valIdxes
.
clear
();
}
inline
void
reserve
(
int
resSz
)
{
clear
();
structVals
.
reserve
(
resSz
);
valIdxes
.
reserve
(
resSz
);
}
inline
void
pushBack
(
const
VT
&
val
,
const
ST
&
structVal
)
{
valIdxes
.
push_back
(
std
::
make_pair
(
val
,
sz
)
);
structVals
.
push_back
(
structVal
);
sz
++
;
}
inline
const
VT
&
operator
()(
int
i
)
const
{
return
valIdxes
[
i
].
first
;
}
// Should be called after sort
inline
const
ST
&
operator
[](
int
i
)
const
{
return
structVals
[
valIdxes
[
i
].
second
];
}
// Should be called after sort
inline
VT
&
operator
()(
int
i
)
{
return
valIdxes
[
i
].
first
;
}
// Should be called after sort
inline
ST
&
operator
[](
int
i
)
{
return
structVals
[
valIdxes
[
i
].
second
];
}
// Should be called after sort
void
sort
(
bool
descendOrder
=
true
);
const
std
::
vector
<
ST
>
&
getSortedStructVal
();
std
::
vector
<
std
::
pair
<
VT
,
int
>
>
getvalIdxes
();
void
append
(
const
ValStructVec
<
VT
,
ST
>
&
newVals
,
int
startV
=
0
);
std
::
vector
<
ST
>
structVals
;
// struct values
private
:
int
sz
;
// size of the value struct vector
std
::
vector
<
std
::
pair
<
VT
,
int
>
>
valIdxes
;
// Indexes after sort
bool
smaller
()
{
return
true
;
}
;
std
::
vector
<
ST
>
sortedStructVals
;
};
template
<
typename
VT
,
typename
ST
>
void
ValStructVec
<
VT
,
ST
>::
append
(
const
ValStructVec
<
VT
,
ST
>
&
newVals
,
int
startV
)
{
int
newValsSize
=
newVals
.
size
();
for
(
int
i
=
0
;
i
<
newValsSize
;
i
++
)
pushBack
(
(
float
)
(
(
i
+
300
)
*
startV
),
newVals
[
i
]
);
}
template
<
typename
VT
,
typename
ST
>
void
ValStructVec
<
VT
,
ST
>::
sort
(
bool
descendOrder
/* = true */
)
{
if
(
descendOrder
)
std
::
sort
(
valIdxes
.
begin
(),
valIdxes
.
end
(),
std
::
greater
<
std
::
pair
<
VT
,
int
>
>
()
);
else
std
::
sort
(
valIdxes
.
begin
(),
valIdxes
.
end
(),
std
::
less
<
std
::
pair
<
VT
,
int
>
>
()
);
}
template
<
typename
VT
,
typename
ST
>
const
std
::
vector
<
ST
>&
ValStructVec
<
VT
,
ST
>::
getSortedStructVal
()
{
sortedStructVals
.
resize
(
sz
);
for
(
int
i
=
0
;
i
<
sz
;
i
++
)
sortedStructVals
[
i
]
=
structVals
[
valIdxes
[
i
].
second
];
return
sortedStructVals
;
}
template
<
typename
VT
,
typename
ST
>
std
::
vector
<
std
::
pair
<
VT
,
int
>
>
ValStructVec
<
VT
,
ST
>::
getvalIdxes
()
{
return
valIdxes
;
}
}
/* namespace saliency */
}
/* namespace cv */
#endif //__OPENCV_VAL_STRUCT_VEC_HPP__
modules/saliency/src/kyheader.hpp
deleted
100644 → 0
View file @
255d83ac
/*M///////////////////////////////////////////////////////////////////////////////////////
//
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
//
// By downloading, copying, installing or using the software you agree to this license.
// If you do not agree to this license, do not download, install,
// copy or use the software.
//
//
// License Agreement
// For Open Source Computer Vision Library
//
// Copyright (C) 2014, OpenCV Foundation, all rights reserved.
// Third party copyrights are property of their respective owners.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// * Redistribution's of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// * Redistribution's in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// * The name of the copyright holders may not be used to endorse or promote products
// derived from this software without specific prior written permission.
//
// This software is provided by the copyright holders and contributors "as is" and
// any express or implied warranties, including, but not limited to, the implied
// warranties of merchantability and fitness for a particular purpose are disclaimed.
// In no event shall the Intel Corporation or contributors be liable for any direct,
// indirect, incidental, special, exemplary, or consequential damages
// (including, but not limited to, procurement of substitute goods or services;
// loss of use, data, or profits; or business interruption) however caused
// and on any theory of liability, whether in contract, strict liability,
// or tort (including negligence or otherwise) arising in any way out of
// the use of this software, even if advised of the possibility of such damage.
//
//M*/
#ifndef KYHEADER_H
#define KYHEADER_H
#include <assert.h>
#include <string>
#include <vector>
#include <functional>
#include <list>
#include <algorithm>
#include <iostream>
#include <cmath>
#include <time.h>
#include <fstream>
#include <stdint.h>
//#include <omp.h>
// TODO: reference additional headers your program requires here
//#include "LibLinear/linear.h"
//#include <opencv2/opencv.hpp>
#include "opencv2/core.hpp"
#define CV_VERSION_ID CVAUX_STR(CV_MAJOR_VERSION) CVAUX_STR(CV_MINOR_VERSION) CVAUX_STR(CV_SUBMINOR_VERSION)
#ifdef _DEBUG
#define cvLIB(name) "opencv_" name CV_VERSION_ID "d"
#else
#define cvLIB(name) "opencv_" name CV_VERSION_ID
#endif
//#pragma comment( lib, cvLIB("core"))
//#pragma comment( lib, cvLIB("imgproc"))
//#pragma comment( lib, cvLIB("highgui"))
#ifdef WIN32
/* windows stuff */
#else
typedef
unsigned
long
DWORD
;
typedef
unsigned
short
WORD
;
typedef
unsigned
int
UNINT32
;
typedef
bool
BOOL
;
typedef
void
*
HANDLE
;
#endif
#ifndef _MSC_VER
typedef
unsigned
char
BYTE
;
#else
#include <windows.h>
#endif
namespace
cv
{
namespace
saliency
{
typedef
std
::
vector
<
int
>
vecI
;
typedef
const
std
::
string
CStr
;
typedef
const
cv
::
Mat
CMat
;
typedef
std
::
vector
<
std
::
string
>
vecS
;
typedef
std
::
vector
<
cv
::
Mat
>
vecM
;
typedef
std
::
vector
<
float
>
vecF
;
typedef
std
::
vector
<
double
>
vecD
;
enum
{
CV_FLIP_BOTH
=
-
1
,
CV_FLIP_VERTICAL
=
0
,
CV_FLIP_HORIZONTAL
=
1
};
#define _S(str) ((str).c_str())
#define CHK_IND(p) ((p).x >= 0 && (p).x < _w && (p).y >= 0 && (p).y < _h)
#define CV_Assert_(expr, args) \
{\
if(!(expr)) {\
String msg = cv::format args; \
printf("%s in %s:%d\n", msg.c_str(), __FILE__, __LINE__); \
cv::error(cv::Exception(CV_StsAssert, msg, __FUNCTION__, __FILE__, __LINE__) ); }\
}
// Return -1 if not in the list
template
<
typename
T
>
static
inline
int
findFromList
(
const
T
&
word
,
const
std
::
vector
<
T
>
&
strList
)
{
//TODO delete test code
//cout << "\n\n" << "word" <<" "<< word << endl;
for
(
int
i
=
0
;
i
<
strList
.
size
();
i
++
)
{
//cout <<"test word:"<< word << " " << endl;
//cout << "Size w " << word.size() << " Size L "<< strList[i].size() << endl;
}
std
::
vector
<
cv
::
String
>::
iterator
it
=
std
::
find
(
strList
.
begin
(),
strList
.
end
(),
word
);
if
(
it
==
strList
.
end
()
)
{
return
-
1
;
}
else
{
int
index
=
it
-
strList
.
begin
();
return
index
;
//vector<String>::iterator index = std::distance( strList.begin(), it );
//cout << "index" <<" "<< index << endl;
//return int( index );
}
}
/*template<typename T>
static inline int findFromList(const string &word, const vector<T> &strList) {
//for(int i=0; i<strList.size(); i++){
//cout <<"element: " <<strList[i]<<" "<<word << endl;
//if (std::strcmp(word.c_str(),strList[i].c_str())==0) return i;
}
return -1;
}
*/
template
<
typename
T
>
inline
T
sqr
(
T
x
)
{
return
x
*
x
;
}
// out of range risk for T = byte, ...
template
<
class
T
,
int
D
>
inline
T
vecSqrDist
(
const
cv
::
Vec
<
T
,
D
>
&
v1
,
const
cv
::
Vec
<
T
,
D
>
&
v2
)
{
T
s
=
0
;
for
(
int
i
=
0
;
i
<
D
;
i
++
)
s
+=
sqr
(
v1
[
i
]
-
v2
[
i
]
);
return
s
;
}
// out of range risk for T = byte, ...
template
<
class
T
,
int
D
>
inline
T
vecDist
(
const
cv
::
Vec
<
T
,
D
>
&
v1
,
const
cv
::
Vec
<
T
,
D
>
&
v2
)
{
return
sqrt
(
vecSqrDist
(
v1
,
v2
)
);
}
// out of range risk for T = byte, ...
inline
cv
::
Rect
Vec4i2Rect
(
cv
::
Vec4i
&
v
)
{
return
cv
::
Rect
(
cv
::
Point
(
v
[
0
]
-
1
,
v
[
1
]
-
1
),
cv
::
Point
(
v
[
2
],
v
[
3
]
)
);
}
/*
#ifdef __WIN32
#define INT64 long long
#else
#define INT64 long
typedef unsigned long UINT64_;
//#define UINT64 unsigned long
#endif
*/
#if defined(_MSC_VER)
# include <intrin.h>
# define POPCNT(x) __popcnt(x)
# define POPCNT64(x) __popcnt64(x)
#endif
#if defined(__GNUC__)
# define POPCNT(x) __builtin_popcount(x)
# define POPCNT64(x) __builtin_popcountll(x)
#endif
inline
int
popcnt64
(
register
uint64_t
u
)
{
u
=
(
u
&
0x5555555555555555
)
+
(
(
u
>>
1
)
&
0x5555555555555555
);
u
=
(
u
&
0x3333333333333333
)
+
(
(
u
>>
2
)
&
0x3333333333333333
);
u
=
(
u
&
0x0f0f0f0f0f0f0f0f
)
+
(
(
u
>>
4
)
&
0x0f0f0f0f0f0f0f0f
);
u
=
(
u
&
0x00ff00ff00ff00ff
)
+
(
(
u
>>
8
)
&
0x00ff00ff00ff00ff
);
u
=
(
u
&
0x0000ffff0000ffff
)
+
(
(
u
>>
16
)
&
0x0000ffff0000ffff
);
u
=
(
u
&
0x00000000ffffffff
)
+
(
(
u
>>
32
)
&
0x00000000ffffffff
);
return
(
int
)
u
;
}
inline
int
popcnt
(
register
uint32_t
u
)
{
u
=
(
u
&
0x55555555
)
+
(
(
u
>>
1
)
&
0x55555555
);
u
=
(
u
&
0x33333333
)
+
(
(
u
>>
2
)
&
0x33333333
);
u
=
(
u
&
0x0f0f0f0f
)
+
(
(
u
>>
4
)
&
0x0f0f0f0f
);
u
=
(
u
&
0x00ff00ff
)
+
(
(
u
>>
8
)
&
0x00ff00ff
);
u
=
(
u
&
0x0000ffff
)
+
(
(
u
>>
16
)
&
0x0000ffff
);
return
(
int
)
u
;
}
inline
int
popcnt64_nibble
(
register
uint64_t
u
)
{
static
const
uint8_t
Table
[]
=
{
0
,
1
,
1
,
2
,
1
,
2
,
2
,
3
,
1
,
2
,
2
,
3
,
2
,
3
,
3
,
4
};
int
c
=
0
;
while
(
u
)
{
c
+=
Table
[
u
&
0xf
];
u
>>=
4
;
}
return
(
int
)
c
;
}
inline
int
popcnt_nibble
(
register
uint32_t
u
)
{
static
const
uint8_t
Table
[]
=
{
0
,
1
,
1
,
2
,
1
,
2
,
2
,
3
,
1
,
2
,
2
,
3
,
2
,
3
,
3
,
4
};
int
c
=
0
;
while
(
u
)
{
c
+=
Table
[
u
&
0xf
];
u
>>=
4
;
}
return
(
int
)
c
;
}
inline
int
popcnt64_byte
(
register
uint64_t
u
)
{
#define B2(k) k, k+1, k+1, k+2
#define B4(k) B2(k), B2(k+1), B2(k+1), B2(k+2)
#define B6(k) B4(k), B4(k+1), B4(k+1), B4(k+2)
static
const
uint8_t
Table
[]
=
{
B6
(
0
),
B6
(
1
),
B6
(
1
),
B6
(
2
)
};
#undef B6
#undef B4
#undef B2
int
c
=
0
;
while
(
u
)
{
c
+=
Table
[
u
&
0xff
];
u
>>=
8
;
}
return
(
int
)
c
;
}
inline
int
popcnt_byte
(
register
uint32_t
u
)
{
#define B2(k) k, k+1, k+1, k+2
#define B4(k) B2(k), B2(k+1), B2(k+1), B2(k+2)
#define B6(k) B4(k), B4(k+1), B4(k+1), B4(k+2)
static
const
uint8_t
Table
[]
=
{
B6
(
0
),
B6
(
1
),
B6
(
1
),
B6
(
2
)
};
#undef B6
#undef B4
#undef B2
int
c
=
0
;
while
(
u
)
{
c
+=
Table
[
u
&
0xff
];
u
>>=
8
;
}
return
(
int
)
c
;
}
}
}
/////
#endif // KYHEADER_H
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment