This file is indexed.

/usr/include/mia-2.4/mia/3d/distance.hh is in libmia-2.4-dev 2.4.6-1.

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
/* -*- mia-c++  -*-
 *
 * This file is part of MIA - a toolbox for medical image analysis 
 * Copyright (c) Leipzig, Madrid 1999-2017 Gert Wollny
 *
 * MIA is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with MIA; if not, see <http://www.gnu.org/licenses/>.
 *
 */

#ifndef mia_3d_distance_hh
#define mia_3d_distance_hh

#include <mia/core/iodata.hh>
#include <mia/3d/image.hh>


NS_MIA_BEGIN

/**
   This function evaluates the 3D distance transform of an input function. 
   If the input function is given as raw data that is not the result of another 
   call to this distance transform function, then one should call 
   distance_transform_prepare to properly prepare the data for the distance transform. 

   \param f squared values of the input function input 
   \returns the squared distance values for each grid point. 
*/

C3DFImage EXPORT_3D distance_transform(const C3DImage& f); 

/**
   \brief 3D distance transform for high resolution data 
   
   This class represents a 3D distance transform for high resolution data. Other than 
   distance_transform(const C3DImage& f), this class does not store the distances for the 
   whole grid. Instead the distances can ether be obtained slice-wise, or by evaluating 
   the distance at certain points. 

*/
class EXPORT_3D C3DDistance : public CIOData {
public: 

	/**
	   Initializes the distance transform 
	*/
	C3DDistance(); 

	~C3DDistance(); 

	C3DDistance(const C3DDistance& other) = delete;
	C3DDistance& operator =(const C3DDistance& other) = delete;
		
	/**
	   Add another z-slice to the distance transform. Note, the slices have to be 
	   added in the order of increasing z. 
	   Thr input data should be prepared using the distance_transform_prepare function. 
	   \param z current z-position 
	   \param slice of the function to measure the distance to 
	*/
	
	void push_slice(int z, const C2DImage& slice); 

	/**
	   Evaluate the distance of a point to the input function 
	   \param p point 
	   \returns the Euclidian distance of the point to the function 
	 */
	float get_distance_at(const C3DFVector& p) const;

	/**
	   Evaluate the distance of a slice to the represented input function 
	   \param z the slice to evaluate the distance to 
	   \returns a 2D data field of the squared distances
	*/
	C2DFImage get_distance_slice(int z) const; 
private: 
	struct C3DDistanceImpl *impl; 
}; 

NS_MIA_END

#endif