mirror of
https://github.com/glatterf42/music-panphasia.git
synced 2024-09-11 06:53:45 +02:00
189 lines
4.8 KiB
C++
189 lines
4.8 KiB
C++
/*
|
|
|
|
poisson.cc - This file is part of MUSIC -
|
|
a code to generate multi-scale initial conditions
|
|
for cosmological simulations
|
|
|
|
Copyright (C) 2010 Oliver Hahn
|
|
|
|
*/
|
|
|
|
#ifndef __POISSON_HH
|
|
#define __POISSON_HH
|
|
|
|
#include <string>
|
|
#include <map>
|
|
|
|
#include "general.hh"
|
|
#include "mesh.hh"
|
|
|
|
//! abstract base class for Poisson solvers and gradient calculations
|
|
class poisson_plugin
|
|
{
|
|
protected:
|
|
|
|
//! reference to the config_file object that holds all configuration options
|
|
config_file& cf_;
|
|
|
|
public:
|
|
|
|
//! constructor
|
|
explicit poisson_plugin( config_file& cf )
|
|
: cf_(cf)
|
|
{ }
|
|
|
|
//! destructor
|
|
virtual ~poisson_plugin()
|
|
{ }
|
|
|
|
//! solve Poisson's equation Du=f
|
|
virtual double solve( grid_hierarchy& f, grid_hierarchy& u ) = 0;
|
|
|
|
//! compute the gradient of u
|
|
virtual double gradient( int dir, grid_hierarchy& u, grid_hierarchy& Du ) = 0;
|
|
|
|
//! compute the gradient and add
|
|
virtual double gradient_add( int dir, grid_hierarchy& u, grid_hierarchy& Du ) = 0;
|
|
|
|
};
|
|
|
|
#pragma mark -
|
|
|
|
/*!
|
|
* @brief implements abstract factory design pattern for poisson solver plug-ins
|
|
*/
|
|
struct poisson_plugin_creator
|
|
{
|
|
//! create an instance of a plug-in
|
|
virtual poisson_plugin * create( config_file& cf ) const = 0;
|
|
|
|
//! destroy an instance of a plug-in
|
|
virtual ~poisson_plugin_creator() { }
|
|
};
|
|
|
|
//! maps the name of a plug-in to a pointer of the factory pattern
|
|
std::map< std::string, poisson_plugin_creator *>& get_poisson_plugin_map();
|
|
|
|
//! print a list of all registered output plug-ins
|
|
void print_poisson_plugins();
|
|
|
|
|
|
/*!
|
|
* @brief concrete factory pattern for output plug-ins
|
|
*/
|
|
template< class Derived >
|
|
struct poisson_plugin_creator_concrete : public poisson_plugin_creator
|
|
{
|
|
//! register the plug-in by its name
|
|
poisson_plugin_creator_concrete( const std::string& plugin_name )
|
|
{
|
|
get_poisson_plugin_map()[ plugin_name ] = this;
|
|
}
|
|
|
|
//! create an instance of the plug-in
|
|
poisson_plugin * create( config_file& cf ) const
|
|
{
|
|
return new Derived( cf );
|
|
}
|
|
};
|
|
|
|
/**************************************************************************************/
|
|
/**************************************************************************************/
|
|
#pragma mark -
|
|
|
|
//! adaptive FAS multigrid implementation of abstract base class poisson_plugin
|
|
class multigrid_poisson_plugin : public poisson_plugin
|
|
{
|
|
public:
|
|
|
|
//! constructor
|
|
explicit multigrid_poisson_plugin( config_file& cf )
|
|
: poisson_plugin( cf )
|
|
{ }
|
|
|
|
//! solve Poisson's equation Du=f
|
|
double solve( grid_hierarchy& f, grid_hierarchy& u );
|
|
|
|
//! compute the gradient of u
|
|
double gradient( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
|
|
//! compute the gradient and add
|
|
double gradient_add( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
|
|
protected:
|
|
|
|
//! various FD approximation implementations
|
|
struct implementation
|
|
{
|
|
//! solve 2nd order FD approximation to Poisson's equation
|
|
double solve_O2( grid_hierarchy& f, grid_hierarchy& u );
|
|
|
|
//! solve 4th order FD approximation to Poisson's equation
|
|
double solve_O4( grid_hierarchy& f, grid_hierarchy& u );
|
|
|
|
//! solve 6th order FD approximation to Poisson's equation
|
|
double solve_O6( grid_hierarchy& f, grid_hierarchy& u );
|
|
|
|
//! compute 2nd order FD gradient
|
|
void gradient_O2( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
|
|
//! compute and add 2nd order FD gradient
|
|
void gradient_add_O2( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
|
|
//! compute 4th order FD gradient
|
|
void gradient_O4( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
|
|
//! compute and add 4th order FD gradient
|
|
void gradient_add_O4( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
|
|
//! compute 6th order FD gradient
|
|
void gradient_O6( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
|
|
//! compute and add 6th order FD gradient
|
|
void gradient_add_O6( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
};
|
|
};
|
|
|
|
/**************************************************************************************/
|
|
/**************************************************************************************/
|
|
#pragma mark -
|
|
|
|
//! FFT based implementation of abstract base class poisson_plugin
|
|
class fft_poisson_plugin : public poisson_plugin
|
|
{
|
|
public:
|
|
|
|
//! constructor
|
|
explicit fft_poisson_plugin( config_file& cf )
|
|
: poisson_plugin( cf )
|
|
{ }
|
|
|
|
//! solve Poisson's equation Du=f
|
|
double solve( grid_hierarchy& f, grid_hierarchy& u );
|
|
|
|
//! compute the gradient of u
|
|
double gradient( int dir, grid_hierarchy& u, grid_hierarchy& Du );
|
|
|
|
//! compute the gradient and add
|
|
double gradient_add( int dir, grid_hierarchy& u, grid_hierarchy& Du ){ return 0.0; }
|
|
|
|
|
|
};
|
|
|
|
/**************************************************************************************/
|
|
/**************************************************************************************/
|
|
#pragma mark -
|
|
|
|
template< typename T >
|
|
void poisson_hybrid( T& f, int idir, int order, bool periodic, bool deconvolve_cic );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif // __POISSON_HH
|
|
|