This file is indexed.

/usr/include/ITK-4.9/itkVectorCentralDifferenceImageFunction.hxx is in libinsighttoolkit4-dev 4.9.0-4ubuntu1.

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

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
/*=========================================================================
 *
 *  Copyright Insight Software Consortium
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0.txt
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 *=========================================================================*/
#ifndef itkVectorCentralDifferenceImageFunction_hxx
#define itkVectorCentralDifferenceImageFunction_hxx

#include "itkVectorCentralDifferenceImageFunction.h"

namespace itk
{
/**
 * Constructor
 */
template< typename TInputImage, typename TCoordRep >
VectorCentralDifferenceImageFunction< TInputImage, TCoordRep >
::VectorCentralDifferenceImageFunction()
{
  this->m_UseImageDirection = true;
}

/**
 *
 */
template< typename TInputImage, typename TCoordRep >
void
VectorCentralDifferenceImageFunction< TInputImage, TCoordRep >
::PrintSelf(std::ostream & os, Indent indent) const
{
  this->Superclass::PrintSelf(os, indent);
  os << indent << "UseImageDirection = " << this->m_UseImageDirection << std::endl;
}

/**
 *
 */
template< typename TInputImage, typename TCoordRep >
typename VectorCentralDifferenceImageFunction< TInputImage, TCoordRep >::OutputType
VectorCentralDifferenceImageFunction< TInputImage, TCoordRep >
::EvaluateAtIndex(const IndexType & index) const
{
  OutputType derivative;

  derivative.Fill(0.0);

  IndexType neighIndex = index;

  const typename InputImageType::SizeType & size =
    this->GetInputImage()->GetBufferedRegion().GetSize();
  const typename InputImageType::IndexType & start =
    this->GetInputImage()->GetBufferedRegion().GetIndex();

  for ( unsigned int dim = 0; dim < TInputImage::ImageDimension; dim++ )
    {
    // bounds checking
    if ( index[dim] < start[dim] + 1
         || index[dim] > ( start[dim] + static_cast< OffsetValueType >( size[dim] ) - 2 ) )
      {
      for ( unsigned int vdim = 0; vdim < Dimension; ++vdim )
        {
        derivative(vdim, dim) = 0.0;
        }
      continue;
      }

    // compute derivative
    const double deriv_weight = 0.5 / this->GetInputImage()->GetSpacing()[dim];

    neighIndex[dim] += 1;
    const InputPixelType & pixf = this->GetInputImage()->GetPixel(neighIndex);
    for ( unsigned int vdim = 0; vdim < Dimension; ++vdim )
      {
      derivative(vdim, dim) = pixf[vdim];
      }

    neighIndex[dim] -= 2;
    const InputPixelType & pixb = this->GetInputImage()->GetPixel(neighIndex);
    for ( unsigned int vdim = 0; vdim < Dimension; ++vdim )
      {
      derivative(vdim, dim) -= pixb[vdim];
      derivative(vdim, dim) *= deriv_weight;
      }

    neighIndex[dim] += 1;
    }

  if ( this->m_UseImageDirection )
    {
    OutputType orientedderivative;
    const typename InputImageType::DirectionType & direction =
      this->GetInputImage()->GetDirection();
    for ( unsigned int i = 0; i < TInputImage::ImageDimension; ++i )
      {
      std::vector< double > sums(Dimension, 0.0);
      for ( unsigned int j = 0; j < TInputImage::ImageDimension; ++j )
        {
        for ( unsigned int vdim = 0; vdim < Dimension; ++vdim )
          {
          sums[vdim] += direction[i][j] * derivative(vdim, j);
          }
        }
      for ( unsigned int vdim = 0; vdim < Dimension; ++vdim )
        {
        orientedderivative(vdim, i) = static_cast< TCoordRep >( sums[vdim] );
        }
      }
    return orientedderivative;
    }

  return ( derivative );
}
} // end namespace itk

#endif