1*530ad8c4SKenneth E. Jansen // Copyright (c) 2017-2022, Lawrence Livermore National Security, LLC and other CEED contributors. 2*530ad8c4SKenneth E. Jansen // All Rights Reserved. See the top-level LICENSE and NOTICE files for details. 3*530ad8c4SKenneth E. Jansen // 4*530ad8c4SKenneth E. Jansen // SPDX-License-Identifier: BSD-2-Clause 5*530ad8c4SKenneth E. Jansen // 6*530ad8c4SKenneth E. Jansen // This file is part of CEED: http://github.com/ceed 7*530ad8c4SKenneth E. Jansen 8*530ad8c4SKenneth E. Jansen /// @file 9*530ad8c4SKenneth E. Jansen /// Thermodynamic wave propogation for testing freestream/non-reflecting boundary conditions. Proposed in Mengaldo et. al. 2014 10*530ad8c4SKenneth E. Jansen 11*530ad8c4SKenneth E. Jansen #include <ceed.h> 12*530ad8c4SKenneth E. Jansen #include <math.h> 13*530ad8c4SKenneth E. Jansen 14*530ad8c4SKenneth E. Jansen #include "newtonian_state.h" 15*530ad8c4SKenneth E. Jansen #include "utils.h" 16*530ad8c4SKenneth E. Jansen 17*530ad8c4SKenneth E. Jansen typedef struct GaussianWaveContext_ *GaussianWaveContext; 18*530ad8c4SKenneth E. Jansen struct GaussianWaveContext_ { 19*530ad8c4SKenneth E. Jansen CeedScalar epicenter[3]; // Location of the perturbation 20*530ad8c4SKenneth E. Jansen CeedScalar width; // Controls width of the perturbation 21*530ad8c4SKenneth E. Jansen CeedScalar amplitude; // Amplitude of the perturbation 22*530ad8c4SKenneth E. Jansen State S_infty; // Flow state at infinity 23*530ad8c4SKenneth E. Jansen struct NewtonianIdealGasContext_ newt_ctx; 24*530ad8c4SKenneth E. Jansen }; 25*530ad8c4SKenneth E. Jansen 26*530ad8c4SKenneth E. Jansen CEED_QFUNCTION_HELPER int IC_GaussianWave(void *ctx, CeedInt Q, const CeedScalar *const *in, CeedScalar *const *out, StateToQi_t StateToQi) { 27*530ad8c4SKenneth E. Jansen const CeedScalar(*X)[CEED_Q_VLA] = (const CeedScalar(*)[CEED_Q_VLA])in[0]; 28*530ad8c4SKenneth E. Jansen 29*530ad8c4SKenneth E. Jansen CeedScalar(*q0)[CEED_Q_VLA] = (CeedScalar(*)[CEED_Q_VLA])out[0]; 30*530ad8c4SKenneth E. Jansen 31*530ad8c4SKenneth E. Jansen const GaussianWaveContext context = (GaussianWaveContext)ctx; 32*530ad8c4SKenneth E. Jansen const NewtonianIdealGasContext newt_ctx = &context->newt_ctx; 33*530ad8c4SKenneth E. Jansen 34*530ad8c4SKenneth E. Jansen const CeedScalar amplitude = context->amplitude; 35*530ad8c4SKenneth E. Jansen const CeedScalar width = context->width; 36*530ad8c4SKenneth E. Jansen const State S_infty = context->S_infty; 37*530ad8c4SKenneth E. Jansen const CeedScalar xc = context->epicenter[0]; 38*530ad8c4SKenneth E. Jansen const CeedScalar yc = context->epicenter[1]; 39*530ad8c4SKenneth E. Jansen 40*530ad8c4SKenneth E. Jansen const CeedScalar gamma = HeatCapacityRatio(newt_ctx); 41*530ad8c4SKenneth E. Jansen 42*530ad8c4SKenneth E. Jansen CeedPragmaSIMD for (CeedInt i = 0; i < Q; i++) { 43*530ad8c4SKenneth E. Jansen CeedScalar U[5] = {0.}, qi[5] = {0.}; 44*530ad8c4SKenneth E. Jansen const CeedScalar x[3] = {X[0][i], X[1][i], X[2][i]}; 45*530ad8c4SKenneth E. Jansen const CeedScalar x0 = x[0] - xc; 46*530ad8c4SKenneth E. Jansen const CeedScalar y0 = x[1] - yc; 47*530ad8c4SKenneth E. Jansen const CeedScalar e_kinetic = 0.5 * S_infty.U.density * Dot3(S_infty.Y.velocity, S_infty.Y.velocity); 48*530ad8c4SKenneth E. Jansen 49*530ad8c4SKenneth E. Jansen const CeedScalar perturbation = 1 + amplitude * exp(-(Square(x0) + Square(y0)) / (2 * Square(width))); 50*530ad8c4SKenneth E. Jansen 51*530ad8c4SKenneth E. Jansen U[0] = S_infty.U.density * perturbation; 52*530ad8c4SKenneth E. Jansen U[1] = S_infty.Y.velocity[0] * U[0]; 53*530ad8c4SKenneth E. Jansen U[2] = S_infty.Y.velocity[1] * U[0]; 54*530ad8c4SKenneth E. Jansen U[3] = S_infty.Y.velocity[2] * U[0]; 55*530ad8c4SKenneth E. Jansen U[4] = S_infty.Y.pressure / (gamma - 1) * perturbation + e_kinetic; 56*530ad8c4SKenneth E. Jansen 57*530ad8c4SKenneth E. Jansen State initCond = StateFromU(newt_ctx, U, x); 58*530ad8c4SKenneth E. Jansen StateToQi(newt_ctx, initCond, qi); 59*530ad8c4SKenneth E. Jansen 60*530ad8c4SKenneth E. Jansen for (CeedInt j = 0; j < 5; j++) q0[j][i] = qi[j]; 61*530ad8c4SKenneth E. Jansen } 62*530ad8c4SKenneth E. Jansen 63*530ad8c4SKenneth E. Jansen return 0; 64*530ad8c4SKenneth E. Jansen } 65*530ad8c4SKenneth E. Jansen 66*530ad8c4SKenneth E. Jansen CEED_QFUNCTION(IC_GaussianWave_Conserv)(void *ctx, CeedInt Q, const CeedScalar *const *in, CeedScalar *const *out) { 67*530ad8c4SKenneth E. Jansen return IC_GaussianWave(ctx, Q, in, out, StateToU); 68*530ad8c4SKenneth E. Jansen } 69*530ad8c4SKenneth E. Jansen 70*530ad8c4SKenneth E. Jansen CEED_QFUNCTION(IC_GaussianWave_Prim)(void *ctx, CeedInt Q, const CeedScalar *const *in, CeedScalar *const *out) { 71*530ad8c4SKenneth E. Jansen return IC_GaussianWave(ctx, Q, in, out, StateToY); 72*530ad8c4SKenneth E. Jansen } 73