/*******************************************************************************
* This file is part of SWIFT.
* Copyright (c) 2020 Mladen Ivkovic (mladen.ivkovic@hotmail.com)
*
* 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_RT_H
#define SWIFT_RT_H
/**
* @file src/rt.h
* @brief Branches between the different radiative transfer schemes. Also
* contains some globally valid functions related to time bin data.
*/
/* Config parameters. */
#include
/* Import the right RT definition */
#if defined(RT_NONE)
#include "./rt/none/rt.h"
#include "./rt/none/rt_iact.h"
#elif defined(RT_DEBUG)
#include "./rt/debug/rt.h"
#include "./rt/debug/rt_iact.h"
#elif defined(RT_GEAR)
#include "./rt/GEAR/rt.h"
#include "./rt/GEAR/rt_iact.h"
#elif defined(RT_SPHM1RT)
#include "./rt/SPHM1RT/rt.h"
#include "./rt/SPHM1RT/rt_iact.h"
#else
#error "Invalid choice of radiation scheme"
#endif
/**
* @brief Initialise RT time step data. This struct should be hidden from users,
* so we do it for all schemes here.
*
* @param p The #part.
*/
__attribute__((always_inline)) INLINE static void rt_first_init_timestep_data(
struct part *restrict p) {
p->rt_time_data.min_ngb_time_bin = num_time_bins + 1;
p->rt_time_data.time_bin = 0;
}
/**
* @brief Prepare the rt *time step* quantities for a *hydro force* calculation.
*
* @param p The #part.
*/
__attribute__((always_inline)) INLINE static void rt_timestep_prepare_force(
struct part *restrict p) {
p->rt_time_data.min_ngb_time_bin = num_time_bins + 1;
}
/**
* @brief Gathers neighbor data for RT during *hydro* force loops.
* This is something all RT schemes should have in common, and something
* users most likely never should be touching, so it's 'hidden' in the
* top-level header file all schemes have in common.
*
* @param r2 Comoving square distance between the two particles.
* @param dx Comoving vector separating both particles (pi - pj).
* @param hi Comoving smoothing-length of particle i.
* @param hj Comoving smoothing-length of particle j.
* @param pi First particle.
* @param pj Second particle.
* @param a Current scale factor.
* @param H Current Hubble parameter.
*/
__attribute__((always_inline)) INLINE static void runner_iact_rt_timebin(
const float r2, const float dx[3], const float hi, const float hj,
struct part *restrict pi, struct part *restrict pj, const float a,
const float H) {
#ifndef RT_NONE
/* Update the minimal time-bin */
if (pj->rt_time_data.time_bin > 0)
pi->rt_time_data.min_ngb_time_bin =
min(pi->rt_time_data.min_ngb_time_bin, pj->rt_time_data.time_bin);
if (pi->rt_time_data.time_bin > 0)
pj->rt_time_data.min_ngb_time_bin =
min(pj->rt_time_data.min_ngb_time_bin, pi->rt_time_data.time_bin);
#endif
}
/**
* @brief Gathers neighbor data for RT during *hydro* force loops
* (non-symmetric). This is something all RT schemes should have in common, and
* something users most likely never should be touching, so it's 'hidden' in the
* top-level header file all schemes have in common.
*
*
* @param r2 Comoving square distance between the two particles.
* @param dx Comoving vector separating both particles (pi - pj).
* @param hi Comoving smoothing-length of particle i.
* @param hj Comoving smoothing-length of particle j.
* @param pi First particle.
* @param pj Second particle (not updated).
* @param a Current scale factor.
* @param H Current Hubble parameter.
*/
__attribute__((always_inline)) INLINE static void runner_iact_nonsym_rt_timebin(
const float r2, const float dx[3], const float hi, const float hj,
struct part *restrict pi, const struct part *restrict pj, const float a,
const float H) {
#ifndef RT_NONE
/* Update the minimal time-bin */
if (pj->rt_time_data.time_bin > 0)
pi->rt_time_data.min_ngb_time_bin =
min(pi->rt_time_data.min_ngb_time_bin, pj->rt_time_data.time_bin);
#endif
}
#endif /* SWIFT_RT_H */