-
Notifications
You must be signed in to change notification settings - Fork 1
Home
WIKI IS STILL UNDER CONSTRUCTION
- Introduction
- Walkthrough
- Frequently Asked Questions (FAQ)
- Code and Programs for Related Publications
TODO
This section outlines a walkthrough, or tutorial, of the basic functionality of the JHMR software and how it may be applied to solve common computer assisted surgery workflow tasks, ranging from preoperative planning to intraoperative navigation. All data used in the workflow is either obtained from freely available online sources, such as The Cancer Imaging Archive (TCIA), data derived by processing the data available online, simulating new data, or some combination therein. Links to all of the derived and simulated data files are provided here.
Walkthrough Outline:
- Obtaining the tools
- Preoperative planning
- Simulated data
- Intraoperative 3D/3D registration
- Intraoperative 2D/3D (fluoroscopy/CT) registration
Help generate this section by asking some questions via the repository issues page, email, or twitter!
- Are there pre-compiled binaries for Windows/Mac/Linux?
- Not yet! Once these are available they will be posted on the repository page under releases. Stay tuned.
- How do I select a specific GPU (or OpenCL device) to use on a system with several GPUs (OpenCL devices) available?
- This may be accomplished by setting the desired device ID with the
--ocl-id
flag or through the use of environment variables (e.g.CUDA_VISIBLE_DEVICES
). See this page for further information.
- This may be accomplished by setting the desired device ID with the
- Is it possible to run on a system that does not have a GPU or a less-capable GPU (e.g. a server)?
- Yes! Select the CPU backend by passing
--backend cpu
or use the OpenCL backend with a compatible CPU device (e.g. something like--backend ocl --ocl-id "Intel(R)Core(TM)[email protected]"
. Tools that do not provide a backend flag only perform CPU processing. See this page for further information.
- Yes! Select the CPU backend by passing
- My program crashed with some strange OpenCL error message - what happened?
- This usually occurs when there are insufficient resources, such as memory, on the OpenCL device. The exact reason depends on the processing involved, but typically adjusting the parameters that effect the amount of memory required may resolve the issue. For example, lowering the population sizes for the CMA-ES or Differential Evolution registration strategies will reduce the number of DRRs created during each optimization iteration, and therefore reduce the memory footprint. This may also occur if your code chains together OpenCL ray casters and similarity metrics, but different contexts or command queues are used for each object.
- Why did you choose OpenCL for GPU computations instead of CUDA?
- Although CUDA kernels are generally more computationally efficient than their OpenCL counterparts, using OpenCL avoids a lock-in to NVIDIA GPUs. Since most NVIDIA, AMD, and Intel GPUs provide OpenCL support, nearly any hardware setup, ranging from entry-level laptops to state-of-the-art compute clusters, may leverage GPU support. This should enable any interested user to run this software. Support for CUDA, Metal, and Vulkan processing backends is planned for future work.
- How do I incorporate this library into my software?
- The JHMR library is most easily incorporated using standard CMake practices, such as
add_subdirectory()
andfind_package()
. See this page for more details.
- The JHMR library is most easily incorporated using standard CMake practices, such as
The JHMR library and supporting executables have been used for research leading to various publications. Some of these publications are listed below, along with links to any available source code.
- Automatic Annotation of Hip Anatomy in Fluoroscopy for Robust and Efficient 2D/3D Registration
- Published in International Journal of Computer Assisted Radiology and Surgery
- Paper: https://doi.org/10.1007/s11548-020-02162-7
- Preprint: https://arxiv.org/abs/1911.07042
- Source Code: Coming Soon
- Pose Estimation of Periacetabular Osteotomy Fragments with Intraoperative X-Ray Navigation
- Published in IEEE Transactions on Biomedical Engineering
- Paper: https://doi.org/10.1109/TBME.2019.2915165
- Preprint: https://arxiv.org/abs/1903.09339
- Source Code: Coming Soon
- Fast and Automatic Periacetabular Osteotomy Fragment Pose Estimation Using Intraoperatively Implanted Fiducials and Single-View Fluoroscopy
- Published in Physics in Medicine & Biology
- Paper: https://doi.org/10.1088/1361-6560/aba089
- Preprint: https://arxiv.org/abs/1910.10187
- Patch-Based Image Similarity for Intraoperative 2D/3D Pelvis Registration During Periacetabular Osteotomy
- Published at MICCAI CLIP Workshop 2018
- Paper: https://doi.org/10.1007/978-3-030-01201-4_17
- Preprint: https://arxiv.org/abs/1909.10443
- Source Code: Coming Soon
- Home
- FAQ
-
Walkthrough
- Obtaining the Tools
- Preoperative
- Simulated Data
- 3D/3D Registration
- 2D/3D Registration
- Data
- Other Stuff