This repository provides C++ and CUDA C++ source code and a UNIX build for iterative nonlocal means denoising (iterNLM). The denoiser is designed to handle correlated noise footprints characteristic to postreconstruction denoising problems of tomography reconstructions. It is based on the works by Antoni Buades et al.:
-
Buades, A.; Coll, B.; Morel, J.M. Multiscale Model. Simul. 2005, 4(2), 490–530. "A review of image denoising algorithms, with a new one", doi: 10.1137/040616024.
-
Coupé, P.; Yger, P.; Prima, S.; Hellier, P.; Kervrann, C.; Barillot, C. IEEE T. Med. Imaging 2008, 27(4), 425–441. "An optimized blockwise nonlocal means denoising filter for 3-D magnetic resonance images", doi: 10.1109/TMI.2007.906087.
The iterative implementation of the NLM algorithm enables targeted removal of textures with few redundacies and low contrast-to-noise ratio. Such textures are characteristic to backprojected noise and artefacts in high resolution tomography. A publication providing benchmark results and discussing the quality, implementation and range of application of the iterative NLM procedure has been published in Advances in Water Resources. Please consider citing it when you decide to use the algorithm:
- Bruns, S.; Stipp, S.L.S.; Sørensen, H.O. Adv. Water Res. 2017, 105, 96-107. "Looking for the Signal: A Guide to Iterative Noise and Artefact Removal in X-ray Tomography Reconstructions of Porous Geomaterials", doi: 10.1016/j.advwatres.2017.04.020.
As of 06.12.2019 the prototype programs nanotomodenoise and microtomodenoise have been replace by iterNLM_v0.3 with the following changes and improvements:
- severly reduced memory requirements
- improved speed in CPU mode by a factor of ~1.5 and added GPU and multiGPU support for further speed improvements (cf. below)
- added individual kernel functions for patch radii of up to 3
- added a countdown timer for expected runtime
- incorporate automated noise estimation and various options for setting the noise and texture level (cf. below)
- added basic support for Poisson noise corrupted 2D RGB TIF images in CPU mode
Required libraries are LibTiff and OpenMP. The source code should compile on most Linux distributions by providing the location of your nvcc compiler and the CUDA compute capability of your GPU in the script file make_iternlm.sh. Without the latter set the compute capability to 0. Execute with
sh make_iternlm.sh
which will provide an executable iterNLM in the same directory.
The currently available implementation is limited to 8 bit, 16 bit, 32 bit greyscale TIF image sequences and spatially uniform noise levels in XY. With default settings the noise level is evaluated with a z-adaptive moving window. ImageJ 3D tifs are supported but require the --blocks option in CPU mode. We rarely use 2D, RGB or denoising of spatially varying noise, i.e. the code is less maintained.
It is not necessary to set the noise level manually but when using a manual noise estimate the noise level (s0) and texture level (s1) need to be provided manually before and after the first denoising iteration. The easiest way to do this is to select (expected) uniform regions in the image and measure the standard deviation several times. Use a lower boundary estimate and run a single iteration of denoising before repeating the procedure to estimate s1.
The program is best run from the command line by calling iterNLM with the following program arguments:
argument | value | explanation |
---|---|---|
-i | /directory/with/noisy/images/ | (mandatory) input directory with tiff image sequence |
-o | /output/directory/ | (optional) default output is 1 level above input directory. Separate outputs are generated for each iteration. |
-a | 0 > float >= 1 | (optional, default=0.5) weighting parameter alpha for s0 and s1. Lower alphas preserve more detail. Higher alphas impose stronger artefact removal. |
-noise | string | (optional, default=z-adaptive, valid=global, z-adaptive, semimanual or manual) determines a mode for how the noise level is estimated (cf. below) |
-search | integer | (optional) set all dimensions of the search space to a uniform radius. 5 may be preferable when there is only backprojected noise and little artefacts. |
--cleanup | (optional) only keep the final denoising result on the HDD. By default every iteration is exported. |
The straightforward program call would thus be:
./iterNLM -i /directory/with/noisy/images/
Available modes for setting the noise and texture level (-noise):
- global (calculates the variance in 2D patches and separates the result in two clusters. The lower value is the noise estimate.)
- z-adaptive (The same as above but instead of a uniform noise level a moving window of 100 slices is considered. Especially useful for zoom-tomography in irregular shaped samples.)
- semimanual (Provide the noise level s0. A patch with a similar variance is selected and used to estimate the texture level.)
- manual (Provide the noise level s0 and the texture level s1 manually.)
argument | value | explanation |
---|---|---|
-iter | integer | (optional, default=4) number of denoising iterations |
-a | 0 > float >= 1 | (optional, default=0.5) weighting parameter alpha for s0 and s1. Lower alphas preserve more detail. Higher alphas impose stronger artefact removal. |
-slices | integer | (optional, default=11) amount of 3D information used for denoising the central slice. Default settings are high quality requiring plenty of resources. 7 or 5 are usually sufficient for avoiding artefacts in z-direction. Try reverting to 3 slices on older machines. |
-search0 | integer | (optional, default=10) radius of the search space in the first dimension |
-search1 | integer | (optional, default=10) radius of the search space in the second dimension |
-search2 | integer | (optional, default=10) radius of the search space in the third dimension |
-search | integer | (optional) set all dimensions of the search space to a uniform radius. 5 may be preferable when there is only backprojected noise and little artefacts. |
-patch0 | integer | (optional, default=1) radius of the patch space in the first dimension |
-patch1 | integer | (optional, default=1) radius of the patch space in the second dimension |
-patch2 | integer | (optional, default=1) radius of the patch space in the third dimension |
-patch | integer | (optional) set all dimensions to a uniform radius. For soft tissue images a value of 2 or 3 may (or may not) be more suited |
argument | value | explanation |
---|---|---|
-noise | string | (optional, default=z-adaptive) determines a mode for how the noise level is estimated (cf. above) |
-noiseshift | float | (optional, default=1) shift the estimated noise level by noiseshift times the standard deviation of the noise estimate |
-s | float | (optional) set both noise levels at once. Equivalent to alpha=1 |
-s0 | float | (optional) allows setting the noise level manually |
-s1 | float | (optional) allows setting the texture level manually = noise standard deviation after 1 denoising iteration |
-nsamples | integer | (optional, default=1e5) number of samples drawn for estimating the noise level |
-noisepatch | integer | (optional, default=15) size of 2D window used for automatic noise estimation |
--continuous | update the noise estimate after every iteration and not only the first two (not recommended) |
argument | value | explanation |
---|---|---|
-cpus | integer | (optional, default=128) Provides an upper limit to the amount of threads used by the CPU. |
-gpus | integer | (optional, default=2) Provides an upper limit to the amount of GPUs used by the denoiser. |
-gpu0 | integer | (optional, default=0) device ID of the first GPU used by the denoiser. Use this when you have multiple GPUs and GPU0 is already occupied. |
--noblocks | (optional) keep everything in host RAM. This is default in GPU mode but may speed-up CPU mode. By default active slices are grabbed from the HDD when required to save on memory requirements. | |
--blocks | (optional) When low on host memory this should help. Forces the program to only read into memory what is currently needed. | |
--v | (optional) verbose mode currently only provides an estimate of the memory requirement in CPU mode. Might be helpful if you encounter crashes. | |
-threads | integer | (optional, default=128) sets threadsPerBlock in CUDA. No reason to touch this. |
argument | value | explanation |
---|---|---|
--color | activates the RGB denoiser | |
--nopoisson | when images are corrupted with Gaussian noise only | |
--noaverage | by default the noise level is averaged across all channels. Keep an individual estimate for each channel with this option | |
--independent | by default image similarity is measured across R,G and B channel. Choose this option for denoising them independently |
argument | value | explanation |
---|---|---|
--resume | (optional) tries resuming a previously interrupted denoising job | |
--16bit | (optional) allows safing disk space by only generating 16bit results | |
-fs | integer | (optional) subset denoising, first slice |
-ls | integer | (optional) subset denoising, last slice |
Please contact stefan.bruns@hereon.de or henning.osholm@gmail.com for assistance, requests or recommendations.
Applications in science:
- Nielsen,M. S.; Munk, M. B.; Diaz, A.; Pedersen, E. B. L.; Holler, M.; Bruns, S.; Risbo, J.; Mortensen, K.; Feidenhans’l, R. K. Food Structure 2016, 7, 21–28. “Ptychographic X-ray Computed Tomography of Extended Colloidal Networks in Food Emulsions”, doi: 10.1016/j.foostr.2016.01.001.
- Bruns, S.; Stipp, S. L. S.; Sørensen, H. O. Adv. Water. Res. 2017, 107, 32-42. “Statistical Representative Elementary Volumes of Porous Media determined using Greyscale Analysis of 3D Tomograms”, doi: 10.1016/j.advwatres.2017.06.002.
- Yang, Y.; Bruns, S.; Stipp, S. L. S.; Sørensen, H. O. Environ. Sci. Technol. 2017, 51(14), 7982-7991, “Dissolved CO 2 stabilizes Dissolution Front and increases Breakthrough Porosity of Natural Porous Materials”, doi: 10.1021/acs.est.7b02157.
- Chavez Panduro, E. A.; Torsæter, M.; Gawel, K.; Bjørge, R.; Gibaud, A.; Yang, Y.; Bruns, S.; Zheng, Y.; Sørensen, H. O.; Breiby, D. Environ. Sci. Technol. 2017, 51(16), 9344-9351. “In-situ X-ray Tomography Study of Cement exposed to CO 2 Saturated Brine“, doi: 10.1021/acs.est.6b06534.
- Yousefi, N.; Wong, K.; Hosseinidoust, Z.; Sørensen, H.O.; Bruns, S.; Zheng, Y.; Tufenkji, N Nanoscale 2018, 10(15), 7171-7184. "Ultra-strong graphene oxide-cellulose nanocrystal nanohybrid sponges for efficient water treatment", doi: 10.1039/c7nr09037d.
- Yang, Y.; Bruns, S.; Rogowska, M.; Hakim, S. S.; Hammel, J.; Stipp, S. L. S.; Sørensen, H. O. Sci. Rep. 2018, 8, 5693. “Retraction of the Dissolution Front in Natural Porous Media”, doi: 10.1038/s41598-018-23823-3.
- Yang, Y.; Bruns, S.; Stipp, S. L. S.; Sørensen, H. O. Adv. Water. Res. 2018, 115, 151-159. “Impact of microstructure evolution on the difference between geometric and reactive surface areas in natural chalk”., doi: 10.1016/j.advwatres.2018.03.005.
- Yang, Y.; Hakim, S. S.; Bruns, S.; Rogowska, M.; Böhnert, S.; Hammel, J.; Stipp, S. L. S.; Sørensen, H. O. ACS Earth Space Chem. 2018, 2(6), 618-633. “Direct Observation of Coupled Geochemical and Geomechanical Impacts on Chalk Microstructure Evolution under Elevated CO2 Pressure”, doi: 10.1021/acsearthspacechem.8b00013.
- Yang, Y.; Bruns, S.; Stipp, S. L. S.; Sørensen, H. O. PLoS One 2018. “Patterns of entropy production in dissolving natural porous media with flowing fluid”, doi: 10.1371/journal.pone.0204165.
- Yang, Y.; Rogowska, M.; Zheng, Y.; Bruns, S.; Gundlach, C.; Stipp, S. L. S.; Sørensen, H. O. J. Hydrol. 2019, 571, 21-35. “Transient increase in reactive surface and the macroscopic Damkohler number in chalk dissolution”, doi: 10.1016/j.jhydrol.2019.01.032.
- Yang, Y.; Hakim, S. S.; Bruns, S.; Uesugi, K.; Stipp, S. L. S.; Sørensen, H. O. Water Resour. Res. 2019, 55(6), 4801-4819. “Effect of Cumulative Surface on Pore Development in Chalk”, doi: 10.1029/2018WR023756.
- Zeller-Plumhoff, B.; Robisch, A.-L.; Pelliccia, D.; Longo, E.; Slominska, H.; Hermann, A.; Krenkel, M.; Storm, M.; Estrin, Y.; Willumeit-Römer, R.; Salditt, T.; Orlov, D. Sci. Rep. 2020, 10,16101. "Nanotomographic evaluation of precipitate structure evolution in a Mg–Zn–Zr alloy during plastic deformation", doi: 10.1038/s41598-020-72964-x.
- Sartori, J.; Kohring, S.; Bruns, S.; Moosmann, J.; Hammel, J.U. Adv. Eng. Mater. 2021, 2100085. "Gaining Insight into the Deformation of Achilles Tendon Entheses in Mice", doi:10.1002/adem.202100085.
- Rasmussen, P.W.; Sørensen, H.O.; Bruns, S.; Dahl, A.B.; Christensen, A.N. Sci. Rep. 2021 11(1), 12501. "Improved dynamic imaging of multiphase flow by constrained tomographic reconstruction", doi: 10.1038/s41598-021-91776-1.
- Schmelzle, S.; Bruns, S.; Beckmann, F.; Moosmann, J.; Lautner, S. Adv. Eng. Mater. 2021, 2100235. "Using In Situ Synchrotron-Radiation-Based Microtomography to Investigate 3D Structure-Dependent Material Properties of Tension Wood", doi:10.1002/adem.202100235.
- Tolnai, D.; Gavras, S.; Wilde, F.; Hammel, J.U.; Bruns, S. Adv. Eng. Mater. 2021, 2100383. "In Situ Synchrotron Tomography of the Solidification of an Elektron 21 Mg Alloy", doi:10.1002/adem.202100383.
- Zeller-Plumhoff, B.; Laipple, D.; Slominska, H.; Iskhakova, K.; Longo, E.; Hermann, A.; Flenner, S.; Greving, I.; Storm, M.; Willumeit-Romer, R. Bioact. Mater. 2021, 6(12), 4368-4376. "Evaluating the morphology of the degradation layer of pure magnesium via 3D imaging at resolutions below 40 nm", doi:10.1016/j.bioactmat.2021.04.009.
- Flenner, S.; Bruns, S.; Longo, E.; Parnell, A. J.; Stockhausen, K. E.; Muller, M.; Greving, I. J. Synchr. Rad. 2022, 29, 230-238. "Machine learning denoising of high-resolution X-ray nanotomography data", doi:10.1107/S1600577521011139.
- Hauck, M.; Dittmann, J.; Zeller-Plumhoff, B.; Madurawala, R.; Hellmold, D.; Kubelt, C.; Synowitz, M.; Held-Feindt, J.; Adelung, R.; Wulfinghoff, S.; Schutt, F. Pharmaceutics 2022, 14(4), 777. "Fabrication and Modelling of a Reservoir-Based Drug Delivery System for Customizable Release", doi:10.3390/pharmaceutics14040777.
- Sommer, N. G.; Hirzberger, D.; Paar, L.; Berger, L.; Cwieka, H.; Schwarze, U. Y.; Herber, V.; Okutan, B.; Bodey, A. J.; Willumeit-Romer, R.; Zeller-Plumhoff, B.; Loffler, J. F.; Weinberg, A. M. Acta Biomater. 2022, 147, 427-438. "Implant degradation of low-alloyed Mg-Zn-Ca in osteoporotic, old and juvenile rats", doi:10.1016/j.actbio.2022.05.041.
- Schiefler, A. A.; Bruns, S.; Müter, D.; Uesugi, K.; Sørensen, H. O.; Tobler, D.J. Environ. Sci. Nano 2022, 9(9), 3439-3455. "Retention of sulfidated nZVI (S-nZVI) in porous media visualized by X-ray mu-CT - the relevance of pore space geometry", doi:10.1039/d2en00224h.
- Okumura, S. H.; Mujin, M.; Tsuchiyama, A.; Miyake, A. Amer. Mineral. 2022 107(9), 1766-1778. "D crystal size distributions of pyroxene nanolites from nano X-ray computed tomography: Improved correction of crystal size distributions from CSDCorrections for magma ascent dynamics in conduits", doi:10.2138/am-2022-8039