Hello,
Your library is amazing and so are your examples. I was working on something similar for my research then stumbled upon your project.
I am trying to specify a simple barrier for Quantum Tunneling. I copy/pasted the method for rendering eigen modes and used it to render the potential
I specify the potential with this code
def tunnelingBarrier(
particle, potential = 1,
offsetX = .2, offsetY = .5, offsetZ = .5,
width = .2, height = 1, depth = 1
):
extent = np.abs(particle.x.max()) + np.abs(particle.x.min())
offsetX *= particle.x.max()
width *= particle.x.max()
return np.where(
(particle.x < (offsetX + width)) & (particle.x > offsetX),
np.ones(particle.x.shape) * potential,
np.zeros(particle.x.shape),
)
Here is what I get:
It took quite a lot of struggle getting too this point, and thankfully it is sort of working
I can just see a an evanescent probability density on the other side of where the barrier might be.
data:image/s3,"s3://crabby-images/1d52b/1d52b4b53fbd327bf7eaadb6680d62b08f6e772e" alt="Screenshot from 2022-12-10 20-31-43"
However its quite wonky, first there is the matter of the gap, the value should be constant wherever the conditions are satisfied.
If I double the offset (without changing particle.x.max()
) the width of the barrier increases as well, while it should not be effected. Its like there are 2 of them.
data:image/s3,"s3://crabby-images/ae41d/ae41d4a7fbdd9fba222b23c314d373b68c761790" alt="Screenshot from 2022-12-10 20-19-50"
I did modify the existing way of rendering things, so maybe I did something wrong there and its just a graphical thing?
from mayavi import mlab
import numpy as np
from qmsolve.util.constants import *
def plot_potential(hamiltonian, contrast_vals= [0.1, 0.25], plot_type = "volume"):
potential = hamiltonian.Vgrid
mlab.figure(1, bgcolor=(0, 0, 0), size=(700, 700))
abs_max= np.amax(np.abs(potential))
potential = (potential)/(abs_max)
L = hamiltonian.extent / 2 / Å
N = hamiltonian.N
vol = mlab.pipeline.volume(mlab.pipeline.scalar_field(potential))
# Change the color transfer function
from tvtk.util import ctf
c = ctf.save_ctfs(vol._volume_property)
c['rgb'] = [[-0.45, 0.3, 0.3, 1.0],
[-0.4, 0.1, 0.1, 1.0],
[-0.3, 0.0, 0.0, 1.0],
[-0.2, 0.0, 0.0, 1.0],
[-0.001, 0.0, 0.0, 1.0],
[0.0, 0.0, 0.0, 0.0],
[0.001, 1.0, 0.0, 0.],
[0.2, 1.0, 0.0, 0.0],
[0.3, 1.0, 0.0, 0.0],
[0.4, 1.0, 0.1, 0.1],
[0.45, 1.0, 0.3, 0.3]]
c['alpha'] = [[-0.5, 1.0],
[-contrast_vals[1], 1.0],
[-contrast_vals[0], 0.0],
[0, 0.0],
[contrast_vals[0], 0.0],
[contrast_vals[1], 1.0],
[0.5, 1.0]]
if plot_type == 'volume':
ctf.load_ctfs(c, vol._volume_property)
# Update the shadow LUT of the volume module.
vol.update_ctf = True
mlab.outline()
mlab.axes(xlabel='x [Å]', ylabel='y [Å]', zlabel='z [Å]',nb_labels=6 , ranges = (-L,L,-L,L,-L,L) )
#azimuth angle
φ = 30
mlab.view(azimuth= φ, distance=N*3.5)
mlab.show()
if plot_type == 'abs-volume':
abs_max= np.amax(np.abs(potential))
psi = (potential)/(abs_max)
L = hamiltonian.extent/2/Å
N = hamiltonian.N
vol = mlab.pipeline.volume(mlab.pipeline.scalar_field(np.abs(psi)), vmin= contrast_vals[0], vmax= contrast_vals[1])
# Change the color transfer function
mlab.outline()
mlab.axes(xlabel='x [Å]', ylabel='y [Å]', zlabel='z [Å]',nb_labels=6 , ranges = (-L,L,-L,L,-L,L) )
#azimuth angle
φ = 30
mlab.view(azimuth= φ, distance=N*3.5)
mlab.show()
elif plot_type == 'contour':
psi = potential
L = hamiltonian.extent/2/Å
N = hamiltonian.N
isovalue = np.mean(contrast_vals)
abs_max= np.amax(np.abs(potential))
psi = (psi)/(abs_max)
field = mlab.pipeline.scalar_field(np.abs(psi))
arr = mlab.screenshot(antialiased = False)
mlab.outline()
mlab.axes(xlabel='x [Å]', ylabel='y [Å]', zlabel='z [Å]',nb_labels=6 , ranges = (-L,L,-L,L,-L,L) )
colour_data = np.angle(psi.T.ravel())%(2*np.pi)
field.image_data.point_data.add_array(colour_data)
field.image_data.point_data.get_array(1).name = 'phase'
field.update()
field2 = mlab.pipeline.set_active_attribute(field,
point_scalars='scalar')
contour = mlab.pipeline.contour(field2)
contour.filter.contours= [isovalue,]
contour2 = mlab.pipeline.set_active_attribute(contour,
point_scalars='phase')
s = mlab.pipeline.surface(contour, colormap='hsv', vmin= 0.0 ,vmax= 2.*np.pi)
s.scene.light_manager.light_mode = 'vtk'
s.actor.property.interpolation = 'phong'
#azimuth angle
φ = 30
mlab.view(azimuth= φ, distance=N*3.5)
mlab.show()
The field is normalized but if its constant over a region then it should have the same color/value throughout the region. I looked at the code for Hamiltonian
, the generation of the potential looks pretty straightforward, I'm not sure what is causing it.
So I would like to ask:
A: How do I resolve this, and is it me or qmsolve?
B: Could we have some documentation on how to specify potentials?
Thank you :)