Home

Introduction

Caesar is a modern robotic framework for localization and mapping, reducing the barrier of entry for Simultaneous Localization and Mapping (SLAM). Caesar attempts to address a number of issues that arise in normal SLAM solutions - solving under-defined systems, inference with non-Gaussian measurement distributions, simplifying factor creation, and centralizing factor-graph persistence with databases. Caesar started as part of the thesis "Multi-modal and Inertial Sensor Solutions for Navigation-type Factor Graphs" [1.2].

Focus Area

This project focuses on the open development and progression to a public, stable, growing and usable inference library suited to data-fusion aspects of device navigation.

The Caesar Framework

Caesar

Caesar.jl is the "umbrella" framework for other dedicated algorithmic/supporting packages that are implemented in Julia (and JuliaPro).

FAQ: Why use Julia?

FAQ: Interop with other languages

RoME.jl/IncrementalInference.jl/ApproxManifoldProducts.jl

Critically, this package can operate in the conventional SLAM manner, using local memory (dictionaries), or alternatively distribute around a persisted FactorGraph through a graph database using CloudGraphs.jl, as discussed in literature here [1.3]. A variety of plotting, 3D visualization, serialization, LCM middleware, and analysis tools come standard. Please see internal packages, Robot Motion Estimate RoME.jl and back-end solver IncrementalInference.jl.

Details about the accompanying packages:

Visualization (Arena.jl/RoMEPlotting.jl)

Caesar visualization (plotting of results, graphs, and data) is provided by 2D and 3D packages respectively:

Multilanguage Interops: Caesar SDKs and APIs

The Caesar framework is not limited to direct Julia use. See the multi-language page for details.

Also see Frequently Asked Questions for more.

A Few Highlights

Work In Progress: (must be updated, 2019Q1)

The Caesar framework has the following features:

Origins in Fundamental Research

See related works on the literature page.

Future Directions

Many future directions are in the works โ€“ including fundamental research, implementation quality/performance, and system integration. Please see/open issues for specific requests or adding comments to an ongoing discussion.

Next Steps

For installation steps, examples/tutorials, and concepts please refer to the following pages:

Future

This package is a work in progress. Please file issues here as needed to help resolve problems for everyone! We are tracking improvements and new endeavors in the Issues section of this repository.

In the future, Caesar will likely interact more closely with repos such as:

JuliaRobotics Code of Conduct

The Caesar repository is part of the JuliaRobotics organization and adheres to the JuliaRobotics code-of-conduct.

Contributors

We are grateful for many, many contributions within the Julia package ecosystem โ€“ see the REQUIRE files of Caesar, Arena, RoME, RoMEPlotting, KernelDensityEstimate, IncrementalInference, NLsolve, DrakeVisualizer, Graphs, CloudGraphs and others for a far reaching list of contributions.

Consider citing our work:

@misc{caesarjl,
  author = "Contributors",
  title =  "Caesar.jl",
  year =   2019,
  url =    "https://github.com/JuliaRobotics/Caesar.jl"
}

Administration of the Caesar/RoME/IncrementalInference/Arena packages is currently conducted by Dehann Fourie who can be contacted for more details.