/*******************************************************************************
* This file is part of SWIFT.
* Copyright (c) 2012 Pedro Gonnet (pedro.gonnet@durham.ac.uk),
* Matthieu Schaller (schaller@strw.leidenuniv.nl).
*
* 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 .
*
******************************************************************************/
#ifndef SWIFT_COMMON_IO_H
#define SWIFT_COMMON_IO_H
/* Config parameters. */
#include
/* Local includes. */
#include "part_type.h"
#define FIELD_BUFFER_SIZE 64
#define DESCRIPTION_BUFFER_SIZE 600
#define PARTICLE_GROUP_BUFFER_SIZE 50
#define FILENAME_BUFFER_SIZE 150
#define IO_BUFFER_ALIGNMENT 1024
#define HDF5_LOWEST_FILE_FORMAT_VERSION H5F_LIBVER_V18
#define HDF5_HIGHEST_FILE_FORMAT_VERSION H5F_LIBVER_LATEST
/* Avoid cyclic inclusion problems */
struct cell;
struct space;
struct part;
struct gpart;
struct velociraptor_gpart_data;
struct spart;
struct bpart;
struct xpart;
struct sink;
struct io_props;
struct engine;
struct threadpool;
struct output_list;
struct output_options;
struct unit_system;
/**
* @brief The different types of data used in the GADGET IC files.
*
* (This is admittedly a poor substitute to C++ templates...)
*/
enum IO_DATA_TYPE {
INT,
LONG,
LONGLONG,
UINT8,
UINT,
UINT64,
ULONG,
ULONGLONG,
FLOAT,
DOUBLE,
CHAR,
BOOL,
SIZE_T,
};
#if defined(HAVE_HDF5)
/* Library header */
#include
hid_t io_hdf5_type(enum IO_DATA_TYPE type);
hsize_t io_get_number_element_in_attribute(hid_t attr);
hsize_t io_get_number_element_in_dataset(hid_t dataset);
void io_read_attribute(hid_t grp, const char* name, enum IO_DATA_TYPE type,
void* data);
void io_read_attribute_graceful(hid_t grp, const char* name,
enum IO_DATA_TYPE type, void* data);
void io_assert_valid_header_cosmology(hid_t h_grp, double a);
void io_read_array_attribute(hid_t grp, const char* name,
enum IO_DATA_TYPE type, void* data,
hsize_t number_element);
void io_read_array_dataset(hid_t grp, const char* name, enum IO_DATA_TYPE type,
void* data, hsize_t number_element);
void io_write_attribute(hid_t grp, const char* name, enum IO_DATA_TYPE type,
const void* data, int num);
void io_write_attribute_d(hid_t grp, const char* name, double data);
void io_write_attribute_f(hid_t grp, const char* name, float data);
void io_write_attribute_i(hid_t grp, const char* name, int data);
void io_write_attribute_b(hid_t grp, const char* name, int data);
void io_write_attribute_l(hid_t grp, const char* name, long data);
void io_write_attribute_ll(hid_t grp, const char* name, long long data);
void io_write_attribute_s(hid_t grp, const char* name, const char* str);
void io_write_meta_data(hid_t h_file, const struct engine* e,
const struct unit_system* internal_units,
const struct unit_system* snapshot_units,
const int fof);
void io_write_code_description(hid_t h_file);
void io_write_engine_policy(hid_t h_file, const struct engine* e);
void io_write_part_type_names(hid_t h_grp);
void io_write_cell_offsets(hid_t h_grp, const int cdim[3], const double dim[3],
const struct cell* cells_top, const int nr_cells,
const double width[3], const int nodeID,
const int distributed,
const int subsample[swift_type_count],
const float subsample_fraction[swift_type_count],
const int snap_num,
const long long global_counts[swift_type_count],
const long long global_offsets[swift_type_count],
const int to_write[swift_type_count],
const int num_fields[swift_type_count],
const struct unit_system* internal_units,
const struct unit_system* snapshot_units);
void io_read_unit_system(hid_t h_file, struct unit_system* ic_units,
const struct unit_system* internal_units,
int mpi_rank);
void io_write_unit_system(hid_t h_grp, const struct unit_system* us,
const char* groupName);
void io_copy_temp_buffer(void* temp, const struct engine* e,
const struct io_props props, size_t N,
const struct unit_system* internal_units,
const struct unit_system* snapshot_units);
#endif /* HAVE_HDF5 */
size_t io_sizeof_type(enum IO_DATA_TYPE type);
int io_is_double_precision(enum IO_DATA_TYPE type);
long long io_count_gas_to_write(const struct space* s, const int subsample,
const float subsample_ratio,
const int snap_num);
long long io_count_dark_matter_to_write(const struct space* s,
const int subsample,
const float subsample_ratio,
const int snap_num);
long long io_count_background_dark_matter_to_write(const struct space* s,
const int subsample,
const float subsample_ratio,
const int snap_num);
long long io_count_stars_to_write(const struct space* s, const int subsample,
const float subsample_ratio,
const int snap_num);
long long io_count_sinks_to_write(const struct space* s, const int subsample,
const float subsample_ratio,
const int snap_num);
long long io_count_black_holes_to_write(const struct space* s,
const int subsample,
const float subsample_ratio,
const int snap_num);
long long io_count_neutrinos_to_write(const struct space* s,
const int subsample,
const float subsample_ratio,
const int snap_num);
void io_collect_parts_to_write(const struct part* restrict parts,
const struct xpart* restrict xparts,
struct part* restrict parts_written,
struct xpart* restrict xparts_written,
const int subsample, const float subsample_ratio,
const int snap_num, const size_t Nparts,
const size_t Nparts_written);
void io_collect_sinks_to_write(const struct sink* restrict sinks,
struct sink* restrict sinks_written,
const int subsample, const float subsample_ratio,
const int snap_num, const size_t Nsinks,
const size_t Nsinks_written);
void io_collect_sparts_to_write(const struct spart* restrict sparts,
struct spart* restrict sparts_written,
const int subsample,
const float subsample_ratio, const int snap_num,
const size_t Nsparts,
const size_t Nsparts_written);
void io_collect_bparts_to_write(const struct bpart* restrict bparts,
struct bpart* restrict bparts_written,
const int subsample,
const float subsample_ratio, const int snap_num,
const size_t Nbparts,
const size_t Nbparts_written);
void io_collect_gparts_to_write(const struct gpart* restrict gparts,
const struct velociraptor_gpart_data* vr_data,
struct gpart* restrict gparts_written,
struct velociraptor_gpart_data* vr_data_written,
const int subsample,
const float subsample_ratio, const int snap_num,
const size_t Ngparts,
const size_t Ngparts_written, int with_stf);
void io_collect_gparts_background_to_write(
const struct gpart* restrict gparts,
const struct velociraptor_gpart_data* vr_data,
struct gpart* restrict gparts_written,
struct velociraptor_gpart_data* vr_data_written, const int subsample,
const float subsample_ratio, const int snap_num, const size_t Ngparts,
const size_t Ngparts_written, int with_stf);
void io_collect_gparts_neutrino_to_write(
const struct gpart* restrict gparts,
const struct velociraptor_gpart_data* vr_data,
struct gpart* restrict gparts_written,
struct velociraptor_gpart_data* vr_data_written, const int subsample,
const float subsample_ratio, const int snap_num, const size_t Ngparts,
const size_t Ngparts_written, int with_stf);
void io_prepare_dm_gparts(struct threadpool* tp, struct gpart* const gparts,
size_t Ndm);
void io_prepare_dm_background_gparts(struct threadpool* tp,
struct gpart* const gparts, size_t Ndm);
size_t io_count_dm_background_gparts(const struct gpart* const gparts,
size_t Ndm);
void io_prepare_dm_neutrino_gparts(struct threadpool* tp,
struct gpart* const gparts, size_t Ndm);
size_t io_count_dm_neutrino_gparts(const struct gpart* const gparts,
size_t Ndm);
void io_duplicate_hydro_gparts(struct threadpool* tp, struct part* const parts,
struct gpart* const gparts, size_t Ngas,
size_t Ndm);
void io_duplicate_stars_gparts(struct threadpool* tp,
struct spart* const sparts,
struct gpart* const gparts, size_t Nstars,
size_t Ndm);
void io_duplicate_sinks_gparts(struct threadpool* tp, struct sink* const sinks,
struct gpart* const gparts, size_t Nsinks,
size_t Ndm);
void io_duplicate_black_holes_gparts(struct threadpool* tp,
struct bpart* const bparts,
struct gpart* const gparts, size_t Nstars,
size_t Ndm);
void io_prepare_output_fields(struct output_options* output_options,
const int with_cosmology, const int with_fof,
const int with_stf, int verbose);
void io_write_output_field_parameter(const char* filename, int with_cosmology,
int with_fof, int with_stf);
void io_make_snapshot_subdir(const char* dirname);
void io_get_snapshot_filename(char filename[FILENAME_BUFFER_SIZE],
char xmf_filename[FILENAME_BUFFER_SIZE],
const struct output_list* output_list,
const int snapshots_invoke_stf,
const int stf_count, const int snap_count,
const char* default_subdir, const char* subdir,
const char* default_basename,
const char* basename);
void io_set_ids_to_one(struct gpart* gparts, const size_t Ngparts);
void io_select_hydro_fields(const struct part* const parts,
const struct xpart* const xparts,
const int with_cosmology, const int with_cooling,
const int with_temperature, const int with_fof,
const int with_stf, const int with_rt,
const struct engine* const e, int* const num_fields,
struct io_props* const list);
void io_select_dm_fields(const struct gpart* const gparts,
const struct velociraptor_gpart_data* gpart_group_data,
const int with_fof, const int with_stf,
const struct engine* const e, int* const num_fields,
struct io_props* const list);
void io_select_neutrino_fields(
const struct gpart* const gparts,
const struct velociraptor_gpart_data* gpart_group_data, const int with_fof,
const int with_stf, const struct engine* const e, int* const num_fields,
struct io_props* const list);
void io_select_sink_fields(const struct sink* const sinks,
const int with_cosmology, const int with_fof,
const int with_stf, const struct engine* const e,
int* const num_fields, struct io_props* const list);
void io_select_star_fields(const struct spart* const sparts,
const int with_cosmology, const int with_fof,
const int with_stf, const int with_rt,
const struct engine* const e, int* const num_fields,
struct io_props* const list);
void io_select_bh_fields(const struct bpart* const bparts,
const int with_cosmology, const int with_fof,
const int with_stf, const struct engine* const e,
int* const num_fields, struct io_props* const list);
#endif /* SWIFT_COMMON_IO_H */