Main Page | Namespace List | Class Hierarchy | Alphabetical List | Compound List | File List | Compound Members | File Members

PolynomialDelta.H

Go to the documentation of this file.
00001 /* _______              __
00002   / ___/ /  ___  __ _  / /  ___
00003  / /__/ _ \/ _ \/  ' \/ _ \/ _ \
00004  \___/_//_/\___/_/_/_/_.__/\___/ 
00005 */
00006 
00007 // PolynomialDeltaFn.H
00008 
00009 //
00010 // This software is copyright (C) by the Lawrence Berkeley
00011 // National Laboratory.  Permission is granted to reproduce
00012 // this software for non-commercial purposes provided that
00013 // this notice is left intact.
00014 // 
00015 // It is acknowledged that the U.S. Government has rights to
00016 // this software under Contract DE-AC03-765F00098 between
00017 // the U.S.  Department of Energy and the University of
00018 // California.
00019 //
00020 // This software is provided as a professional and academic
00021 // contribution for joint exchange. Thus it is experimental,
00022 // is provided ``as is'', with no warranties of any kind
00023 // whatsoever, no support, no promise of updates, or printed
00024 // documentation. By using this software, you acknowledge
00025 // that the Lawrence Berkeley National Laboratory and
00026 // Regents of the University of California shall have no
00027 // liability with respect to the infringement of other
00028 // copyrights by any part of this software.
00029 //
00030 // Dan Martin, Fri, Jan 14, 2000
00031 
00032 #ifndef _PolynomialDelta_H_
00033 #define _PolynomialDelta_H_
00034 
00035 #include "REAL.H"
00036 #include "DiscreteDeltaFn.H"
00037 #include "Vector.H"
00038 
00040 
00044 class PolynomialDelta : public DiscreteDeltaFn
00045 {
00046 public:
00048   PolynomialDelta();
00049   
00051   PolynomialDelta(Real a_epsilon);
00052   
00054   virtual ~PolynomialDelta();
00055   
00057   virtual void define(Real a_epsilon);
00058 
00060   virtual Real epsilon() const {return m_epsilon;};
00061   
00063   virtual DiscreteDeltaFn* clone() const;
00064 
00066   virtual Real evaluateDelta(Real a_radius) const;
00067 
00069   virtual Real integralDelta(Real a_radius) const;
00070   
00072   virtual Real computeK(RealVect& a_radius, int a_idir, int a_jdir) const;
00073   
00075 
00078   virtual void sumForce(FArrayBox& a_sum, 
00079                         const RealVect& a_force,
00080                         const Box& a_box,
00081                         const RealVect& a_position,
00082                         const RealVect& a_origin,
00083                         Real a_dx);
00084 
00085 
00087 
00092   virtual void sumForce(FArrayBox& a_sum, 
00093                         const RealVect& a_force,
00094                         const Box& a_box,
00095                         int a_dir, 
00096                         int a_destComp,
00097                         const RealVect& a_position,
00098                         const RealVect& a_origin,
00099                         Real a_dx);
00100 
00101 
00103   virtual Real computeLapDelta(Real a_radius) const;
00104 
00106   void setCoeffs(const Vector<Real>& a_coeffs);
00107 
00108   void setCoeff(Real a_coeff, int n);
00109 
00110   Vector<Real> getCoeffs() const;
00111   
00112 
00113 protected:
00114   
00116   Vector<Real> m_coeffs;
00117 
00119   Real m_epsilon;
00120 
00122   Real m_factor;
00123 
00124   // calls defineFactor, sets default polynomial
00125   void setDefaultValues();
00126 
00127   // define m_factor (uses m_epsilon, so that should be set first)
00128   void defineFactor();
00129 
00130 };
00131    
00132 
00133 
00134 #endif

Generated on Wed Jun 2 13:53:35 2004 for Chombo&INSwithParticles by doxygen 1.3.2