Select Git revision
hydro_properties.h
Matthieu Schaller authored
hydro_properties.h 3.55 KiB
/*******************************************************************************
* This file is part of SWIFT.
* Copyright (c) 2016 Matthieu Schaller (matthieu.schaller@durham.ac.uk)
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
******************************************************************************/
#ifndef SWIFT_HYDRO_PROPERTIES
#define SWIFT_HYDRO_PROPERTIES
/**
* @file hydro_properties.h
* @brief Contains all the constants and parameters of the hydro scheme
*/
/* Config parameters. */
#include "../config.h"
#if defined(HAVE_HDF5)
#include <hdf5.h>
#endif
/* Local includes. */
#include "parser.h"
#include "physical_constants.h"
#include "restart.h"
#include "units.h"
/**
* @brief Contains all the constants and parameters of the hydro scheme
*/
struct hydro_props {
/*! Resolution parameter */
float eta_neighbours;
/*! Target weightd number of neighbours (for info only)*/
float target_neighbours;
/*! Smoothing length tolerance */
float h_tolerance;
/*! Tolerance on neighbour number (for info only)*/
float delta_neighbours;
/*! Maximal smoothing length */
float h_max;
/*! Maximal number of iterations to converge h */
int max_smoothing_iterations;
/*! Time integration properties */
float CFL_condition;
/*! Maximal change of h over one time-step */
float log_max_h_change;
/*! Minimal temperature allowed */
float minimal_temperature;
/*! Minimal physical internal energy per unit mass */
float minimal_internal_energy;
/*! Initial temperature */
float initial_temperature;
/*! Initial physical internal energy per unit mass */
float initial_internal_energy;
/*! Primordial hydrogen mass fraction for initial energy conversion */
float hydrogen_mass_fraction;
/*! Temperature of the neutral to ionized transition of Hydrogen */
float hydrogen_ionization_temperature;
/*! Artificial viscosity parameters */
struct {
/*! For the fixed, simple case. Also used to set the initial AV
coefficient for variable schemes. */
float alpha;
/*! Artificial viscosity (max) for the variable case (e.g. M&M) */
float alpha_max;
/*! Artificial viscosity (min) for the variable case (e.g. M&M) */
float alpha_min;
/*! The decay length of the artificial viscosity (used in M&M, etc.) */
float length;
} viscosity;
};
void hydro_props_print(const struct hydro_props *p);
void hydro_props_init(struct hydro_props *p,
const struct phys_const *phys_const,
const struct unit_system *us,
struct swift_params *params);
#if defined(HAVE_HDF5)
void hydro_props_print_snapshot(hid_t h_grpsph, const struct hydro_props *p);
#endif
/* Dump/restore. */
void hydro_props_struct_dump(const struct hydro_props *p, FILE *stream);
void hydro_props_struct_restore(const struct hydro_props *p, FILE *stream);
/* Setup for tests */
void hydro_props_init_no_hydro(struct hydro_props *p);
#endif /* SWIFT_HYDRO_PROPERTIES */