/*******************************************************************************
* This file is part of SWIFT.
* Copyright (c) 2021 John Helly (j.c.helly@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 .
*
******************************************************************************/
#ifndef SWIFT_LIGHTCONE_MAP_H
#define SWIFT_LIGHTCONE_MAP_H
/* Define this to write the expected sum of the map to the
output file. This is to check that the SPH smoothing and
communication code is conserving the quantity added to
the map. */
#define LIGHTCONE_MAP_CHECK_TOTAL
/* Standard headers */
#include
#include
/* Config parameters. */
#include
/* HDF5 */
#ifdef HAVE_HDF5
#include
#endif
/* Local headers */
#include "io_compression.h"
#include "lightcone/lightcone_map_types.h"
#include "lightcone/pixel_index.h"
#include "units.h"
/**
* @brief Struct to store a single lightcone healpix map
*/
struct lightcone_map {
/*! Healpix nside parameter */
int nside;
/*! Total pixels in the map */
pixel_index_t total_nr_pix;
/*! Number of pixels stored on this node */
pixel_index_t local_nr_pix;
/*! Offset of the first pixel stored on this rank */
pixel_index_t local_pix_offset;
/*! Number of pixels per rank (last node has any extra) */
pixel_index_t pix_per_rank;
/*! Local healpix map data */
double *data;
/*! Inner radius */
double r_min;
/*! Outer radius */
double r_max;
/*! Type of this map */
struct lightcone_map_type type;
/*! Factor for retrieving values from the update buffer */
double buffer_scale_factor_inv;
#ifdef LIGHTCONE_MAP_CHECK_TOTAL
/*! Total quantity accumulated to this map, for consistency check */
double total;
#endif
};
void lightcone_map_init(struct lightcone_map *map, const int nside,
const pixel_index_t total_nr_pix,
const pixel_index_t pix_per_rank,
const pixel_index_t local_nr_pix,
const pixel_index_t local_pix_offset,
const double r_min, const double r_max,
struct lightcone_map_type type);
void lightcone_map_clean(struct lightcone_map *map);
void lightcone_map_struct_dump(const struct lightcone_map *map, FILE *stream);
void lightcone_map_struct_restore(struct lightcone_map *map, FILE *stream);
void lightcone_map_allocate_pixels(struct lightcone_map *map,
const int zero_pixels);
void lightcone_map_free_pixels(struct lightcone_map *map);
#ifdef HAVE_HDF5
void lightcone_map_write(struct lightcone_map *map, const hid_t loc_id,
const char *name,
const struct unit_system *internal_units,
const struct unit_system *snapshot_units,
const int collective, const int maps_gzip_level,
const int chunk_size,
enum lossy_compression_schemes compression);
#endif
#endif /* #ifndef SWIFT_LIGHTCONE_MAP_H */