BYU Invariant Extended Kalman Filter Library
Project description
Invariant Extended Kalman Filter
InEKF is a C++ library that implements the Invariant Extend Kalman Filter (InEKF) in a modular to enable easy application to any system.
Features
- Support for Right & Left filters.
- Base classes provided easy extension via inheritance.
- Coded using static Eigen types for efficient structure.
- Fully featured python interface for use in classroom, testing, etc.
- C++14 and above supported.
- Fullly templated Lie Groups SO2, SO3, SE2, SE3 to enable additional tracking of Euclidean states and multiple extra columns in SE2/SE3.
- Dynamic Lie Groups types to add columns to SE2/SE3 on the fly (for InEKF SLAM).
- Various examples to get started.
Building & Linking
To use InEKF, only Eigen
is necessary. This can be installed via apt-get
or from source. Also, a version of python with numpy and matplotlib installed for plotting reasons (I recommend systemwide, conda gave me fits).
InEKF is built via cmake, and thus can be built in the usual cmake fashion:
mkdir build
cd build
cmake ..
make
sudo make install
This will install a custom target that can be linked via CMake as
find_package(Eigen3 CONFIG REQUIRED)
find_package(InEKF CONFIG REQUIRED)
target_link_libraries(mytarget PUBLIC InEKF::Core InEKF::Inertial InEKF::SE2Models)
A python wrapper is also available.
Structure
InEKF is split into a couple different libraries
Core
This library includes all the Lie Groups, InEKF
, and GenericMeasureModel
classes along with the base classes MeasureModel
, ProcessModel
.
Inertial
This is the implementation of the Lie Group SE_2(3)
along with an augmented bias state. Along with it are various process/measurement models defined on this group including as of now DVLSensor
, DepthSensor
, and InertialProcess
.
SE2Models
Exactly what it sounds like, is used for SLAM in SE2.
Extending
InEKF is set up so your process/measure models will be an easy extension and continue to function with InEKF
and LieGroups
if defined properly. Note this can be done in python or C++. The following is what must be defined/done to successfully do this. The following methods/variables for each base class must be implemented/set
MeasureModel
All methods are already implemented in the MeasureModel
class, so overriding them can be decided on a case by case basis. There is a few constants that must be set though.
Method | Use |
---|---|
error_ |
Type of invariant measurement, either ERROR::LEFT or ERROR::Right |
M_ |
Noise parameter. A default should be set in the constructor, and possible a method made to set it |
H_ |
Linearized innovation matrix H . Will be hit with adjoint depending on type of filter. Use H_error_ in calcSInverse(z, state) |
processZ(z, state) |
Any preprocessing that needs to be done on z should be done here. This could include adding 0s and 1s on the end, change of frames, etc. |
calcV(z, state) |
Accepts an exact size of z, and calculates/returns the innovation. Likely will not need to be overriden. |
calcSInverse(state) |
Calculates and returns S^{-1}, the inverse of the measurement covariance. Also likely won't need to be overriden. |
ProcessModel
In contrast, the process model implements a few things that MUST be overriden.
Method | Use |
---|---|
f(u, dt, state) |
State process model. Returns the state. |
MakePhi(u, dt, state) |
Creates exp(A*dt) to use. Make sure to check what type of error State is and make A accordingly |
Q_ |
Noise parameter. A default should be set in the constructor, and possible a method made to set it |
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
File details
Details for the file inekf-0.1.0.dev2-cp39-cp39-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
.
File metadata
- Download URL: inekf-0.1.0.dev2-cp39-cp39-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
- Upload date:
- Size: 3.3 MB
- Tags: CPython 3.9, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e4696652efefbc51cedf5be5e18e6e572febca7973f4923f1fea1db8240bc44d |
|
MD5 | dcd9a5c2db6a645923ef790311abba2e |
|
BLAKE2b-256 | bf771a60bf9aa3c9cdb1978c0ab54ddc3467247ad630a01da0db0c48aeb97363 |
File details
Details for the file inekf-0.1.0.dev2-cp38-cp38-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
.
File metadata
- Download URL: inekf-0.1.0.dev2-cp38-cp38-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
- Upload date:
- Size: 3.3 MB
- Tags: CPython 3.8, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e62da7783740c94558e3bb9ca8d3bb6a99aff122339c22afc723076bf6712ec5 |
|
MD5 | 98e83cc50bda67388d8beefc86dd6f2f |
|
BLAKE2b-256 | 027dd651a39c1d58bde0a5b85add47fbff529a616972503ad5b47af74821ed57 |
File details
Details for the file inekf-0.1.0.dev2-cp37-cp37m-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
.
File metadata
- Download URL: inekf-0.1.0.dev2-cp37-cp37m-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
- Upload date:
- Size: 3.3 MB
- Tags: CPython 3.7m, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fe0313f09f4909115218ecc32f5e523de2a754b3e000e7e351fbc9c3784efa79 |
|
MD5 | 4d92d99ae3c62048da56e622b4067112 |
|
BLAKE2b-256 | efe0f40c13d00dc44b2cd398b540716c1ae9cace8f351bde16d075d51fc1420d |
File details
Details for the file inekf-0.1.0.dev2-cp36-cp36m-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
.
File metadata
- Download URL: inekf-0.1.0.dev2-cp36-cp36m-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
- Upload date:
- Size: 3.3 MB
- Tags: CPython 3.6m, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1f1afb341ef423c56aefecbfec07f31131bdd5f3f5f8a095d885c92eb95c14ae |
|
MD5 | 9d33120033218f988e207d0357aad640 |
|
BLAKE2b-256 | 2f1b4e8d516478db1bad2de026a22bb6c5ac30734731cdfd84560bcc94664c90 |