/******************************************************************************* * 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 */