I am trying to calculate the solid angle subtended by arbitrary-shaped loops on a sphere's surface.
First, I parametrize circular loops by:
θ(t,kx0,r)=kx0+rcos(t);
where 0≤t≤2π, and kx0, ky0 define the loop's center. So, we can say that this step draws out a circular loop on the θ/ϕ plane.
Then I project these onto the sphere's surface using spherical coordinates, as follows:
x(θ,ϕ)=rcosθsinϕ,y(θ,ϕ)=rsinθsinϕ,z(θ,ϕ)=rcosϕ
How do I go about calculating the surface area within these (x,y,z) loops on the surface? This will allow me to calculate the solid angle I need.
The solid angle is given by: Ω=∬Sˆr⋅ˆnr2dΣ=∬Rsinθdθdϕ=spherical surface arear2
I tried using various types of RegionMeasures to calculate this area (such as defining the area within the loop on the sphere as a Region, and by varying the radius from 0 to r, calculating the length of each loop in between and summing it all up), but I feel like I am missing a simple answer to my problem. Maybe what I am missing is a way to somehow map my arbitrary loops into a appropriate integration bounds for Ω, but I tried to avoid this by resorting to Mathematica.
So far, I found the following posts most useful:
Integrate to calculate enclosed area
https://math.stackexchange.com/questions/1832110/area-of-a-circle-on-sphere
Thanks in advance for your time!
Note: I am parametrizing these loops in a peculiar way because I am trying to investigate a physics problem where the functions x(θ,ϕ),y(θ,ϕ),z(θ,ϕ) will be different, and make my loops twist and turn. The ultimate goal is to find the solid angle in these cases, but I wanted to start with the sphere.
Note: I posted a similar question before, but it was misinterpreted by answerers because I did a poor job phrasing it at first, and I am afraid that it lost attention and I still am clueless as to how to proceed (I did not want to delete it because others already put time into it).
Comments
Post a Comment