Skip to content

ThoHiller/nmr-nucleus

Repository files navigation

NUCLEUS

BLOCHUS icon

modeling and iNversion of nUCLear magnetic rEsonance data with angUlar poreS

release DOI


Table of Contents

  1. About
  2. Requirements
  3. Installation
  4. Usage
  5. Documentation
  6. ToDo
  7. Cite as & References
  8. Changelog

About

NUCLEUS is a set of MATLABTM tools, that allow forward and inverse modeling of nuclear magnetic resonance (NMR) relaxometry data (T1 and T2 relaxation). The main front-ends to these tools are two graphical user interfaces, NUCLEUSmod and NUCLEUSinv for forward and inverse modeling, respectively. For simple NMR relaxometry data inversion, the NUCLEUSinv GUI may be a little feature-rich. But one of the ideas, when starting to develop this code, was to help students understand the basic concepts of NMR relaxometry data inversion.

NUCLEUSmod basic features

  1. Generate pore size distributions (PSD) that can have a cylindrical, rectangular or polygonal cross section
  2. Calculate a capillary pressure saturation curve (CPSC) for the PSD by applying a range of non-zero air pressures (the capillaries are assumed to be water filled and completely water-wet); different saturations for drainage and imbibition conditions are considered
  3. Based on the different saturation levels along the CPSC, calculate the corresponding geometry-dependent forward NMR signals

NUCLEUSmod

NUCLEUSinv basic features

  1. Can import NUCLEUSmod data (directly from the open GUI or from a saved session file) and a wide range of different laboratory NMR data files (please contact me if you need a specific import routine for your data)
  2. Expert mode for more features (Standard mode has basic settings which should be sufficient for most users)
  3. Simple pre-processing of NMR signals (cutting, gating, normalizing)
  4. Different inversion options to process NMR data (e.g. mono-exponential fit, bi-exponential fit, multi-exponential fit) and estimate the uncertainty of the resulting relaxation time distributions (RTDs)
  5. Different regularization options for multi-exponential fitting (e.g. manual, L-curve, SVD tools)
  6. Joint inversion of NMR and CPS data to directly infer a PSD (non-linear inversion of surface relaxivity and PSD)

NUCLEUSinv UncertView


Requirements

In order to work properly you need to meet the following requirements:

  1. The Mathworks MATLABTM software development environment (tested with R2014b and newer)
    • The Optimization toolbox (optional)
    • The Statistics toolbox (optional)
  2. The GUI Layout Toolbox (get it from FEX) (required)
  3. The regularization toolbox from P. Hansen (get it from FEX or find out more about it here) (required)
  4. findjobj (get it from FEX) (required)
  5. fminsearchbnd (get it from FEX) (required)
  6. dynamicDateTicks (get it from FEX) (optional)
  7. kde kernel density estimator (get it from FEX) (optional; not needed for R2023b and newer)

If you do not have the Optimization or Statistics toolboxes then not all features are available (especially parts of the joint inversion). However, the general functionality of obtaining relaxation time distributions (RTDs) form NMR relaxometry data is of course working.

Operating System

I tested it successfully under Windows 7 (64bit) and 10 (64bit) with Matlab R2016b and newer. Always with the latest version of the GUI Layout Toolbox (current version is afaik v2.3.6)

NOTE: So far I did not test anything on Linux or a Mac. If you get it to work on either of the two systems (which it basically should I guess) please let me know.


Installation

  1. It is recommended to install the GUI Layout Toolbox directly into MATLABTM via the mltbx-file (but it should also work via the old-school way of adding the toolbox folders to the MATLABTM path)
  2. To use NUCLEUS you just need to place the nucleus folder from the git repository on your hard drive and use the start scripts startNUCLEUSinv and startNUCLEUSmod, respectively (within these scripts all necessary NUCLEUS folders are added to the MATLABTM path)

NOTE: It is recommended to have only one version of NUCLEUS on your current MATLABTM path.


Usage

  1. By executing the start scripts (see above)
  2. Simply type NUCLEUSinv or NUCLEUSmod on the MATLABTM prompt (make sure the nucleus folder is on the MATLABTM path)
  3. Check the demo scripts for the usage of the core functions without the GUI (inside the scripts folder)

Documentation

A basic documentation to NUCLEUS can be found in the nucleus\doc folder. Just open the index.html in the web browser of your choice. The documentation was created with m2html by Guillaume Flandin.


TODO

In no particular order and without guarantee that it will ever happen :-) :

  1. A Manual (this is on top of my agenda)
  2. Adapt the core functionality in a Python module
  3. NUCLEUSinv:
    • An import wizard to get rid of the import menu
    • Easy way to set optimization settings
    • For noise estimation: select manually a range of the NMR raw signal
  4. ...

Cite as

If you use NUCLEUS for your research, please cite it as:

Thomas Hiller. (2024, Feb 11). ThoHiller/nmr-nucleus: v0.2.1 (Version v0.2.1). Zenodo. [https://doi.org/10.5281/zenodo.4022195]

Note: Even though the version number might change due to updates, this DOI is permanent (represents all versions) and always links to the latest version.

References

  1. Costabel, S., Hiller, T. and Houben, G. "Nuclear magnetic resonance at the laboratory and field scale as a tool for detecting redox fronts in aquifers", GEOPHYSICS, 88(2), 2023, KS13-KS25, DOI
  2. Costabel, S., Hiller, T., Dlugosch, R., Kruschwitz, S. and Müller-Petke, M. "Evaluation of single-sided nuclear magnetic resonance technology for usage in geosciences", Measurement Science and Technology, 34(1), 2023, 015112, DOI
  3. Hiller, T., Costabel, S., Radic, T., Dlugosch, R. and Müller-Petke, M. "Feasibility study on prepolarized surface nuclear magnetic resonance for soil moisture measurements", Vadose Zone Journal, 20(5), 2021, e20138, DOI
  4. Costabel, S. and Hiller, T., "Soil hydraulic interpretation of nuclear magnetic resonance measurements based on circular and triangular capillary models", Vadose Zone Journal, 20(2), 2021, e20104, DOI
  5. Hiller, T. and Klitzsch, N., "Joint inversion of nuclear magnetic resonance data from partially saturated rocks using a triangular pore model", GEOPHYSICS, 83(4), JM15-JM28, 2018, DOI

MATLAB is a registered trademark of The Mathworks, Inc.