![]() |
OpenCV
4.1.2
Open Source Computer Vision
|
Classes | |
struct | cv::softdouble |
struct | cv::softfloat |
Variables | |
uint32_t | cv::softfloat::v |
uint64_t | cv::softdouble::v |
SoftFloat is a software implementation of floating-point calculations according to IEEE 754 standard. All calculations are done in integers, that's why they are machine-independent and bit-exact. This library can be useful in accuracy-critical parts like look-up tables generation, tests, etc. OpenCV contains a subset of SoftFloat partially rewritten to C++.
There are two basic types: softfloat and softdouble. These types are binary compatible with float and double types respectively and support conversions to/from them. Other types from original SoftFloat library like fp16 or fp128 were thrown away as well as quiet/signaling NaN support, on-the-fly rounding mode switch and exception flags (though exceptions can be implemented in the future).
Both types support the following:
|
inline |
#include <opencv2/core/softfloat.hpp>
Default constructor.
|
inline |
#include <opencv2/core/softfloat.hpp>
Copy constructor.
|
explicit |
#include <opencv2/core/softfloat.hpp>
Construct from integer.
|
explicit |
#include <opencv2/core/softfloat.hpp>
|
explicit |
#include <opencv2/core/softfloat.hpp>
|
explicit |
#include <opencv2/core/softfloat.hpp>
|
inlineexplicit |
#include <opencv2/core/softfloat.hpp>
Construct from double.
|
inline |
#include <opencv2/core/softfloat.hpp>
Default constructor.
|
inline |
#include <opencv2/core/softfloat.hpp>
Copy constructor.
|
explicit |
#include <opencv2/core/softfloat.hpp>
Construct from integer.
|
explicit |
#include <opencv2/core/softfloat.hpp>
|
explicit |
#include <opencv2/core/softfloat.hpp>
|
explicit |
#include <opencv2/core/softfloat.hpp>
|
inlineexplicit |
#include <opencv2/core/softfloat.hpp>
Construct from float.
#include <opencv2/core/softfloat.hpp>
Absolute value.
|
inline |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
Cube root.
Special cases:
softdouble cv::cos | ( | const softdouble & | a | ) |
#include <opencv2/core/softfloat.hpp>
Cosine.
Special cases:
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Difference between 1 and next representable value.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Difference between 1 and next representable value.
#include <opencv2/core/softfloat.hpp>
Exponent.
Special cases:
softdouble cv::exp | ( | const softdouble & | a | ) |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
Construct from raw.
Builds new value from raw binary representation
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Construct from raw.
Builds new value from raw binary representation
|
inline |
#include <opencv2/core/softfloat.hpp>
Get 0-based exponent.
|
inline |
#include <opencv2/core/softfloat.hpp>
Get 0-based exponent.
|
inline |
#include <opencv2/core/softfloat.hpp>
Get a fraction part.
Returns a number 1 <= x < 2 with the same significand
|
inline |
#include <opencv2/core/softfloat.hpp>
Get a fraction part.
Returns a number 1 <= x < 2 with the same significand
|
inline |
#include <opencv2/core/softfloat.hpp>
Get sign bit.
|
inline |
#include <opencv2/core/softfloat.hpp>
Get sign bit.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Positive infinity constant.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Positive infinity constant.
|
inline |
#include <opencv2/core/softfloat.hpp>
Inf state indicator.
|
inline |
#include <opencv2/core/softfloat.hpp>
Inf state indicator.
|
inline |
#include <opencv2/core/softfloat.hpp>
NaN state indicator.
|
inline |
#include <opencv2/core/softfloat.hpp>
NaN state indicator.
|
inline |
#include <opencv2/core/softfloat.hpp>
Subnormal number indicator.
|
inline |
#include <opencv2/core/softfloat.hpp>
Subnormal number indicator.
#include <opencv2/core/softfloat.hpp>
Natural logarithm.
Special cases:
softdouble cv::log | ( | const softdouble & | a | ) |
#include <opencv2/core/softfloat.hpp>
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Biggest finite value.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Biggest finite value.
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Smallest normalized value.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Smallest normalized value.
#include <opencv2/core/softfloat.hpp>
Min and Max functions.
|
inline |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
Fused Multiplication and Addition.
Computes (a*b)+c with single rounding
softdouble cv::mulAdd | ( | const softdouble & | a, |
const softdouble & | b, | ||
const softdouble & | c | ||
) |
#include <opencv2/core/softfloat.hpp>
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Default NaN constant.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Default NaN constant.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
One constant.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
One constant.
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
cv::softfloat::operator softdouble | ( | ) | const |
#include <opencv2/core/softfloat.hpp>
Type casts.
cv::softdouble::operator softfloat | ( | ) | const |
#include <opencv2/core/softfloat.hpp>
Type casts.
bool cv::softfloat::operator!= | ( | const softfloat & | ) | const |
#include <opencv2/core/softfloat.hpp>
bool cv::softdouble::operator!= | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
Remainder operator.
A quote from original SoftFloat manual:
The IEEE Standard remainder operation computes the value a - n * b, where n is the integer closest to a / b. If a / b is exactly halfway between two integers, n is the even integer closest to a / b. The IEEE Standard’s remainder operation is always exact and so requires no rounding. Depending on the relative magnitudes of the operands, the remainder functions can take considerably longer to execute than the other SoftFloat functions. This is an inherent characteristic of the remainder operation itself and is not a flaw in the SoftFloat implementation.
softdouble cv::softdouble::operator% | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
Remainder operator.
A quote from original SoftFloat manual:
The IEEE Standard remainder operation computes the value a - n * b, where n is the integer closest to a / b. If a / b is exactly halfway between two integers, n is the even integer closest to a / b. The IEEE Standard’s remainder operation is always exact and so requires no rounding. Depending on the relative magnitudes of the operands, the remainder functions can take considerably longer to execute than the other SoftFloat functions. This is an inherent characteristic of the remainder operation itself and is not a flaw in the SoftFloat implementation.
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
softdouble cv::softdouble::operator* | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
Basic arithmetics.
softdouble cv::softdouble::operator+ | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
Basic arithmetics.
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
softdouble cv::softdouble::operator- | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
softdouble cv::softdouble::operator/ | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
bool cv::softfloat::operator< | ( | const softfloat & | ) | const |
#include <opencv2/core/softfloat.hpp>
bool cv::softdouble::operator< | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
bool cv::softfloat::operator<= | ( | const softfloat & | ) | const |
#include <opencv2/core/softfloat.hpp>
bool cv::softdouble::operator<= | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
#include <opencv2/core/softfloat.hpp>
Assign constructor.
|
inline |
#include <opencv2/core/softfloat.hpp>
Assign constructor.
bool cv::softfloat::operator== | ( | const softfloat & | ) | const |
#include <opencv2/core/softfloat.hpp>
Comparison operations.
bool cv::softdouble::operator== | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
Comparison operations.
bool cv::softfloat::operator> | ( | const softfloat & | ) | const |
#include <opencv2/core/softfloat.hpp>
bool cv::softdouble::operator> | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
bool cv::softfloat::operator>= | ( | const softfloat & | ) | const |
#include <opencv2/core/softfloat.hpp>
bool cv::softdouble::operator>= | ( | const softdouble & | ) | const |
#include <opencv2/core/softfloat.hpp>
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Correct pi approximation.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Correct pi approximation.
#include <opencv2/core/softfloat.hpp>
Raising to the power.
Special cases:
softdouble cv::pow | ( | const softdouble & | a, |
const softdouble & | b | ||
) |
#include <opencv2/core/softfloat.hpp>
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Saturate casts.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
Saturate cast to unsigned integer and unsigned long long integer We intentionally do not clip negative numbers, to make -1 become 0xffffffff etc.
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
|
inline |
#include <opencv2/core/softfloat.hpp>
Construct a copy with new 0-based exponent.
|
inline |
#include <opencv2/core/softfloat.hpp>
Construct a copy with new 0-based exponent.
#include <opencv2/core/softfloat.hpp>
Construct a copy with provided significand.
Constructs a copy of a number with significand taken from parameter
|
inline |
#include <opencv2/core/softfloat.hpp>
Construct a copy with provided significand.
Constructs a copy of a number with significand taken from parameter
|
inline |
#include <opencv2/core/softfloat.hpp>
Construct a copy with new sign bit.
|
inline |
#include <opencv2/core/softfloat.hpp>
Construct a copy with new sign bit.
softdouble cv::sin | ( | const softdouble & | a | ) |
#include <opencv2/core/softfloat.hpp>
Sine.
Special cases:
#include <opencv2/core/softfloat.hpp>
Square root.
softdouble cv::sqrt | ( | const softdouble & | a | ) |
#include <opencv2/core/softfloat.hpp>
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Zero constant.
|
inlinestatic |
#include <opencv2/core/softfloat.hpp>
Zero constant.
uint32_t cv::softfloat::v |
uint64_t cv::softdouble::v |