-
Notifications
You must be signed in to change notification settings - Fork 240
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add random initial perturbations #1813
Changes from all commits
57c6197
5d404bd
74c448a
8adabe3
c3878da
c0a5220
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
New: A new initial temperature condition was added that adds random | ||
noise of user prescribed magnitude to the initial temperature field. | ||
The same type of plugin was added for initial compositions. | ||
<br> | ||
(Rene Gassmoeller, 2017/06/19) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
/* | ||
Copyright (C) 2017 by the authors of the ASPECT code. | ||
|
||
This file is part of ASPECT. | ||
|
||
ASPECT 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 2, or (at your option) | ||
any later version. | ||
|
||
ASPECT 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 ASPECT; see the file doc/COPYING. If not see | ||
<http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
|
||
#ifndef _aspect_initial_composition_random_perturbation_h | ||
#define _aspect_initial_composition_random_perturbation_h | ||
|
||
#include <aspect/initial_composition/interface.h> | ||
|
||
DEAL_II_DISABLE_EXTRA_DIAGNOSTICS | ||
#include <boost/random.hpp> | ||
DEAL_II_ENABLE_EXTRA_DIAGNOSTICS | ||
|
||
namespace aspect | ||
{ | ||
namespace InitialComposition | ||
{ | ||
using namespace dealii; | ||
|
||
/** | ||
* A class that describes a perturbation for the initial composition fields | ||
* for any geometry model or dimension. The perturbation follows | ||
* a random noise of a prescribed magnitude. | ||
* | ||
* @ingroup InitialCompositions | ||
*/ | ||
template <int dim> | ||
class RandomPerturbation : public Interface<dim> | ||
{ | ||
public: | ||
/** | ||
* Return the initial temperature as a function of position. | ||
*/ | ||
virtual | ||
double initial_composition (const Point<dim> &position, | ||
const unsigned int compositional_index) const; | ||
|
||
/** | ||
* Declare the parameters this class takes through input files. | ||
*/ | ||
static | ||
void | ||
declare_parameters (ParameterHandler &prm); | ||
|
||
/** | ||
* Read the parameters this class declares from the parameter file. | ||
*/ | ||
virtual | ||
void | ||
parse_parameters (ParameterHandler &prm); | ||
|
||
|
||
private: | ||
/** | ||
* The maximal magnitude of the random noise. | ||
*/ | ||
double magnitude; | ||
|
||
/** | ||
* Whether to use a random seed for the random | ||
* number generator. This parameter controls whether | ||
* this plugin generates different or identical | ||
* perturbations for subsequent model runs of | ||
* the same setup. | ||
*/ | ||
bool use_random_seed; | ||
}; | ||
} | ||
} | ||
|
||
#endif |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
/* | ||
Copyright (C) 2017 by the authors of the ASPECT code. | ||
|
||
This file is part of ASPECT. | ||
|
||
ASPECT 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 2, or (at your option) | ||
any later version. | ||
|
||
ASPECT 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 ASPECT; see the file doc/COPYING. If not see | ||
<http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
|
||
#ifndef _aspect_initial_temperature_random_perturbation_h | ||
#define _aspect_initial_temperature_random_perturbation_h | ||
|
||
#include <aspect/initial_temperature/interface.h> | ||
|
||
DEAL_II_DISABLE_EXTRA_DIAGNOSTICS | ||
#include <boost/random.hpp> | ||
DEAL_II_ENABLE_EXTRA_DIAGNOSTICS | ||
|
||
namespace aspect | ||
{ | ||
namespace InitialTemperature | ||
{ | ||
using namespace dealii; | ||
|
||
/** | ||
* A class that describes a perturbation for the initial temperature field | ||
* for any geometry model or dimension. The perturbation follows | ||
* a random noise of a prescribed magnitude. | ||
* | ||
* @ingroup InitialTemperatures | ||
*/ | ||
template <int dim> | ||
class RandomPerturbation : public Interface<dim> | ||
{ | ||
public: | ||
/** | ||
* Return the initial temperature as a function of position. | ||
*/ | ||
virtual | ||
double initial_temperature (const Point<dim> &position) const; | ||
|
||
/** | ||
* Declare the parameters this class takes through input files. | ||
*/ | ||
static | ||
void | ||
declare_parameters (ParameterHandler &prm); | ||
|
||
/** | ||
* Read the parameters this class declares from the parameter file. | ||
*/ | ||
virtual | ||
void | ||
parse_parameters (ParameterHandler &prm); | ||
|
||
|
||
private: | ||
/** | ||
* The maximal magnitude of the random noise. | ||
*/ | ||
double magnitude; | ||
|
||
/** | ||
* Whether to use a random seed for the random | ||
* number generator. This parameter controls whether | ||
* this plugin generates different or identical | ||
* perturbations for subsequent model runs of | ||
* the same setup. | ||
*/ | ||
bool use_random_seed; | ||
}; | ||
} | ||
} | ||
|
||
#endif |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,118 @@ | ||
/* | ||
Copyright (C) 2017 by the authors of the ASPECT code. | ||
|
||
This file is part of ASPECT. | ||
|
||
ASPECT 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 2, or (at your option) | ||
any later version. | ||
|
||
ASPECT 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 ASPECT; see the file doc/COPYING. If not see | ||
<http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
|
||
#include <aspect/initial_composition/random_perturbation.h> | ||
|
||
#include <boost/functional/hash.hpp> | ||
#include <time.h> | ||
|
||
namespace aspect | ||
{ | ||
namespace InitialComposition | ||
{ | ||
namespace | ||
{ | ||
template<int dim> | ||
std::size_t point_hash(const Point<dim> &position) | ||
{ | ||
std::size_t hash; | ||
|
||
for (unsigned int i = 0; i < dim; ++i) | ||
boost::hash_combine(hash,position[i]); | ||
|
||
return hash; | ||
} | ||
} | ||
Comment on lines
+33
to
+43
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This function would require documentation. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Also, you could use |
||
|
||
template <int dim> | ||
double | ||
RandomPerturbation<dim>:: | ||
initial_composition (const Point<dim> &position, | ||
const unsigned int compositional_index) const | ||
{ | ||
std::size_t seed = point_hash(position); | ||
boost::hash_combine(seed,compositional_index); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. nice idea! |
||
if (use_random_seed) | ||
boost::hash_combine(seed,time(NULL)); | ||
|
||
boost::mt19937 random_number_generator(seed); | ||
Comment on lines
+53
to
+56
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should all be std:: facilities now. Same for everything below that uses boost. |
||
|
||
// Uniform distribution on the interval [-magnitude,magnitude). This | ||
// will be used to generate the random composition perturbation. | ||
boost::random::uniform_real_distribution<double> uniform_distribution(-magnitude,magnitude); | ||
return uniform_distribution(random_number_generator); | ||
} | ||
|
||
template <int dim> | ||
void | ||
RandomPerturbation<dim>::declare_parameters (ParameterHandler &prm) | ||
{ | ||
prm.enter_subsection ("Initial composition model"); | ||
{ | ||
prm.enter_subsection("Random perturbation"); | ||
{ | ||
prm.declare_entry ("Magnitude", "1.0", | ||
Patterns::Double (0), | ||
"The magnitude of the random perturbation."); | ||
prm.declare_entry ("Use random seed", "false", | ||
Patterns::Bool(), | ||
"Whether to use a random seed for the random " | ||
"number generator. This parameter controls whether " | ||
"this plugin generates different or identical " | ||
"perturbations for subsequent model runs of" | ||
"the same setup."); | ||
} | ||
prm.leave_subsection (); | ||
} | ||
prm.leave_subsection (); | ||
} | ||
|
||
|
||
template <int dim> | ||
void | ||
RandomPerturbation<dim>::parse_parameters (ParameterHandler &prm) | ||
{ | ||
prm.enter_subsection ("Initial composition model"); | ||
{ | ||
prm.enter_subsection("Random perturbation"); | ||
{ | ||
magnitude = prm.get_double ("Magnitude"); | ||
use_random_seed = prm.get_bool("Use random seed"); | ||
} | ||
prm.leave_subsection (); | ||
} | ||
prm.leave_subsection (); | ||
} | ||
} | ||
} | ||
|
||
// explicit instantiations | ||
namespace aspect | ||
{ | ||
namespace InitialComposition | ||
{ | ||
ASPECT_REGISTER_INITIAL_COMPOSITION_MODEL(RandomPerturbation, | ||
"random perturbation", | ||
"An initial composition anomaly that perturbs the composition " | ||
"following a random noise with uniform distribution and user " | ||
"specified magnitude.") | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
a random noise -> random noise
(noise is like milk -- it has no singular or plural)