This file is indexed.

/usr/bin/mincview is in minc-tools 2.2.00-3.

This file is owned by root:root, with mode 0o755.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
#! /bin/bash
#
# Script for viewing a minc file.
# uses display from ImageMagick to display the images.


PGM_CODE="P5"
PPM_CODE="P6"

# Check arguments
if [ $# -lt "1" ] || \
   [ $# -gt "2" ] || \
   [ "$1" = "-help" ] || \
   [ "$1" = "-h" ]
then
   cat <<END
Usage: $0 <infile.mnc> [<slice number>]

Images are displayed with the patients left on the left side
of the screen.

END
   exit -1
fi

infile="$1"

# Create temporary directory
tmpdir="/tmp/mincview-$$"

# cleanup nicely
trap "rm -rf $tmpdir" 0 1 2 3 13 15

mkdir -p $tmpdir

# Get dimension names
dims=( $(mincinfo -vardims image $infile ) )

echo " + Dimensions: ${dims[*]}"

# Check for vector dimension
pnm_code=$PGM_CODE
if [ "${dims[${#dims[*]} - 1]}" = "vector_dimension" ]
then
   ndims=$(( ${#dims[*]} - 1 ))
   nvec=$(mincinfo $infile -dimlength $dims[$#dims])
   start_suffix=",0"
   if [ $nvec != 3 ]
   then
      count_suffix=",1"
   else
      count_suffix=",3"
      pnm_code=$PPM_CODE
   fi
else
   ndims="${#dims[*]}"
   start_suffix=""
   count_suffix=""
fi

echo " + ndims: $ndims"

if [ $ndims -gt 3 ]
then
   nprefix=$(( $ndims - 3 ))
   start_prefix=$(awk 'BEGIN{for (i=0;i<$nprefix;i++) print "0,"}' < /dev/null)
   count_prefix=$(awk 'BEGIN{for (i=0;i<$nprefix;i++) print "1,"}' < /dev/null)
elif [ $ndims -lt "2" ]
then
   echo "No image found in file $infile"
   exit -1
else
   start_prefix=""
   count_prefix=""
fi

# Get number of slices and image dimensions
ind1=$(( $ndims - 3 ))
ind2=$(( $ndims - 2 ))
ind3=$(( $ndims - 1 ))
if [ $ind1 -gt "-1" ]
then
   nslices=$(mincinfo $infile -dimlength ${dims[$ind1]})
else
   nslices=1
fi

# figure out which slices to get
allslices=$(seq 0 $(($nslices - 1)))
slices_to_get=${2:-"$allslices"}

if [ "$slices_to_get" = "$2" ]
then
   if [ "$slices_to_get" -ge "$nslices" ] || [ "$slices_to_get" -lt "0" ]
   then
      echo ""
      echo "$0: Slice number $slices_to_get out of range (0-$nslices)"
      echo ""
      exit -1
   fi
fi

# Check for inverting images to get standard orientation
imgsize=( $(mincinfo -dimlength ${dims[$ind2]} -dimlength ${dims[$ind3]} $infile) )
echo " + imgsize: ${imgsize[0]}x${imgsize[1]}"
echo " + nslices $nslices"

# Loop through slices, if needed
echo -n "Loading slices"
for slice in $slices_to_get
do
   echo -n "."
   if [ $ndims -gt 2 ]
   then
      start="${start_prefix}$slice,0,0${start_suffix}"
      count="${count_prefix}1,${imgsize[0]},${imgsize[1]}${count_suffix}"
   else
      start="0,0$start_suffix"
      count="${imgsize[0]},${imgsize[1]}$count_suffix"
   fi
   output_file=$(printf "$tmpdir/slice-%04d.pgm" $slice)
   echo "$pnm_code" > $output_file
   echo "${imgsize[1]} ${imgsize[0]}" >> $output_file
   echo "255" >> $output_file
   mincextract -byte \
      -start $start \
      -count $count \
      -positive_direction \
      $infile >> $output_file
   
   slice=$(($slice + 1))
done
echo "Done"

cat <<END
--------------------------------------------------------------
Images are now being displayed with display from ImageMagick.

Use <space> to advance to the next image

The image number is displayed in the title of the window
--------------------------------------------------------------

END

# Display the images
display -monitor -geometry 512x512 -flip $tmpdir/slice-*.pgm