gtsam/wrap
Bernd Pfrommer 71f4bb3019 Use GNUInstallDirs to make install destination directories configurable 2020-05-31 21:52:00 -04:00
..
python Transitioned toa method to a functor 2020-03-17 14:34:11 -04:00
tests updated tests to work with new wrap code generation 2019-07-10 15:56:32 -04:00
Argument.cpp
Argument.h
CMakeLists.txt Use GNUInstallDirs to make install destination directories configurable 2020-05-31 21:52:00 -04:00
Class.cpp Add better error reporting 2019-06-15 11:12:19 -04:00
Class.h
Constructor.cpp
Constructor.h
Deconstructor.cpp
Deconstructor.h
FileWriter.cpp fix unused parameter warning 2019-06-15 23:09:10 +02:00
FileWriter.h
ForwardDeclaration.h
FullyOverloadedFunction.cpp
FullyOverloadedFunction.h
Function.cpp
Function.h
GlobalFunction.cpp propagate exceptions from global functions from cpp to python 2019-07-10 15:56:07 -04:00
GlobalFunction.h
Method.cpp Add better error reporting 2019-06-15 11:12:19 -04:00
Method.h
MethodBase.cpp
MethodBase.h
Module.cpp
Module.h
OverloadedFunction.h
Qualified.cpp
Qualified.h
README.md renamed all READMEs to README.md and updated markdown syntax 2019-06-13 17:26:07 -04:00
ReturnType.cpp
ReturnType.h
ReturnValue.cpp
ReturnValue.h
StaticMethod.cpp
StaticMethod.h
Template.h
TemplateInstantiationTypedef.cpp
TemplateInstantiationTypedef.h
TemplateMethod.cpp
TemplateMethod.h
TemplateSubstitution.h
TypeAttributesTable.cpp
TypeAttributesTable.h
TypedefPair.h
matlab.h
spirit.h
utilities.cpp
utilities.h
wrap.cpp

README.md

WRAP README

The wrap library wraps the GTSAM library into a MATLAB toolbox.

It was designed to be more general than just wrapping GTSAM, but a small amount of GTSAM specific code exists in matlab.h, the include file that is included by the mex files. The GTSAM-specific functionality consists primarily of handling of Eigen Matrix and Vector classes.

For notes on creating a wrap interface, see gtsam.h for what features can be wrapped into a toolbox, as well as the current state of the toolbox for gtsam. For more technical details on the interface, please read comments in matlab.h

Some good things to know:

OBJECT CREATION

  • Classes are created by special constructors, e.g., new_GaussianFactorGraph_.cpp. These constructors are called from the MATLAB class @GaussianFactorGraph. new_GaussianFactorGraph_ calls wrap_constructed in matlab.h, see documentation there

METHOD (AND CONSTRUCTOR) ARGUMENTS

  • Simple argument types of methods, such as "double", will be converted in the mex wrappers by calling unwrap, defined in matlab.h
  • Vector and Matrix arguments are normally passed by reference in GTSAM, but in gtsam.h you need to pretend they are passed by value, to trigger the generation of the correct conversion routines unwrap and unwrap
  • passing classes as arguments works, provided they are passed by reference. This triggers a call to unwrap_shared_ptr