iMSTK
Interactive Medical Simulation Toolkit
|
iMSTK is a C++ based free & open-source toolkit that aids rapid prototyping of real-time multi-modal surgical simulation scenarios. Surgical simulation scenarios involve algorithms from areas such as haptics, advanced rendering, computational geometry, computational mechanics, virtual reality and parallel computing. iMSTK employs a highly modular and extensible design to enable the use of libraries and codes from these areas in a given application thereby reducing the development time.
This project is supported in part by the following grants 9R44OD018334, 1R44EB019802, 1R44AR075481 , 1R01EB025247, 2R44DK115332
Disclaimer: The content is solely the responsibility of the authors and does not necessarily represent the official views of the NIH and its institutes.
iMSTK is licensed under Apache 2.0
Click here for user documentation.
Click here for doxygen code documentation.
Click https://gitlab.kitware.com/iMSTK/iMSTK/-/blob/master/Docs/CodingGuide.md "here" for iMSTK coding style
Click https://gitlab.kitware.com/iMSTK/iMSTK/-/blob/master/Docs/Maintainance.md "here" to view information about iMSTK maintenance tasks
Click here for nightly build & MR results.
The iMSTK Users and Developers can post questions and discuss relevant topics at the Discourse.
Designed more specifically for developers, the issue tracker allows developers to list and discuss issues & enhancements: >https://gitlab.kitware.com/iMSTK/iMSTK/issues
Assign labels to the issues. The description of each label can be found HERE.
bug compilation critical enhancement optimization clean up refactor testcase visualization mechanics device documentation support discussion
To be able to contribute back to the iMSTK project, the preferred way is to use Git for code version control. You can use the following command in the terminal for Linux/macOS, or in Git Bash for Windows.
OR
If cloning with HTTPS, skip this step. If cloning with SSH the build process will check out external dependency sources with the SSH protocol to avoid manually entering credentials during the build process. To allow this, make sure you set up your ssh key in your profile HERE. You can find documentation on how to generate and retrieve your public ssh key HERE.
We use CMake to configure the project on every platform. See how to run it HERE.
CMAKE_BUILD_TYPE
, use ccmake
instead of cmake
. -GNinja
: Innerbuild
directory.iMSTK.sln
solution file for Visual Studio at the top level for what is called the Superbuild. Open this file and build all targets, which will checkout, build and link all iMSTK dependencies. Make sure the build mode is set to Release
or RelWithDebInfo
, iMSTK is not very usable in Debug
mode. The switches IMSTK_BUILD_EXAMPLES, IMSTK_BUILD_TESTING and IMSTK_BUILD_VISUAL_TESTING should be on as well. When making changes to iMSTK base source code, you can then build from the iMSTK.sln
solution file located in the Innerbuild
directory. If you would like to build on multiple cores add /MP[N] to CMAKE_CXX_FLAGS in CMake-GUI, where N is optional representing the number of cores (without N supplied, the build will use as many cores as available on the device). If you check out the unit tests or the examples make sure to run git install lfs
to make sure that git lfs
is installed.iMSTK_USE_OpenHaptics
set to ON
.OPENHAPTICS_ROOT_DIR
should be set to the OpenHaptics path on your system.#### Haply Support To support the Haply Inverse3 haptic device, follow the steps below:
iMSTK_USE_HAPLY
set to ON
.Please note the Haply Hardware API is in early stages of development and will be deprecated & changed in the future.
#### VRPN Support
The VRPNDeviceModule
enables access to a large number devices supported by VRPN. The VRPNDeviceModule
expects a vrpn_server
to be running. The iMSTK superbuild builds and installs a server with some default settings but if you want to configure a specific server it might be easier to separately build a server. The file CMake\External\External_VRPN.cmake
shows how to pass configuration into VRPN in case you want to modify the modules enabled and disabled by the build
The vrpn.cfg
that is installed by default doesn't have any devices enabled, before use you will need to uncomment the devices that you would like to use. If you use the one inside the iMSTK install directory please note that it will be overwritten every time the superbuild is run.
Currently iMSTK supports VRPN Analog
, Button
and Tracker
devices. Future support will depend on user demand.
bash sudo apt install mesa-common-dev libosmesa6-dev libglu1-mesa-dev
``
Set
iMSTK_USE_VTK_OSMESAto
ON`iMSTK_USE_RENDERING_VTK
to OFF
iMSTK_BUILD_VISUAL_TESTING
to OFF