Poissons Equation with Point source
Show older comments
Hello everyone :)
in matlab´s Example "Poisson's Equation with Point Source and Adaptive Mesh Refinement" ist a function "circlef" mentioned, that create the point source by returning 1/area for the triangle that contains the origin and zero elsewhere. How do I create such a funtion? Meaning how can I define f differently on specific traingles in the mesh?
Thanks in advance
Hannah
2 Comments
Dyuman Joshi
on 7 Feb 2024
"How do I create such a funtion?"
Use the description given as its definition.
"Meaning how can I define f differently on specific traingles in the mesh?"
Hannah Burmester
on 7 Feb 2024
Answers (1)
You can use inpolygon to see if the origin is inside the triangle or not and polyarea to calculate the area of the triangle -
Note - inpolygon() also considers the points that lie ON the edges of the polygon (see the case below).
x = [-2 -1 1];
y = [-2 1 -1];
plot(polyshape(x,y))
hold on
plot(0, 0, '.r', 'MarkerSize', 10)
if inpolygon(0, 0, x, y)
f = 1./polyarea(x,y);
else
f = 0;
end
f
This can be condensed to -
F = inpolygon(0, 0, x, y)./polyarea(x,y)
5 Comments
If the criteria you use does not involve the points ON the edge to be counted, use this -
x = [-2 -1 1];
y = [-2 1 -1];
[in,on] = inpolygon(0, 0, x, y)
if in & ~on
f = 1./polyarea(x,y);
else
f = 0;
end
f
Which, again, can be condensed to -
F = (in & ~on)./polyarea(x,y)
Dyuman Joshi
on 12 Feb 2024
Torsten
on 12 Feb 2024
I'd simply edit the mentionned MATLAB function:
edit circlef
Isn't that possible ?
Hannah Burmester
on 12 Feb 2024
Dyuman Joshi
on 12 Feb 2024
Edited: Dyuman Joshi
on 17 Feb 2024
From a cursory glance, I'd say my solution is simpler than whatever is being done here -
type circlef.m
Categories
Find more on Electromagnetics in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!