aboutsummaryrefslogtreecommitdiff
path: root/Source/FieldSolver/SpectralSolver/SpectralAlgorithms/SpectralBaseAlgorithmRZ.cpp
blob: 679fc5fba2867e57e2b887096ef3c39c3acef8e6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/* Copyright 2019 Edoardo Zoni
 *
 * This file is part of WarpX.
 *
 * License: BSD-3-Clause-LBNL
 */
#include "SpectralBaseAlgorithmRZ.H"

#include <cmath>

using namespace amrex;

/**
 * \brief Compute spectral divergence of E
 */
void
SpectralBaseAlgorithmRZ::ComputeSpectralDivE (
    SpectralFieldDataRZ& field_data,
    const std::array<std::unique_ptr<amrex::MultiFab>,3>& Efield,
    amrex::MultiFab& divE )
{
    using amrex::operator""_rt;
    using Idx = SpectralFieldIndex;

    // Forward Fourier transform of E
    field_data.ForwardTransform( *Efield[0], Idx::Ex,
                                 *Efield[1], Idx::Ey );
    field_data.ForwardTransform( *Efield[2], Idx::Ez, 0 );

    // Loop over boxes
    for (MFIter mfi(field_data.fields); mfi.isValid(); ++mfi){

        Box const & bx = field_data.fields[mfi].box();

        // Extract arrays for the fields to be updated
        Array4<Complex> fields = field_data.fields[mfi].array();

        // Extract pointers for the k vectors
        auto const & kr = field_data.getKrArray(mfi);
        Real const * kr_arr = kr.dataPtr();
        Real const * modified_kz_arr = modified_kz_vec[mfi].dataPtr();

        int const nr = bx.length(0);
        int const modes = field_data.n_rz_azimuthal_modes;
        constexpr int n_fields = SpectralFieldIndex::n_fields;

        // Loop over indices within one box
        ParallelFor(bx, modes,
        [=] AMREX_GPU_DEVICE(int i, int j, int k, int mode) noexcept
        {
            int const ic1 = Idx::Ex + mode*n_fields;
            int const ic2 = Idx::Ey + mode*n_fields;
            int const ic3 = Idx::Ez + mode*n_fields;

            // Shortcuts for the components of E
            Complex const Ep = fields(i,j,0,ic1);
            Complex const Em = fields(i,j,0,ic2);
            Complex const Ez = fields(i,j,0,ic3);

            // k vector values
            int const ir = i + nr*mode;
            Real const kr = kr_arr[ir];
            Real const kz = modified_kz_arr[j];
            Complex const I = Complex{0._rt,1._rt};

            // div(E) in Fourier space
            int const ic = Idx::divE + mode*n_fields;
            fields(i,j,0,ic) = kr*(Ep - Em) + I*kz*Ez;
        });
    }

    // Backward Fourier transform
    field_data.BackwardTransform( divE, Idx::divE, 0 );
};
on> Unnamed repository; edit this file 'description' to name the repository.
aboutsummaryrefslogtreecommitdiff
path: root/examples/blog-multiple-authors/.stackblitzrc (unfollow)
AgeCommit message (Collapse)AuthorFilesLines
2021-11-19Resolve vite client modules to vendored vite (#1903)Gravatar Matthew Phillips 2-2/+7
* Resolve vite client modules to vendored vite * Adds a changeset
2021-11-19[ci] yarn formatGravatar matthewp 1-3/+3
2021-11-19Add Debug tests (#1882)Gravatar Matthew Phillips 4-0/+62
* Make Debug use the Code component * Use a random port so parallel testing works * some debugging * Skip these tests for now * Dont run these tests on osx
2021-11-19[ci] collect statsGravatar FredKSchott 1-0/+1
2021-11-19Version Packages (next) (#1881)astro@0.21.0-next.8@astrojs/renderer-vue@0.2.0-next.2Gravatar github-actions[bot] 25-23/+42
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2021-11-18Improve HMR (#1896)Gravatar Drew Powers 2-10/+18
2021-11-18update depsGravatar Fred K. Schott 5-352/+65
2021-11-18fix #1778Gravatar Fred K. Schott 2-1/+8
2021-11-18Update compiler (#1869)Gravatar Nate Moore 3-11/+6
* chore: update compiler * redeploy * fix(www): ensure www can build * chore: update compiler Co-authored-by: Fred K. Schott <fkschott@gmail.com>
2021-11-18remove unused remark dependency (#1894)Gravatar Fred K. Schott 2-245/+13
2021-11-18Improve error messages (#1875)Gravatar Drew Powers 39-61/+448
* Fix error handling in correct scope Also improve Vite IDs for better module graph lookups * Improve code frame * Add changeset * maybeLoc can be undefined * Add tests Co-authored-by: Matthew Phillips <matthew@skypack.dev>
2021-11-18pin astro compiler to older versionGravatar Fred K. Schott 2-5/+5
2021-11-18Update yarn.lock to reflect the state of the package.json files (#1892)Gravatar Jonathan Neal 5-1300/+1000
* update dependencies * update file to fix build:all
2021-11-19[ci] yarn formatGravatar FredKSchott 1-5/+3