Source code for unravel.image_tools.max
#!/usr/bin/env python3
"""
Use ``img_max`` (``max``) from UNRAVEL to load an image.nii.gz and print its max intensity value.
Usage:
------
img_max -i path/image.nii.gz [-v]
"""
import nibabel as nib
import numpy as np
from rich import print
from rich.traceback import install
from unravel.core.help_formatter import RichArgumentParser, SuppressMetavar, SM
from unravel.core.config import Configuration
from unravel.core.utils import log_command, verbose_start_msg, verbose_end_msg
[docs]
def parse_args():
parser = RichArgumentParser(formatter_class=SuppressMetavar, add_help=False, docstring=__doc__)
reqs = parser.add_argument_group('Required arguments')
reqs.add_argument('-i', '--input', help='path/image.nii.gz', required=True, action=SM)
general = parser.add_argument_group('General arguments')
general.add_argument('-v', '--verbose', help='Increase verbosity. Default: False', action='store_true', default=False)
return parser.parse_args()
[docs]
def find_max_intensity(file_path):
"""Find the maximum intensity value in the NIfTI image file."""
# Load the .nii.gz file
nii_img = nib.load(file_path)
# Get the data from the file
data = nii_img.get_fdata(dtype=np.float32)
# Find the maximum intensity value in the data
max_intensity = int(data.max())
return max_intensity
[docs]
@log_command
def main():
install()
args = parse_args()
Configuration.verbose = args.verbose
verbose_start_msg()
max_intensity = find_max_intensity(args.input)
print(max_intensity)
verbose_end_msg()
if __name__ == '__main__':
main()