Note
Go to the end to download the full example code.
Samplers#
Various strategies for sampling vectors and quaternions
import numpy as np
import pyvista as pv
import mirage as mr
import mirage.vis as mrv
Sampling uniform unit vectors
n = 1_000
pl = pv.Plotter()
uv = mr.rand_unit_vectors(n)
mrv.scatter3(pl, uv, point_size=10, color='c')
mrv.two_sphere(pl)
pl.show()
data:image/s3,"s3://crabby-images/4479c/4479cc3ce9adab067e6a7f220bfdf81ce4d04dd0" alt="samplers"
Sampling uniform vectors in a cone
v = mr.rand_unit_vectors(1)
pl = pv.Plotter()
uv = mr.rand_cone_vectors(v, np.pi / 10, n)
mrv.scatter3(pl, uv, point_size=10, color='c')
mrv.scatter3(pl, v, point_size=20, color='r')
mrv.two_sphere(pl)
pl.view_isometric()
pl.show()
data:image/s3,"s3://crabby-images/14400/14400cc84cdc46adcaa1924b6f2558ace7b32823" alt="samplers"
Sampling uniform vectors in multiple cone
v = mr.rand_unit_vectors(100)
pl = pv.Plotter()
uv = mr.rand_cone_vectors(v, np.pi / 30, 100)
mrv.scatter3(pl, uv, point_size=10, color='c')
mrv.scatter3(pl, v, point_size=20, color='r')
mrv.two_sphere(pl)
pl.view_isometric()
pl.show()
data:image/s3,"s3://crabby-images/15bc6/15bc6b3879873c6d1095908f332936cdaa778108" alt="samplers"
Sampling uniformly in the volume of a ball
pl = pv.Plotter()
uv = mr.rand_points_in_ball(1.0, n)
mrv.scatter3(pl, uv, point_size=10, cmap='cool', scalars=mr.vecnorm(uv))
mrv.two_sphere(pl)
pl.view_isometric()
pl.show()
data:image/s3,"s3://crabby-images/a4983/a49838f88809268cb9ed647ff494264902b1fcea" alt="samplers"
Sampling uniformly in a spherical shell
pl = pv.Plotter()
uv = mr.rand_points_in_shell((0.6, 0.7), n)
mrv.scatter3(pl, uv, point_size=10, cmap='cool', scalars=mr.vecnorm(uv))
mrv.two_sphere(pl)
pl.view_isometric()
pl.show()
data:image/s3,"s3://crabby-images/1bcda/1bcda77945cc5930d9f54a44d3f16315f7b49539" alt="samplers"
Total running time of the script: (0 minutes 0.700 seconds)