Find the Charge Distribution on a Sphere
Find the positions that minimize the Coulomb potential for equally charged particles free to move on a sphere. This is the equilibrium charge distribution.
Denote by n the number of particles.
In[1]:=
data:image/s3,"s3://crabby-images/f4622/f462230a7f5b820e9b588dd480bcce72d044d285" alt="Click for copyable input"
n = 50;
Let be the Cartesian coordinates of the
particle.
In[2]:=
data:image/s3,"s3://crabby-images/a51f1/a51f10d8e838f81b7c97a39cbaba5889ad58f7d8" alt="Click for copyable input"
vars = Join[Array[x, n], Array[y, n], Array[z, n]];
The goal is to minimize the Coulomb potential.
In[3]:=
data:image/s3,"s3://crabby-images/c7bc7/c7bc7167d52367dae977c1beb60450d0cbd1b34a" alt="Click for copyable input"
potential =
Sum[((x[i] - x[j])^2 + (y[i] - y[j])^2 + (z[i] - z[j])^2)^-(1/
2), {i, 1, n - 1}, {j, i + 1, n}];
Since the particles are on a sphere, their coordinates must satisfy unit-magnitude constraints.
In[4]:=
data:image/s3,"s3://crabby-images/28ec5/28ec5888efe2fb1b810eed077c8311a9db749c52" alt="Click for copyable input"
sphereconstr = Table[x[i]^2 + y[i]^2 + z[i]^2 == 1, {i, 1, n}];
Choose initial points on the sphere at random using spherical coordinates.
In[5]:=
data:image/s3,"s3://crabby-images/b6381/b63818f2b6afc32a76c7a893fc36085a91146b32" alt="Click for copyable input"
rpts = ConstantArray[1, n];
thetapts = RandomReal[{0, Pi}, n];
phipts = RandomReal[{-Pi, Pi}, n];
spherpts = Transpose[{rpts, thetapts, phipts}];
Transform the initial points to Cartesian coordinates.
In[6]:=
data:image/s3,"s3://crabby-images/1473d/1473dbcfeb44e7f7d09f8b5f79b0a40e7a9d311d" alt="Click for copyable input"
cartpts = CoordinateTransform["Spherical" -> "Cartesian", spherpts];
Rearrange the initial points to match the variables' ordering.
In[7]:=
data:image/s3,"s3://crabby-images/c138f/c138f7a9c376f7ad5809d7b9f785869728c9c92a" alt="Click for copyable input"
initpts = Flatten[Transpose[cartpts]];
Minimize the Coulomb potential subject to the sphere constraint.
In[8]:=
data:image/s3,"s3://crabby-images/c2af1/c2af1b5bca6392606d50b879f2f6b9550817ebee" alt="Click for copyable input"
sol = FindMinimum[{potential, sphereconstr}, Thread[{vars, initpts}]];
Extract from the solution the equilibrium positions of the particles.
In[9]:=
data:image/s3,"s3://crabby-images/f2590/f2590eb884954ed886063e78350c0fc20689207f" alt="Click for copyable input"
solpts = Table[{x[i], y[i], z[i]}, {i, 1, n}] /. sol[[2]];
Plot the result.
In[10]:=
data:image/s3,"s3://crabby-images/11395/11395b9f092758952ad8f700e4d41e19c44d77f5" alt="Click for copyable input"
Show[ListPointPlot3D[solpts,
PlotRange -> {{-1.1, 1.1}, {-1.1, 1.1}, {-1.1, 1.1}},
PlotStyle -> {{PointSize[.03], Blue}}, AspectRatio -> 1,
BoxRatios -> 1, PlotLabel -> "Particle Distribution"],
Graphics3D[{Opacity[.5], Sphere[]}]]
Out[10]=
data:image/s3,"s3://crabby-images/2fc2d/2fc2dc0eb9f36a73ad92908ddf6a402c4b8232d1" alt=""