Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Jm/visualize basis functions #98

Open
wants to merge 27 commits into
base: master
Choose a base branch
from
Open
Changes from 22 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
d04c475
ntriangles for higher order triangles
JanM12 May 5, 2023
fe44a99
interpolate_gradient() um kWarg erweitert um bereits vorhandene Feld…
JanM12 May 17, 2023
985e44e
bugs behoben.
JanM12 May 17, 2023
517703a
Update src/utils.jl
JanM12 May 17, 2023
ab8c9d3
updated docstring for
JanM12 May 17, 2023
f7a8d00
Merge branch 'master' of github.com:JanM12/FerriteViz.jl
JanM12 May 17, 2023
3b16fe8
added comma to docstring
JanM12 May 17, 2023
131ee0c
inkonsistency regarding WF observables and resolved
JanM12 May 22, 2023
37f177d
resolved merge conflicts after git pull. accepted all changes from ma…
JanM12 Jun 9, 2023
b22b580
merge master
JanM12 Jun 16, 2023
0d6ca25
introduced ploting fcn for all 2D and 1D basis functions.
JanM12 Jun 16, 2023
697f95a
rework 'get_triangulation_triangle()' to make it work for rectangles …
JanM12 Jun 16, 2023
6d940fd
removed doubling of code for show_basis_function(). Therefore introdu…
JanM12 Jun 16, 2023
043ec73
removed commented out section
JanM12 Jun 16, 2023
bb15eff
initialize_figure() dispatches zu einem generischen dispatch vereinigt
JanM12 Jun 23, 2023
7bd8e32
implemented workaround for CrouzeixRaviart element
JanM12 Jun 23, 2023
b5272e9
removed println() and fixed small bugs (forgot to pass argument to fu…
JanM12 Jun 23, 2023
50cc0c4
reworked show_basis_function(ip::Lagrange{RefLine})
JanM12 Jun 23, 2023
05321e0
remooved trailing whitespaces
JanM12 Jun 23, 2023
b9ad793
plotting finctions for plotting base functions added to makieplotting.jl
JanM12 Jun 23, 2023
03d9dba
removed plotbasisfunctions.jl
JanM12 Jun 23, 2023
2ffa6d8
adapted to Ferrite v.0.13.4 (RefQuadrilateral=>RefCube,...)
JanM12 Jun 23, 2023
d3bee2e
implemented visibility of corresponding element underneath the basis …
JanM12 Jun 30, 2023
c251a26
introduced a second base function plotting routine in order to sepera…
JanM12 Jun 30, 2023
0b53025
deleted unneeded method
JanM12 Jun 30, 2023
d4a4ee1
introduced kwargs for in order to allow adjustment of call to
JanM12 Jun 30, 2023
490bd29
um show_basis_functions(ip::CrouzeixRaviart) erweitert.
JanM12 Jul 24, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
150 changes: 150 additions & 0 deletions src/makieplotting.jl
Original file line number Diff line number Diff line change
Expand Up @@ -566,6 +566,156 @@ function ferriteviewer(plotter::MakiePlotter, data::Vector{Vector{T}}) where T
display(fig)
end

#function get_domain(ip::Ferrite.Interpolation{ref_shape,order}, meshsize::Int) where {ref_shape<:Union{RefQuadrilateral,RefTriangle},order}
function get_domain(ip::Ferrite.Interpolation{2,ref_shape,order}, meshsize::Int) where {ref_shape<:Union{Ferrite.RefCube,Ferrite.RefTetrahedron},order}
rcs = Ferrite.reference_coordinates(ip)
lwr = min(vcat(collect.(rcs)...)...)
upr = max(vcat(collect.(rcs)...)...)
y = range(upr,lwr,length=meshsize)
x = range(lwr,upr,length=meshsize)
ref_z = get_ref_z(ip,meshsize)
return x,y,ref_z
end
JanM12 marked this conversation as resolved.
Show resolved Hide resolved

#get_ref_z(ip::Ferrite.Interpolation{ref_shape,order},meshsize::Int) where {ref_shape,order} = zeros(meshsize,meshsize)
get_ref_z(ip::Ferrite.Interpolation{2,ref_shape,order},meshsize::Int) where {ref_shape,order} = zeros(meshsize,meshsize)
#function get_ref_z(ip::Ferrite.Interpolation{ref_shape,order},meshsize::Int) where {ref_shape<:RefTriangle,order}
function get_ref_z(ip::Ferrite.Interpolation{2,ref_shape,order},meshsize::Int) where {ref_shape<:Ferrite.RefTetrahedron,order}
z = zeros(meshsize,meshsize)
for ix in 1:size(z,2), iy in 1:size(z,1)
(ix>iy) ? z[iy,ix]=NaN : nothing
end
#if typeof(ip)==CrouzeixRaviart{RefTriangle,1,Nothing}
# z = collect(z')
#end
return z
end

#function initialize_figure(ip::Ferrite.Interpolation{ref_shape,N}) where {ref_shape<:Union{RefQuadrilateral,RefTriangle},N}
function initialize_figure(ip::Ferrite.Interpolation{2,ref_shape,N}) where {ref_shape<:Union{Ferrite.RefCube,Ferrite.RefTetrahedron},N}
rcs = Ferrite.reference_coordinates(ip)
min_val = Int(min(vcat(rcs...)...))
rcs = [[c[1]-min_val,c[2]-min_val] for c in rcs]
scale = round(inv(min(filter(!iszero,vcat(rcs...))...));digits=15)
max_id = Int(round(max(vcat(rcs...)...)*scale))
refpos = [Int.([max_id-coord[2]+1, coord[1]+1]) for coord in rcs.*scale]

fig = Figure()
ax = [Axis3(fig[pos...];xlabel=L"ξ_x", ylabel=L"ξ_y", zlabel=L"N(ξ)" ,title="id: $(i), node = "*string(round.(rcs[i];digits=2))) for (i,pos) in enumerate(refpos)]
return fig, ax
end

"""
show_basis_function(ip::Interpolation{ref_shape,N})

Plots all basis functions of `ip`. Only implemented for 1D and 2D instances of `ip`.
"""
#function show_basis_function(ip::Ferrite.Interpolation{ref_shape,N}) where {ref_shape<:Union{RefTriangle,RefQuadrilateral},N}
function show_basis_function(ip::Ferrite.Interpolation{2,ref_shape,N}) where {ref_shape<:Union{Ferrite.RefTetrahedron,Ferrite.RefCube},N}
x,y,ref_z = get_domain(ip,20)

# initialize axes
fig,ax = initialize_figure(ip)

for i in 1:Ferrite.getnbasefunctions(ip)
local z = copy(ref_z)
for (iy,_y) in enumerate(y), (ix,_x) in enumerate(x)
!isnan(z[iy,ix]) && (z[iy,ix]=Ferrite.value(ip,i,Ferrite.Vec{2,Float64}((_x,_y))))
end
vertices, clist = get_triangulation(ip,x,y,z)
mesh!(ax[i],vertices,clist; shading=false, fxaa=true, transparency=false, color=[vertices[i,3] for i in 1:size(vertices)[1]], colormap=:viridis)
end
current_figure()
end

#function show_basis_function(ip::Ferrite.Lagrange{RefLine,N}) where {N}
function show_basis_function(ip::Ferrite.Lagrange{1,refshape,N}) where {refshape,N}
rcs = Ferrite.reference_coordinates(ip)
x = range(-1,1,length=100)

# initialize axes
min_val = Int(min(vcat(rcs...)...))
rcs = [[c[1]-min_val] for c in rcs]
scale = round(inv(min(filter(!iszero,vcat(rcs...))...));digits=15)
max_id = Int(round(max(vcat(rcs...)...)*scale))
refpos = [Int.([coord[1]+1]) for coord in rcs.*scale]

fig = Figure()
ax = [Axis(fig[1,i];xlabel=L"ξ", ylabel=L"N(ξ)" ,title="id: $(i), node = "*string(round.(rcs[i];digits=2))) for i in 1:Ferrite.getnbasefunctions(ip)]
for i in 1:Ferrite.getnbasefunctions(ip)
local z = [Ferrite.value(ip,i,Ferrite.Vec{1,Float64}((_x,))) for _x in x]
lines!(ax[refpos[i]...],x,z)
end
current_figure()
end

#function get_triangulation(ip::Ferrite.Interpolation{ref_shape,N},x,_y,_z::Matrix) where {ref_shape,N}
function get_triangulation(ip::Ferrite.Interpolation{2,ref_shape,N},x,y,z::Matrix) where {ref_shape,N}
# for CrouzeixRaviart the element does not occupy the origin. The triangulation method is not defined for this type of element. Workaround--> mirror y axis
# y = typeof(ip)==CrouzeixRaviart{RefTriangle,1,Nothing} ? reverse(_y) : _y
# z = typeof(ip)==CrouzeixRaviart{RefTriangle,1,Nothing} ? _z[end:-1:1,:] : _z
# ================================
# ===== compute vertice list =====
# ================================
sz = size(z)
nvertices_percol = (.!isnan.(z)')*ones(Int,sz[2])
nvertices = sum(nvertices_percol)
vertices = zeros(nvertices,3) # vertice numbering according to numbering:
cnt = 1 # ┌ ┐ ┌ ┐ ┌ ┐
for col in 1:sz[2], row in 1:sz[1] # │ 1 NaN NaN NaN NaN │ │ 1 NaN NaN NaN NaN │ not allowed: │ 1 NaN NaN NaN NaN │
if !isnan(z[row,col]) # │ 2 6 NaN NaN NaN │ │ 2 6 NaN 13 17 │ -connectivity │ 2 6 NaN 13 16 │
vertices[cnt,:] = [x[col], y[row], z[row,col]] # │ 3 7 10 NaN NaN │ or │ 3 7 10 14 18 │ list is not │ 3 7 10 14 17 │
cnt += 1 # │ 4 8 11 13 NaN │ │ 4 8 11 15 19 │ implemented │ 4 8 11 15 18 │
end # │ 5 9 12 14 15 │ │ 5 9 12 16 20 │ for this │ 5 9 12 NaN NaN │
end # └ └ └
# =====================================
# ===== compute connectivity list =====
# =====================================
ntriangles = 0 # number of triangles necessary
for (i,vertincol) in enumerate(nvertices_percol)
if i!=length(nvertices_percol)
ntriangles+=(vertincol-1)*2 # if current collum has same length as next one add 2 triangles per "gap" between two nodes
if vertincol==nvertices_percol[i+1]-1 # if next col is larger add 1
ntriangles+=1
elseif vertincol==nvertices_percol[i+1]+1 # if next col is smaller subtract 1
ntriangles+=-1
else
!(vertincol==nvertices_percol[i+1]) ? error("triangulation not possible") : nothing
end
end
end
clist = zeros(Int,ntriangles,3)

cnt = 1
lastvertidpercol = [sum(nvertices_percol[1:c]) for c in 1:sz[2]]
for vert in 1:lastvertidpercol[end-1]
newcol = vert in vcat(1,lastvertidpercol[1:end-1].+1) # vertex first id in a column??
col = findfirst(i->vert<=i,lastvertidpercol)
if vert==sum(nvertices_percol[1:col]) # if vert is last vert in collumn...
if nvertices_percol[col] == 1 # ... check if its the only vertex of the collumn...
clist[cnt,:] = [vert, vert+1, vert+2] # ...add triangle if necessary...
cnt+=1
end
continue # ... skip last vertex per column
end
# fill clist
offset = nvertices_percol[col]==nvertices_percol[col+1]-1 ? nvertices_percol[col]+1 : nvertices_percol[col] #set ofset according to next collumn size
clist[cnt,:] = [vert, vert+1, vert+offset]
cnt+=1
if ((nvertices_percol[col]==nvertices_percol[col+1]+1)&&(!newcol)) || ((nvertices_percol[col]==nvertices_percol[col+1]-1)&&(newcol)) # if next column is shorter && not first vertex of collumn or if next column is longer and first vertex in collumn
clist[cnt,:] = [vert, vert+offset-1, vert+offset]
cnt+=1
end
if (nvertices_percol[col]==nvertices_percol[col+1]) || (nvertices_percol[col]==nvertices_percol[col+1]-1) # if next row is longer or shorter
clist[cnt,:] = [vert+1, vert+offset+1, vert+offset]
cnt+=1
end
end
(cnt-1)!=ntriangles && error("triangulations failed. too few triangles added to connectivity list")

return vertices, clist
end

####### One Shot Methods #######
const FerriteVizPlots = Union{Type{<:Wireframe},Type{<:SolutionPlot},Type{<:Arrows},Type{<:Surface}}

Expand Down