This file is indexed.

/usr/include/ASL/acl/aclMath/aclMathAlg.h is in libasl-dev 0.1.7-2.

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
/*
 * Advanced Simulation Library <http://asl.org.il>
 * 
 * Copyright 2015 Avtech Scientific <http://avtechscientific.com>
 *
 *
 * This file is part of Advanced Simulation Library (ASL).
 *
 * ASL is free software: you can redistribute it and/or modify it
 * under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, version 3 of the License.
 *
 * ASL 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 Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with ASL. If not, see <http://www.gnu.org/licenses/>.
 *
 */


#ifndef ACLMATHALG_H
#define ACLMATHALG_H

#include "aclVectorOfElementsDef.h"
#include "math/aslVectorsDynamicLength.h"

using namespace std;

namespace acl
{
	class ExpressionContainer;
	
	/// generates code for finding nearest direction from given directions set \p directions
	/**
		 \param directions vectors set defining directions
		 \param v the vector for which directions is seeked
		 \param iDir the number of vector is stored here
		 \param k the kernel for the generated code
	*/
	void findNearestDirectionCode(const vector<asl::AVec<>> & directions, 
	                           VectorOfElements v, 
	                           VectorOfElements iDir, 
	                           ExpressionContainer & k);

	/// generates code for finding nearest direction from given directions set \p directions
	/**
		 \param directions vector set defining directions the directions are normalized internaly
		 \param v the vector for which directions is seeked
		 \param iDir the number of vector is stored here
		 \param scalProd the scalar product of the vector with the corresponding normalized direction vector is stored here 
		 \param k the kernel for the generated code
	*/
	void findNearestDirectionCode(const vector<asl::AVec<>> & directions, 
	                           VectorOfElements v, 
	                           VectorOfElements iDir,
	                           VectorOfElements scalProduct,
	                           ExpressionContainer & k);

	/// generate expresion returning true if elements of v have different signs or one of them zerow 
	VectorOfElements differentSign(VectorOfElements v);

	/// generates Vector of elements wraping the \p a in order to avoid out of boundary acces
	VectorOfElements generateVEOutOfBoundarySafe(const VectorOfElements & a);	

	/// generates Vector of elements wraping the \p a in order to avoid out of boundary acces with given out of boundary value
	VectorOfElements generateVEOutOfBoundarySafe(const VectorOfElements & a, 
	                                             const VectorOfElements & outVal);	

	
}  //namespace acl

#endif // ACLMATHALG_H