Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Python build improvements #1316

Merged
merged 52 commits into from
Mar 19, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
52 commits
Select commit Hold shift + click to select a range
0f6aff5
Exclude _visp python target from all to avoid unnecessary build
SamFlt Jan 23, 2024
ac810a6
Update doc with error message
SamFlt Jan 23, 2024
26f73f3
fix uninitialized variables warning
SamFlt Jan 24, 2024
c882eb7
Force python to be inside a virtualenv
SamFlt Jan 24, 2024
420d0bd
disable vpAROgre bindings generation
SamFlt Jan 24, 2024
75deb42
tentative at improving system python rejection (avoid caching, still …
SamFlt Jan 26, 2024
849093e
Update Python retrieval for newer cmake versions, update eror message…
SamFlt Jan 29, 2024
a4db960
Remove mu character '\u03bc' that breaks python bindings
fspindle Feb 2, 2024
2197587
Add new defines for python bindings on Windows
fspindle Feb 2, 2024
ac8e4b0
Ignore Windows subclasses for display, fix some MSVC issues in bindings
SamFlt Feb 2, 2024
e628909
fix remaining ssize_t errors for MSVC
SamFlt Feb 2, 2024
31e0650
Fix doc strings that are too long and generate error on windows
SamFlt Feb 2, 2024
dc5e172
Fix missing symbols for vpDisplayWin32
SamFlt Feb 5, 2024
8f9af8a
Fix MSVC linkage errors due to VISP_EXPORT on header only class
SamFlt Feb 5, 2024
b4c373d
remove default values in vpDisplayWin32.cpp
SamFlt Feb 5, 2024
3e98c2d
Merge remote-tracking branch 'upstream/master' into python_build_impr…
SamFlt Feb 5, 2024
1ca7cc0
Use friend inline (instead of inline friend) required by the python b…
fspindle Feb 7, 2024
760d7e0
automatically replace inline friend with friend inline when parsing h…
SamFlt Feb 7, 2024
f75c627
fix partial name resolution only having one iteration
SamFlt Feb 7, 2024
476ee4c
fix link error with static variables of vpCircleHoughTransform
SamFlt Feb 7, 2024
1bb83fd
Fix stubs generator not running in windows
SamFlt Feb 7, 2024
cb7e32f
remove using namespace std that clashed with MSVC byte declaration, c…
SamFlt Feb 12, 2024
d6259c3
remove using json=nlohmann::json from header files to avoid pollution
SamFlt Feb 12, 2024
e660431
Merge branch 'python_build_improvements' of github.com:SamFlt/visp in…
SamFlt Feb 12, 2024
e5af3cc
Add check for cxx standard, add VISP_EXPORT macro in front of generat…
SamFlt Feb 13, 2024
3353f2c
remove unneeded visp_export
SamFlt Feb 14, 2024
a90d779
Merge remote-tracking branch 'upstream/master' into python_build_impr…
SamFlt Feb 14, 2024
b69c570
Fix missing vp_deprecated, winsock2.h missing includes, vpFrameGrabbe…
fspindle Feb 15, 2024
b13795f
remove useless bindings.py file
SamFlt Feb 15, 2024
ef5fc40
Merge branch 'python_build_improvements' of github.com:SamFlt/visp in…
SamFlt Feb 15, 2024
7e676f5
seeking core visp libraries for potential copy, only display for now
SamFlt Feb 15, 2024
9ce351e
add to runtime_output_directory
SamFlt Feb 20, 2024
0d0ecc1
Importing python bindings works when using conda in windows thanks to…
SamFlt Feb 26, 2024
434b208
Remove getForceTorqueAsync() that was declared but not defined
fspindle Feb 26, 2024
44cd2dc
Ability to split configuration for a module into multiple files, a lo…
SamFlt Feb 27, 2024
84e15e1
More configuration, finish up image conversions, template expansion f…
SamFlt Feb 27, 2024
27c431b
more configuration for core module bindings
SamFlt Feb 28, 2024
2b8fc3f
finish conversions, cleaning core module config
SamFlt Feb 28, 2024
39d0110
rename file with invalid naming convention
SamFlt Mar 11, 2024
f122084
Fix bindings build on python 3.8
SamFlt Mar 11, 2024
e6fe88b
Logging for CI bug with headers coming from multiple folders
SamFlt Mar 11, 2024
3d954fa
Fix attempt for CI failing with assert, Add cmake target for Python b…
SamFlt Mar 11, 2024
36ad312
Fix operators generation and logging, clean up lambda for ops
SamFlt Mar 11, 2024
e73843c
Attempt at fixing failing test on conda ci
SamFlt Mar 12, 2024
3ce7b01
some config, add n-ary operators (mostly vpImage)
SamFlt Mar 12, 2024
5ebfa01
fix method parameters constness, mark some methods as const
SamFlt Mar 12, 2024
acc2327
Some more configuration
SamFlt Mar 12, 2024
a1f1fea
Fix visp_python_bindings build error in vpImageTools.h around lerp()
fspindle Mar 13, 2024
691b91b
Merge remote-tracking branch 'upstream/master' into python_build_impr…
SamFlt Mar 14, 2024
d1c1ab0
Fix static const variable initialized in header file
SamFlt Mar 14, 2024
3f12f69
add dll tracing script, rework VISP_WINDOWS_DLL_PATH variable
SamFlt Mar 14, 2024
aea0103
Move generated .so/.pyd file to visp folder: _visp becomes visp._visp…
SamFlt Mar 15, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
109 changes: 86 additions & 23 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -269,39 +269,93 @@ endif()

# --- Python Support ---
if(NOT IOS)
include(cmake/VISPDetectPython.cmake)
# Make sure to refresh the python interpreter every time we rerun cmake
# If we don't do this, we may use an old or invalid python when installing the bindings
# that was cached by a previous attempt at building
if(CMAKE_VERSION VERSION_LESS "3.15.0")
set(PYTHON3_CACHE_LIST
PYTHON3INTERP_FOUND PYTHONINTERP_FOUND PYTHONLIBS_FOUND PYTHON_FOUND
PYTHON3_EXECUTABLE PYTHON_EXECUTABLE
)
foreach (_variableName ${PYTHON3_CACHE_LIST})
unset(${_variableName} CACHE)
endforeach()
include(cmake/VISPDetectPython.cmake)
else()
set(PYTHON3_CACHE_LIST
Python3_FOUND Python3_EXECUTABLE Python3_Interpreter_FOUND Python3_LIBRARIES
_Python3_EXECUTABLE _Python3_INCLUDE_DIR _Python3_INTERPRETER_PROPERTIES _Python3_LIBRARY_RELEASE
)
foreach (_variableName ${PYTHON3_CACHE_LIST})
unset(${_variableName} CACHE)
endforeach()
# Find strategy
set(Python3_FIND_REGISTRY LAST)
set(Python3_FIND_VIRTUALENV FIRST)
set(Python3_FIND_STRATEGY LOCATION)
find_package (Python3 COMPONENTS Interpreter Development)

# Alias variables to be consistent with previous detection method
set(PYTHON3_FOUND ${Python3_FOUND})
set(PYTHON3_EXECUTABLE ${Python3_EXECUTABLE})
set(PYTHON_DEFAULT_EXECUTABLE ${PYTHON3_EXECUTABLE})
set(PYTHON3INTERP_FOUND ${Python3_Interpreter_FOUND})
set(PYTHON3_VERSION_STRING ${Python3_VERSION})
endif()
endif()

if(CMAKE_VERSION VERSION_LESS "3.19.0")
# --- Python Bindings requirements ---
VP_OPTION(USE_PYBIND11 pybind11 QUIET "Include pybind11 to create Python bindings" "" ON)

# Minimum tool versions
set(CMAKE_MINIMUM_VERSION_PYTHON_BINDINGS "3.19.0")
set(PYTHON3_MINIMUM_VERSION_PYTHON_BINDINGS "3.7.0")
if(CMAKE_VERSION VERSION_LESS ${CMAKE_MINIMUM_VERSION_PYTHON_BINDINGS})
set(CMAKE_NOT_OK_FOR_BINDINGS TRUE)
message(STATUS "Required CMake version for Python bindings is ${CMAKE_MINIMUM_VERSION_PYTHON_BINDINGS},
but you have ${CMAKE_VERSION}.
Python bindings generation will be deactivated.
")
else()
set(CMAKE_NOT_OK_FOR_BINDINGS FALSE)
endif()

if(CMAKE_NOT_OK_FOR_BINDINGS)
status("${CMAKE_NOT_OK_FOR_BINDINGS}")
status("CMake version required for Python bindings is 3.19.0, but you have ${CMAKE_VERSION}. Python bindings generation will be deactivated")
if(PYTHON3_VERSION_STRING VERSION_LESS ${PYTHON3_MINIMUM_VERSION_PYTHON_BINDINGS})
set(PYTHON3_NOT_OK_FOR_BINDINGS TRUE)
message(STATUS "Required Python version for Python bindings is ${PYTHON3_MINIMUM_VERSION_PYTHON_BINDINGS},
but you have ${PYTHON3_VERSION_STRING}.
Python bindings generation will be deactivated.
")
else()
set(PYTHON3_NOT_OK_FOR_BINDINGS FALSE)
endif()
if(VISP_CXX_STANDARD LESS VISP_CXX_STANDARD_17)
set(CXX_STANDARD_NOT_OK_FOR_BINDINGS TRUE)
message(STATUS "Required C++ standard is C++17, but you have ${VISP_CXX_STANDARD}")
else()
set(CXX_STANDARD_NOT_OK_FOR_BINDINGS FALSE)
endif()

# --- Python Bindings requirements ---

# this avoids non-active conda from getting picked anyway on Windows
#set(Python_FIND_REGISTRY LAST)
# Use environment variable PATH to decide preference for Python
#set(Python_FIND_VIRTUALENV FIRST)
#set(Python_FIND_STRATEGY LOCATION)

#find_package(Python 3.7 COMPONENTS Interpreter Development) # TODO: use visp function to find python?
#if(Python_FOUND)
# set(VISP_PYTHON_BINDINGS_EXECUTABLE "${Python_EXECUTABLE}")
#endif()
#find_package(pybind11)
VP_OPTION(USE_PYBIND11 pybind11 QUIET "Include pybind11 to create Python bindings" "" ON)

#if(pybind11_FOUND)
# set(VISP_PYBIND11_DIR "${pybind11_DIR}")
#endif()
#message("${pybind11_FOUND}")
# Forbid system Python
if(DEFINED ENV{VIRTUAL_ENV} OR DEFINED ENV{CONDA_PREFIX})
set(_pip_args)
set(VISP_PYTHON_IS_SYSTEM_WIDE FALSE)
else()
# First solution: raise an error when cmake will call pip install
# set(_pip_args "--require-virtualenv") # If this is a system python, throw an error
if(PYTHON3_FOUND)
message(STATUS "The python version that you are using (${PYTHON3_EXECUTABLE}) is the system interpreter.
pip packages should not be installed system-wide!
Python bindings targets will be deactivated!
To reenable them, install conda or virtualenv,
delete the CMakeCache file then rerun cmake when inside the virtual environment.
")
set(VISP_PYTHON_IS_SYSTEM_WIDE TRUE)
endif()
endif()

# ---


Expand Down Expand Up @@ -447,7 +501,7 @@ VP_OPTION(BUILD_ANDROID_EXAMPLES "" "" "Build examples for Android platform"
VP_OPTION(INSTALL_ANDROID_EXAMPLES "" "" "Install Android examples" "" OFF IF ANDROID )

# Build python bindings as an option
VP_OPTION(BUILD_PYTHON_BINDINGS "" "" "Build Python bindings" "" ON IF (PYTHON3INTERP_FOUND AND USE_PYBIND11 AND NOT CMAKE_NOT_OK_FOR_BINDINGS) )
VP_OPTION(BUILD_PYTHON_BINDINGS "" "" "Build Python bindings" "" ON IF (PYTHON3INTERP_FOUND AND USE_PYBIND11 AND NOT CMAKE_NOT_OK_FOR_BINDINGS AND NOT VISP_PYTHON_IS_SYSTEM_WIDE AND NOT PYTHON3_NOT_OK_FOR_BINDINGS AND NOT CXX_STANDARD_NOT_OK_FOR_BINDINGS) )
VP_OPTION(BUILD_PYTHON_BINDINGS_DOC "" "" "Build the documentation for the Python bindings" "" ON IF BUILD_PYTHON_BINDINGS )


Expand Down Expand Up @@ -1623,8 +1677,17 @@ if(BUILD_PYTHON_BINDINGS)
status(" Package version:" "${VISP_PYTHON_PACKAGE_VERSION}")
status(" Wrapped modules:" "${VISP_PYTHON_BOUND_MODULES}")
status(" Generated input config:" "${VISP_PYTHON_GENERATED_CONFIG_FILE}")
else()
status(" Requirements: ")
status(" Python version > ${PYTHON3_MINIMUM_VERSION_PYTHON_BINDINGS}:" PYTHON3_FOUND AND NOT PYTHON3_NOT_OK_FOR_BINDINGS THEN "ok (ver ${PYTHON3_VERSION_STRING})" ELSE "python not found or too old (${PYTHON3_VERSION_STRING})")
status(" Python in Virtual environment or conda:" VISP_PYTHON_IS_SYSTEM_WIDE THEN "failed" ELSE "ok")
status(" Pybind11 found:" USE_PYBIND11 THEN "ok" ELSE "failed")
status(" CMake > ${CMAKE_MINIMUM_VERSION_PYTHON_BINDINGS}:" CMAKE_NOT_OK_FOR_BINDINGS THEN "failed (${CMAKE_VERSION})" ELSE "ok (${CMAKE_VERSION})")
status(" C++ standard > ${VISP_CXX_STANDARD_17}:" CXX_STANDARD_NOT_OK_FOR_BINDINGS THEN "failed (${VISP_CXX_STANDARD})" ELSE "ok (${VISP_CXX_STANDARD})")

endif()


# ============================ Options ===========================
status("")
status(" Build options: ")
Expand Down
29 changes: 15 additions & 14 deletions modules/core/include/visp3/core/vpBSpline.h
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,8 @@
- k indicates which kth derivative is computed.
- value is the numerical value of \f$ N_{i,p}^k(u) \f$.
*/
typedef struct vpBasisFunction {
typedef struct vpBasisFunction
{
unsigned int i;
unsigned int p;
double u;
Expand Down Expand Up @@ -104,8 +105,8 @@ typedef struct vpBasisFunction {

class VISP_EXPORT vpBSpline
{
public /*protected*/:
//! Vector wich contains the control points
public /*protected*/:
//! Vector wich contains the control points
std::vector<vpImagePoint> controlPoints;
//! Vector which contain the knots \f$ {u0, ..., um} \f$
std::vector<double> knots;
Expand Down Expand Up @@ -214,24 +215,24 @@ class VISP_EXPORT vpBSpline
}
}

static unsigned int findSpan(double l_u, unsigned int l_p, std::vector<double> &l_knots);
unsigned int findSpan(double u);
static unsigned int findSpan(double l_u, unsigned int l_p, const std::vector<double> &l_knots);
unsigned int findSpan(double u) const;

static vpBasisFunction *computeBasisFuns(double l_u, unsigned int l_i, unsigned int l_p,
std::vector<double> &l_knots);
vpBasisFunction *computeBasisFuns(double u);
const std::vector<double> &l_knots);
vpBasisFunction *computeBasisFuns(double u) const;

static vpBasisFunction **computeDersBasisFuns(double l_u, unsigned int l_i, unsigned int l_p, unsigned int l_der,
std::vector<double> &l_knots);
vpBasisFunction **computeDersBasisFuns(double u, unsigned int der);
const std::vector<double> &l_knots);
vpBasisFunction **computeDersBasisFuns(double u, unsigned int der) const;

static vpImagePoint computeCurvePoint(double l_u, unsigned int l_i, unsigned int l_p, std::vector<double> &l_knots,
std::vector<vpImagePoint> &l_controlPoints);
vpImagePoint computeCurvePoint(double u);
static vpImagePoint computeCurvePoint(double l_u, unsigned int l_i, unsigned int l_p, const std::vector<double> &l_knots,
const std::vector<vpImagePoint> &l_controlPoints);
vpImagePoint computeCurvePoint(double u) const;

static vpImagePoint *computeCurveDers(double l_u, unsigned int l_i, unsigned int l_p, unsigned int l_der,
std::vector<double> &l_knots, std::vector<vpImagePoint> &l_controlPoints);
vpImagePoint *computeCurveDers(double u, unsigned int der);
const std::vector<double> &l_knots, const std::vector<vpImagePoint> &l_controlPoints);
vpImagePoint *computeCurveDers(double u, unsigned int der) const;
};

#endif
7 changes: 3 additions & 4 deletions modules/core/include/visp3/core/vpCannyEdgeDetection.h
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,6 @@
// 3rd parties include
#ifdef VISP_HAVE_NLOHMANN_JSON
#include <nlohmann/json.hpp>
using json = nlohmann::json; //! json namespace shortcut
#endif

class VISP_EXPORT vpCannyEdgeDetection
Expand Down Expand Up @@ -213,7 +212,7 @@ class VISP_EXPORT vpCannyEdgeDetection
* \param[in] j : The JSON object, resulting from the parsing of a JSON file.
* \param[out] detector : The detector that will be initialized from the JSON data.
*/
friend inline void from_json(const json &j, vpCannyEdgeDetection &detector)
friend inline void from_json(const nlohmann::json &j, vpCannyEdgeDetection &detector)
{
std::string filteringAndGradientName = vpImageFilter::vpCannyFilteringAndGradientTypeToString(detector.m_filteringAndGradientType);
filteringAndGradientName = j.value("filteringAndGradientType", filteringAndGradientName);
Expand All @@ -233,10 +232,10 @@ class VISP_EXPORT vpCannyEdgeDetection
* \param[out] j : A JSON parser object.
* \param[in] detector : The vpCannyEdgeDetection object that must be parsed into JSON format.
*/
friend inline void to_json(json &j, const vpCannyEdgeDetection &detector)
friend inline void to_json(nlohmann::json &j, const vpCannyEdgeDetection &detector)
{
std::string filteringAndGradientName = vpImageFilter::vpCannyFilteringAndGradientTypeToString(detector.m_filteringAndGradientType);
j = json {
j = nlohmann::json {
{"filteringAndGradientType", filteringAndGradientName},
{"gaussianSize", detector.m_gaussianKernelSize},
{"gaussianStdev", detector.m_gaussianStdev},
Expand Down
4 changes: 2 additions & 2 deletions modules/core/include/visp3/core/vpFrameGrabber.h
Original file line number Diff line number Diff line change
Expand Up @@ -103,9 +103,9 @@ class VISP_EXPORT vpFrameGrabber
/** @name Inherited functionalities from vpFramegrabber */
//@{
//! Return the number of rows in the image.
inline unsigned int getHeight() const { return height; }
unsigned int getHeight() const;
//! Return the number of columns in the image.
inline unsigned int getWidth() const { return width; }
unsigned int getWidth() const;
//@}

public:
Expand Down
34 changes: 17 additions & 17 deletions modules/core/include/visp3/core/vpImageTools.h
Original file line number Diff line number Diff line change
Expand Up @@ -1133,7 +1133,7 @@ void vpImageTools::resize(const vpImage<Type> &I, vpImage<Type> &Ires, const vpI
}
}
}
}
}

#if defined(VISP_HAVE_SIMDLIB)
template <>
Expand Down Expand Up @@ -1511,24 +1511,24 @@ void vpImageTools::warpLinear(const vpImage<Type> &src, const vpMatrix &T, vpIma
const float s = xi_ - x_;

if (y_ < static_cast<int>(src.getHeight()) - 1 && x_ < static_cast<int>(src.getWidth()) - 1) {
const Type val00 = src[y_][x_];
const Type val01 = src[y_][x_ + 1];
const Type val10 = src[y_ + 1][x_];
const Type val11 = src[y_ + 1][x_ + 1];
const float val00 = static_cast<float>(src[y_][x_]);
const float val01 = static_cast<float>(src[y_][x_ + 1]);
const float val10 = static_cast<float>(src[y_ + 1][x_]);
const float val11 = static_cast<float>(src[y_ + 1][x_ + 1]);
const float col0 = lerp(val00, val01, s);
const float col1 = lerp(val10, val11, s);
const float interp = lerp(col0, col1, t);
dst[i][j] = vpMath::saturate<Type>(interp);
}
else if (y_ < static_cast<int>(src.getHeight()) - 1) {
const Type val00 = src[y_][x_];
const Type val10 = src[y_ + 1][x_];
const float val00 = static_cast<float>(src[y_][x_]);
const float val10 = static_cast<float>(src[y_ + 1][x_]);
const float interp = lerp(val00, val10, t);
dst[i][j] = vpMath::saturate<Type>(interp);
}
else if (x_ < static_cast<int>(src.getWidth()) - 1) {
const Type val00 = src[y_][x_];
const Type val01 = src[y_][x_ + 1];
const float val00 = static_cast<float>(src[y_][x_]);
const float val01 = static_cast<float>(src[y_][x_ + 1]);
const float interp = lerp(val00, val01, s);
dst[i][j] = vpMath::saturate<Type>(interp);
}
Expand Down Expand Up @@ -1583,24 +1583,24 @@ void vpImageTools::warpLinear(const vpImage<Type> &src, const vpMatrix &T, vpIma
double t = y - y_lower;

if (y_lower < static_cast<int>(src.getHeight()) - 1 && x_lower < static_cast<int>(src.getWidth()) - 1) {
const Type val00 = src[y_lower][x_lower];
const Type val01 = src[y_lower][x_lower + 1];
const Type val10 = src[y_lower + 1][x_lower];
const Type val11 = src[y_lower + 1][x_lower + 1];
const double val00 = static_cast<double>(src[y_lower][x_lower]);
const double val01 = static_cast<double>(src[y_lower][x_lower + 1]);
const double val10 = static_cast<double>(src[y_lower + 1][x_lower]);
const double val11 = static_cast<double>(src[y_lower + 1][x_lower + 1]);
const double col0 = lerp(val00, val01, s);
const double col1 = lerp(val10, val11, s);
const double interp = lerp(col0, col1, t);
dst[i][j] = vpMath::saturate<Type>(interp);
}
else if (y_lower < static_cast<int>(src.getHeight()) - 1) {
const Type val00 = src[y_lower][x_lower];
const Type val10 = src[y_lower + 1][x_lower];
const double val00 = static_cast<double>(src[y_lower][x_lower]);
const double val10 = static_cast<double>(src[y_lower + 1][x_lower]);
const double interp = lerp(val00, val10, t);
dst[i][j] = vpMath::saturate<Type>(interp);
}
else if (x_lower < static_cast<int>(src.getWidth()) - 1) {
const Type val00 = src[y_lower][x_lower];
const Type val01 = src[y_lower][x_lower + 1];
const double val00 = static_cast<double>(src[y_lower][x_lower]);
const double val01 = static_cast<double>(src[y_lower][x_lower + 1]);
const double interp = lerp(val00, val01, s);
dst[i][j] = vpMath::saturate<Type>(interp);
}
Expand Down
14 changes: 7 additions & 7 deletions modules/core/include/visp3/core/vpMatrix.h
Original file line number Diff line number Diff line change
Expand Up @@ -1060,7 +1060,7 @@ class VISP_EXPORT vpMatrix : public vpArray2D<double>
/*!
\deprecated You should rather use inverseByCholeskyLapack() or inverseByCholesky().
*/
vpMatrix inverseByCholeskyGsl() const
vp_deprecated vpMatrix inverseByCholeskyGsl() const
{
#if defined(VISP_HAVE_LAPACK)
return inverseByCholeskyLapack();
Expand All @@ -1072,7 +1072,7 @@ class VISP_EXPORT vpMatrix : public vpArray2D<double>
/*!
\deprecated You should rather use inverseByQRLapack() or inverseByQR().
*/
vpMatrix inverseByQRGsl() const
vp_deprecated vpMatrix inverseByQRGsl() const
{
#if defined(VISP_HAVE_LAPACK)
return inverseByQRLapack();
Expand All @@ -1084,7 +1084,7 @@ class VISP_EXPORT vpMatrix : public vpArray2D<double>
/*!
\deprecated You should rather use pseudoInverseLapack() or pseudoInverse().
*/
vpMatrix pseudoInverseGsl(double svThreshold = 1e-6) const
vp_deprecated vpMatrix pseudoInverseGsl(double svThreshold = 1e-6) const
{
#if defined(VISP_HAVE_LAPACK)
return pseudoInverseLapack(svThreshold);
Expand All @@ -1097,7 +1097,7 @@ class VISP_EXPORT vpMatrix : public vpArray2D<double>
/*!
\deprecated You should rather use pseudoInverseLapack() or pseudoInverse().
*/
unsigned int pseudoInverseGsl(vpMatrix &Ap, double svThreshold = 1e-6) const
vp_deprecated unsigned int pseudoInverseGsl(vpMatrix &Ap, double svThreshold = 1e-6) const
{
#if defined(VISP_HAVE_LAPACK)
return pseudoInverseLapack(Ap, svThreshold);
Expand All @@ -1111,7 +1111,7 @@ class VISP_EXPORT vpMatrix : public vpArray2D<double>
/*!
\deprecated You should rather use pseudoInverseLapack() or pseudoInverse().
*/
unsigned int pseudoInverseGsl(vpMatrix &Ap, vpColVector &sv, double svThreshold = 1e-6) const
vp_deprecated unsigned int pseudoInverseGsl(vpMatrix &Ap, vpColVector &sv, double svThreshold = 1e-6) const
{
#if defined(VISP_HAVE_LAPACK)
return pseudoInverseLapack(Ap, sv, svThreshold);
Expand All @@ -1126,7 +1126,7 @@ class VISP_EXPORT vpMatrix : public vpArray2D<double>
/*!
\deprecated You should rather use pseudoInverseLapack() or pseudoInverse().
*/
unsigned int pseudoInverseGsl(vpMatrix &Ap, vpColVector &sv, double svThreshold, vpMatrix &imA, vpMatrix &imAt,
vp_deprecated unsigned int pseudoInverseGsl(vpMatrix &Ap, vpColVector &sv, double svThreshold, vpMatrix &imA, vpMatrix &imAt,
vpMatrix &kerAt) const
{
#if defined(VISP_HAVE_LAPACK)
Expand All @@ -1145,7 +1145,7 @@ class VISP_EXPORT vpMatrix : public vpArray2D<double>
/*!
\deprecated You should rather use svdLapack() or svd().
*/
void svdGsl(vpColVector &w, vpMatrix &V)
vp_deprecated void svdGsl(vpColVector &w, vpMatrix &V)
{
#if defined(VISP_HAVE_LAPACK)
svdLapack(w, V);
Expand Down
Loading
Loading