This file is indexed.

/usr/include/ASL/numExtend/aslFDAdvectionDiffusionExtended.h is in libasl-dev 0.1.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
 94
 95
 96
 97
 98
 99
100
/*
 * 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 ASLFDADVECTIONDIFFUSION_H
#define ASLFDADVECTIONDIFFUSION_H

#include "../num/aslNumMethod.h"


namespace acl{
	class Kernel;
	class VectorOfElementsData;
}

namespace asl
{
	class VectorTemplate;
	template <typename V> class DataWithGhostNodes;
	typedef DataWithGhostNodes<acl::VectorOfElementsData> DataWithGhostNodesACLData;
	typedef std::shared_ptr<DataWithGhostNodesACLData> SPDataWithGhostNodesACLData;
	class AbstractDataWithGhostNodes;
	typedef std::shared_ptr<AbstractDataWithGhostNodes> SPAbstractDataWithGhostNodes;
	
	/// Numerical method which computes multicomponent transport processes
	/**
		 \ingroup TransportProcesses
		 \f[ \partial_t c_i= D_i \Delta c_i 
		    					-\nabla\left(\frac{c_i q}{k} \nabla(\phi+f_2)  \right)\f]
		 where
		 \param cData corresponds to \f$c_i\f$
		 \param diffusionCoefficient corresponds to \f$D_i\f$
		 \param efFactor1 corresponds to \f$k\f$
		 \param efFactor2 corresponds to \f$f_2\f$
		 \param efPhi corresponds to \f$\phi\f$
		 \param efChargeAnd corresponds to \f$q\f$

		 This class contains filtering which forbits the local value of 
		 \f$ \frac{q}{k} \nabla(\phi+f_2) \f$ to be larger than \f$0.2\f$
	 */
	class FDAdvectionDiffusionExtended: public NumMethod
	{
		public:
			typedef SPDataWithGhostNodesACLData Data;
			typedef SPAbstractDataWithGhostNodes ScalarField;
		private:
			std::unique_ptr<acl::Kernel> kernel; 
			
			std::vector<Data> cData;
			std::vector<Data> cInternalData;			

			bool electricField;
			ScalarField efPhi;
			ScalarField efFactor1;
			ScalarField efFactor2;
			std::vector<ScalarField> efChargeAnd;
				
			const VectorTemplate* vectorTemplate;

			int t;
			std::vector<double> diffusionCoefficient;
		public:			
			FDAdvectionDiffusionExtended();
			FDAdvectionDiffusionExtended(Data c, double dC,const VectorTemplate* vT);
			void setDiffusionCoefficient(double d, unsigned int i=0);
			double getDiffusionCoefficient(unsigned int i=0);
			void setVectorTemplate(VectorTemplate* vT);
			VectorTemplate setVectorTemplate(const VectorTemplate* vT);
			void setElectricFieldParameters(ScalarField phi, ScalarField f1, ScalarField f2, ScalarField qAnd);
			virtual void init();
			virtual void execute();
			void addComponent(Data c, double dC);
			void addComponent(Data c, double dC, ScalarField qAnd);			
			
	};

	typedef std::shared_ptr<FDAdvectionDiffusionExtended> SPFDAdvectionDiffusionExtended;

		
} // asl
#endif // ASLFDADVECTIONDIFFUSION_H