OpenCV
3.0.0-rc1
Open Source Computer Vision
|
Modules | |
NEON utilities | |
Namespaces | |
cv | |
cv::Error | |
Classes | |
class | cv::Allocator< _Tp > |
class | cv::AutoBuffer< _Tp, fixed_size > |
Automatically Allocated Buffer Class. More... | |
class | cv::AutoLock |
class | cv::CommandLineParser |
designed for command line arguments parsing More... | |
class | cv::Exception |
Class passed to an error. More... | |
struct | cv::Hamming |
class | cv::Mutex |
class | cv::ParallelLoopBody |
Base class for parallel data processors. More... | |
class | cv::TLSData< T > |
class | cv::TLSDataContainer |
Macros | |
#define | CV_Assert(expr) if(!!(expr)) ; else cv::error( cv::Error::StsAssert, #expr, CV_Func, __FILE__, __LINE__ ) |
Checks a condition at runtime and throws exception if it fails. More... | |
#define | CV_DbgAssert(expr) |
#define | CV_Error(code, msg) cv::error( code, msg, CV_Func, __FILE__, __LINE__ ) |
Call the error handler. More... | |
#define | CV_Error_(code, args) cv::error( code, cv::format args, CV_Func, __FILE__, __LINE__ ) |
Call the error handler. More... | |
#define | CV_ErrorNoReturn(code, msg) cv::errorNoReturn( code, msg, CV_Func, __FILE__, __LINE__ ) |
#define | CV_ErrorNoReturn_(code, args) cv::errorNoReturn( code, cv::format args, CV_Func, __FILE__, __LINE__ ) |
#define | CV_Func "" |
Typedefs | |
typedef int(* | cv::ErrorCallback )(int status, const char *func_name, const char *err_msg, const char *file_name, int line, void *userdata) |
typedef Hamming | cv::HammingLUT |
Enumerations | |
enum | cv::CpuFeatures { cv::CPU_MMX = 1, cv::CPU_SSE = 2, cv::CPU_SSE2 = 3, cv::CPU_SSE3 = 4, cv::CPU_SSSE3 = 5, cv::CPU_SSE4_1 = 6, cv::CPU_SSE4_2 = 7, cv::CPU_POPCNT = 8, cv::CPU_AVX = 10, cv::CPU_AVX2 = 11, cv::CPU_FMA3 = 12, cv::CPU_AVX_512F = 13, cv::CPU_AVX_512BW = 14, cv::CPU_AVX_512CD = 15, cv::CPU_AVX_512DQ = 16, cv::CPU_AVX_512ER = 17, cv::CPU_AVX_512IFMA512 = 18, cv::CPU_AVX_512PF = 19, cv::CPU_AVX_512VBMI = 20, cv::CPU_AVX_512VL = 21, cv::CPU_NEON = 100 } |
Available CPU features. More... | |
enum | cv::SortFlags { cv::SORT_EVERY_ROW = 0, cv::SORT_EVERY_COLUMN = 1, cv::SORT_ASCENDING = 0, cv::SORT_DESCENDING = 16 } |
Functions | |
template<typename _Tp > | |
static _Tp * | cv::alignPtr (_Tp *ptr, int n=(int) sizeof(_Tp)) |
Aligns a pointer to the specified number of bytes. More... | |
static size_t | cv::alignSize (size_t sz, int n) |
Aligns a buffer size to the specified number of bytes. More... | |
bool | cv::checkHardwareSupport (int feature) |
Returns true if the specified feature is supported by the host hardware. More... | |
float | cv::cubeRoot (float val) |
Computes the cube root of an argument. More... | |
template<typename _Tp > | |
_Tp | cv::cv_abs (_Tp x) |
int | cv::cv_abs (uchar x) |
int | cv::cv_abs (schar x) |
int | cv::cv_abs (ushort x) |
int | cv::cv_abs (short x) |
int | cvCeil (double value) |
Rounds floating-point number to the nearest integer not larger than the original. More... | |
int | cvCeil (float value) |
int | cvCeil (int value) |
int | cvFloor (double value) |
Rounds floating-point number to the nearest integer not larger than the original. More... | |
int | cvFloor (float value) |
int | cvFloor (int value) |
int | cvIsInf (double value) |
Determines if the argument is Infinity. More... | |
int | cvIsInf (float value) |
int | cvIsNaN (double value) |
Determines if the argument is Not A Number. More... | |
int | cvIsNaN (float value) |
int | cvRound (double value) |
Rounds floating-point number to the nearest integer. More... | |
int | cvRound (float value) |
int | cvRound (int value) |
void | cv::error (const Exception &exc) |
Signals an error and raises the exception. More... | |
void | cv::error (int _code, const String &_err, const char *_func, const char *_file, int _line) |
Signals an error and raises the exception. More... | |
void | cv::errorNoReturn (int _code, const String &_err, const char *_func, const char *_file, int _line) |
float | cv::fastAtan2 (float y, float x) |
Calculates the angle of a 2D vector in degrees. More... | |
void | cv::fastFree (void *ptr) |
Deallocates a memory buffer. More... | |
void * | cv::fastMalloc (size_t bufSize) |
Allocates an aligned memory buffer. More... | |
template<typename _Tp , typename Functor > | |
void | cv::Mat::forEach_impl (const Functor &operation) |
String | cv::format (const char *fmt,...) |
Returns a text string formatted using the printf-like expression. More... | |
const String & | cv::getBuildInformation () |
Returns full configuration time cmake output. More... | |
int64 | cv::getCPUTickCount () |
Returns the number of CPU ticks. More... | |
static size_t | cv::getElemSize (int type) |
int | cv::getNumberOfCPUs () |
Returns the number of logical CPUs available for the process. More... | |
int | cv::getNumThreads () |
Returns the number of threads used by OpenCV for parallel regions. More... | |
int | cv::getThreadNum () |
Returns the index of the currently executed thread within the current parallel region. Always returns 0 if called outside of parallel region. More... | |
int64 | cv::getTickCount () |
Returns the number of ticks. More... | |
double | cv::getTickFrequency () |
Returns the number of ticks per second. More... | |
void | cv::glob (String pattern, std::vector< String > &result, bool recursive=false) |
template<typename _Tp , typename _AccTp > | |
static _AccTp | cv::normInf (const _Tp *a, int n) |
template<typename _Tp , typename _AccTp > | |
static _AccTp | cv::normInf (const _Tp *a, const _Tp *b, int n) |
template<typename _Tp , typename _AccTp > | |
static _AccTp | cv::normL1 (const _Tp *a, int n) |
template<typename _Tp , typename _AccTp > | |
static _AccTp | cv::normL1 (const _Tp *a, const _Tp *b, int n) |
float | cv::normL1 (const float *a, const float *b, int n) |
int | cv::normL1 (const uchar *a, const uchar *b, int n) |
template<typename _Tp , typename _AccTp > | |
static _AccTp | cv::normL2Sqr (const _Tp *a, int n) |
template<typename _Tp , typename _AccTp > | |
static _AccTp | cv::normL2Sqr (const _Tp *a, const _Tp *b, int n) |
float | cv::normL2Sqr (const float *a, const float *b, int n) |
void | cv::parallel_for_ (const Range &range, const ParallelLoopBody &body, double nstripes=-1.) |
Parallel data processor. More... | |
ErrorCallback | cv::redirectError (ErrorCallback errCallback, void *userdata=0, void **prevUserdata=0) |
Sets the new error handler and the optional user data. More... | |
bool | cv::setBreakOnError (bool flag) |
Sets/resets the break-on-error mode. More... | |
void | cv::setNumThreads (int nthreads) |
OpenCV will try to set the number of threads for the next parallel region. More... | |
void | cv::setUseOptimized (bool onoff) |
Enables or disables the optimized code. More... | |
String | cv::tempfile (const char *suffix=0) |
bool | cv::useOptimized () |
Returns the status of optimized code usage. More... | |
#define CV_Assert | ( | expr | ) | if(!!(expr)) ; else cv::error( cv::Error::StsAssert, #expr, CV_Func, __FILE__, __LINE__ ) |
Checks a condition at runtime and throws exception if it fails.
The macros CV_Assert (and CV_DbgAssert(expr)) evaluate the specified expression. If it is 0, the macros raise an error (see cv::error). The macro CV_Assert checks the condition in both Debug and Release configurations while CV_DbgAssert is only retained in the Debug configuration.
#define CV_DbgAssert | ( | expr | ) |
replaced with CV_Assert(expr) in Debug configuration
Call the error handler.
Currently, the error handler prints the error code and the error message to the standard error stream stderr
. In the Debug configuration, it then provokes memory access violation, so that the execution stack and all the parameters can be analyzed by the debugger. In the Release configuration, the exception is thrown.
code | one of Error::Code |
msg | error message |
#define CV_Error_ | ( | code, | |
args | |||
) | cv::error( code, cv::format args, CV_Func, __FILE__, __LINE__ ) |
Call the error handler.
This macro can be used to construct an error message on-fly to include some dynamic information, for example:
code | one of Error::Code |
args | printf-like formatted error message in parentheses |
#define CV_ErrorNoReturn | ( | code, | |
msg | |||
) | cv::errorNoReturn( code, msg, CV_Func, __FILE__, __LINE__ ) |
same as CV_Error(code,msg), but does not return
#define CV_ErrorNoReturn_ | ( | code, | |
args | |||
) | cv::errorNoReturn( code, cv::format args, CV_Func, __FILE__, __LINE__ ) |
same as CV_Error_(code,args), but does not return
#define CV_Func "" |
typedef int(* cv::ErrorCallback)(int status, const char *func_name, const char *err_msg, const char *file_name, int line, void *userdata) |
typedef Hamming cv::HammingLUT |
enum cv::CpuFeatures |
Available CPU features.
remember to keep this list identical to the one in cvdef.h
enum cv::SortFlags |
|
inlinestatic |
Aligns a pointer to the specified number of bytes.
The function returns the aligned pointer of the same type as the input pointer:
\[\texttt{(\_Tp*)(((size\_t)ptr + n-1) \& -n)}\]
ptr | Aligned pointer. |
n | Alignment size that must be a power of two. |
Aligns a buffer size to the specified number of bytes.
The function returns the minimum number that is greater or equal to sz and is divisible by n :
\[\texttt{(sz + n-1) \& -n}\]
sz | Buffer size to align. |
n | Alignment size that must be a power of two. |
bool cv::checkHardwareSupport | ( | int | feature | ) |
Returns true if the specified feature is supported by the host hardware.
The function returns true if the host hardware supports the specified feature. When user calls setUseOptimized(false), the subsequent calls to checkHardwareSupport() will return false until setUseOptimized(true) is called. This way user can dynamically switch on and off the optimized code in OpenCV.
feature | The feature of interest, one of cv::CpuFeatures |
float cv::cubeRoot | ( | float | val | ) |
Computes the cube root of an argument.
The function cubeRoot computes \(\sqrt[3]{\texttt{val}}\). Negative arguments are handled correctly. NaN and Inf are not handled. The accuracy approaches the maximum possible accuracy for single-precision data.
val | A function argument. |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
int cvCeil | ( | double | value | ) |
Rounds floating-point number to the nearest integer not larger than the original.
The function computes an integer i such that:
\[i \le \texttt{value} < i+1\]
value | floating-point number. If the value is outside of INT_MIN ... INT_MAX range, the result is not defined. |
int cvCeil | ( | float | value | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
int cvCeil | ( | int | value | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
int cvFloor | ( | double | value | ) |
Rounds floating-point number to the nearest integer not larger than the original.
The function computes an integer i such that:
\[i \le \texttt{value} < i+1\]
value | floating-point number. If the value is outside of INT_MIN ... INT_MAX range, the result is not defined. |
int cvFloor | ( | float | value | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
int cvFloor | ( | int | value | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
int cvIsInf | ( | double | value | ) |
Determines if the argument is Infinity.
value | The input floating-point value |
The function returns 1 if the argument is a plus or minus infinity (as defined by IEEE754 standard) and 0 otherwise.
int cvIsInf | ( | float | value | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
int cvIsNaN | ( | double | value | ) |
Determines if the argument is Not A Number.
value | The input floating-point value |
The function returns 1 if the argument is Not A Number (as defined by IEEE754 standard), 0 otherwise.
int cvIsNaN | ( | float | value | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
int cvRound | ( | double | value | ) |
Rounds floating-point number to the nearest integer.
value | floating-point number. If the value is outside of INT_MIN ... INT_MAX range, the result is not defined. |
int cvRound | ( | float | value | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
int cvRound | ( | int | value | ) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
void cv::error | ( | const Exception & | exc | ) |
Signals an error and raises the exception.
By default the function prints information about the error to stderr, then it either stops if cv::setBreakOnError() had been called before or raises the exception. It is possible to alternate error processing by using cv::redirectError().
exc | the exception raisen. |
void cv::error | ( | int | _code, |
const String & | _err, | ||
const char * | _func, | ||
const char * | _file, | ||
int | _line | ||
) |
Signals an error and raises the exception.
By default the function prints information about the error to stderr, then it either stops if setBreakOnError() had been called before or raises the exception. It is possible to alternate error processing by using redirectError().
_code | - error code (Error::Code) |
_err | - error description |
_func | - function name. Available only when the compiler supports getting it |
_file | - source file name where the error has occured |
_line | - line number in the source file where the error has occured |
void cv::errorNoReturn | ( | int | _code, |
const String & | _err, | ||
const char * | _func, | ||
const char * | _file, | ||
int | _line | ||
) |
same as cv::error, but does not return
float cv::fastAtan2 | ( | float | y, |
float | x | ||
) |
Calculates the angle of a 2D vector in degrees.
The function fastAtan2 calculates the full-range angle of an input 2D vector. The angle is measured in degrees and varies from 0 to 360 degrees. The accuracy is about 0.3 degrees.
x | x-coordinate of the vector. |
y | y-coordinate of the vector. |
void cv::fastFree | ( | void * | ptr | ) |
Deallocates a memory buffer.
The function deallocates the buffer allocated with fastMalloc . If NULL pointer is passed, the function does nothing. C version of the function clears the pointer pptr to avoid problems with double memory deallocation.
ptr | Pointer to the allocated buffer. |
void* cv::fastMalloc | ( | size_t | bufSize | ) |
Allocates an aligned memory buffer.
The function allocates the buffer of the specified size and returns it. When the buffer size is 16 bytes or more, the returned buffer is aligned to 16 bytes.
bufSize | Allocated buffer size. |
|
inlineprotected |
idx is modified in this->rowCall
String cv::format | ( | const char * | fmt, |
... | |||
) |
Returns a text string formatted using the printf-like expression.
The function acts like sprintf but forms and returns an STL string. It can be used to form an error message in the Exception constructor.
fmt | printf-compatible formatting specifiers. |
const String& cv::getBuildInformation | ( | ) |
Returns full configuration time cmake output.
Returned value is raw cmake output including version control system revision, compiler version, compiler flags, enabled modules and third party libraries, etc. Output format depends on target architecture.
int64 cv::getCPUTickCount | ( | ) |
Returns the number of CPU ticks.
The function returns the current number of CPU ticks on some architectures (such as x86, x64, PowerPC). On other platforms the function is equivalent to getTickCount. It can also be used for very accurate time measurements, as well as for RNG initialization. Note that in case of multi-CPU systems a thread, from which getCPUTickCount is called, can be suspended and resumed at another CPU with its own counter. So, theoretically (and practically) the subsequent calls to the function do not necessary return the monotonously increasing values. Also, since a modern CPU varies the CPU frequency depending on the load, the number of CPU clocks spent in some code cannot be directly converted to time units. Therefore, getTickCount is generally a preferable solution for measuring execution time.
|
inlinestatic |
int cv::getNumberOfCPUs | ( | ) |
Returns the number of logical CPUs available for the process.
int cv::getNumThreads | ( | ) |
Returns the number of threads used by OpenCV for parallel regions.
Always returns 1 if OpenCV is built without threading support.
The exact meaning of return value depends on the threading framework used by OpenCV library:
TBB
– The number of threads, that OpenCV will try to use for parallel regions. If there is any tbb::thread_scheduler_init in user code conflicting with OpenCV, then function returns default number of threads used by TBB library.OpenMP
– An upper bound on the number of threads that could be used to form a new team.Concurrency
– The number of threads, that OpenCV will try to use for parallel regions.GCD
– Unsupported; returns the GCD thread pool limit (512) for compatibility.C=
– The number of threads, that OpenCV will try to use for parallel regions, if before called setNumThreads with threads > 0, otherwise returns the number of logical CPUs, available for the process. int cv::getThreadNum | ( | ) |
Returns the index of the currently executed thread within the current parallel region. Always returns 0 if called outside of parallel region.
The exact meaning of return value depends on the threading framework used by OpenCV library:
TBB
– Unsupported with current 4.1 TBB release. May be will be supported in future.OpenMP
– The thread number, within the current team, of the calling thread.Concurrency
– An ID for the virtual processor that the current context is executing on (0 for master thread and unique number for others, but not necessary 1,2,3,...).GCD
– System calling thread's ID. Never returns 0 inside parallel region.C=
– The index of the current parallel task. int64 cv::getTickCount | ( | ) |
Returns the number of ticks.
The function returns the number of ticks after the certain event (for example, when the machine was turned on). It can be used to initialize RNG or to measure a function execution time by reading the tick count before and after the function call. See also the tick frequency.
double cv::getTickFrequency | ( | ) |
Returns the number of ticks per second.
The function returns the number of ticks per second. That is, the following code computes the execution time in seconds:
void cv::glob | ( | String | pattern, |
std::vector< String > & | result, | ||
bool | recursive = false |
||
) |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inline |
|
inlinestatic |
|
inlinestatic |
|
inline |
void cv::parallel_for_ | ( | const Range & | range, |
const ParallelLoopBody & | body, | ||
double | nstripes = -1. |
||
) |
Parallel data processor.
ErrorCallback cv::redirectError | ( | ErrorCallback | errCallback, |
void * | userdata = 0 , |
||
void ** | prevUserdata = 0 |
||
) |
Sets the new error handler and the optional user data.
The function sets the new error handler, called from cv::error().
errCallback | the new error handler. If NULL, the default error handler is used. |
userdata | the optional user data pointer, passed to the callback. |
prevUserdata | the optional output parameter where the previous user data pointer is stored |
bool cv::setBreakOnError | ( | bool | flag | ) |
Sets/resets the break-on-error mode.
When the break-on-error mode is set, the default error handler issues a hardware exception, which can make debugging more convenient.
void cv::setNumThreads | ( | int | nthreads | ) |
OpenCV will try to set the number of threads for the next parallel region.
If threads == 0, OpenCV will disable threading optimizations and run all it's functions sequentially. Passing threads < 0 will reset threads number to system default. This function must be called outside of parallel region.
OpenCV will try to run it's functions with specified threads number, but some behaviour differs from framework:
TBB
– User-defined parallel constructions will run with the same threads number, if another does not specified. If late on user creates own scheduler, OpenCV will be use it.OpenMP
– No special defined behaviour.Concurrency
– If threads == 1, OpenCV will disable threading optimizations and run it's functions sequentially.GCD
– Supports only values <= 0.C=
– No special defined behaviour. nthreads | Number of threads used by OpenCV. |
void cv::setUseOptimized | ( | bool | onoff | ) |
Enables or disables the optimized code.
The function can be used to dynamically turn on and off optimized code (code that uses SSE2, AVX, and other instructions on the platforms that support it). It sets a global flag that is further checked by OpenCV functions. Since the flag is not checked in the inner OpenCV loops, it is only safe to call the function on the very top level in your application where you can be sure that no other OpenCV function is currently executed.
By default, the optimized code is enabled unless you disable it in CMake. The current status can be retrieved using useOptimized.
onoff | The boolean flag specifying whether the optimized code should be used (onoff=true) or not (onoff=false). |
String cv::tempfile | ( | const char * | suffix = 0 | ) |
bool cv::useOptimized | ( | ) |
Returns the status of optimized code usage.
The function returns true if the optimized code is enabled. Otherwise, it returns false.