view src/Grids/zero_dim_grid.jl @ 1344:760a4a1ec4b7 refactor/grids

Add 2D tests for dissipation operators and fix bug
author Jonatan Werpers <jonatan@werpers.com>
date Mon, 15 May 2023 22:37:55 +0200
parents 8860bfcaedaa
children 4ad1282f8bab
line wrap: on
line source

"""
    ZeroDimGrid{T} <: Grid{T,0}

A zero dimensional grid consisting of a single point.
"""
struct ZeroDimGrid{T} <: Grid{T,0}
    point::T
end

# Indexing interface
Base.getindex(g::ZeroDimGrid) = g.point
Base.eachindex(g::ZeroDimGrid) = CartesianIndices(())

# Iteration interface
Base.iterate(g::ZeroDimGrid) = (g.point, nothing)
Base.iterate(g::ZeroDimGrid, ::Any) = nothing

Base.IteratorSize(::Type{<:ZeroDimGrid}) = Base.HasShape{0}()
Base.length(g::ZeroDimGrid) = 1
Base.size(g::ZeroDimGrid) = ()


refine(g::ZeroDimGrid, ::Int) = g
coarsen(g::ZeroDimGrid, ::Int) = g

boundary_identifiers(g::ZeroDimGrid) = ()
boundary_grid(g::ZeroDimGrid, ::Any) = throw(ArgumentError("ZeroDimGrid has no boundaries"))