Need to solve this problem about hydrogen radial wavefunction

조회 수: 18 (최근 30일)
HANAN HAKIM
HANAN HAKIM 2018년 10월 28일
답변: Star Strider 2018년 10월 28일
function [] = h_atom_radial_plot(n, l, Z)
ao = 1; % functions plotted in units of Bohr radius
r_min = 0;
r_max = 25*ao;
r_range = r_max - r_min;
r_step = 0.005; % resolution of spatial grid
r = linspace(0, r_range, r_range/r_step + 1);
zeroline = zeros(r_range/r_step + 1, 1);
psi_max = 2 * (Z / (2*ao))^(3/2); % maximum y value
rho = Z * r / ao; % scaled length rho
% associated Laguerre polynomials
if (n == 1 && l == 0)
L = 1;
N = 2 * (Z/(ao))^(3/2);
elseif (n == 2 && l == 0)
L = 2 - rho;
N = (Z/(2*ao))^(3/2);
elseif (n == 2 && l == 1)
L = rho;
N = 1/sqrt(3) * (Z/(2*ao))^(3/2);
elseif (n == 3 && l == 0)
L = 27 - 18*rho + 2*rho.^2;
N = 2/27 * (Z/(3*ao))^(3/2);
elseif (n == 3 && l == 1)
L = rho .* (6 - rho);
N = 1/27 * (2*Z/(3*ao))^(3/2);
elseif (n == 3 && l == 2)
L = rho.^2;
N = 4/(27*sqrt(10)) * (Z/(3*ao))^(3/2);
end
% prepare plot
psi = N * L .* exp(-rho/n); % psi_n_l(r)
psi2 = r.^2 .* psi.^2; % psi*_nl(r)*psi_nl(r)
plot(r, r.^2, r, psi, r, psi2, r, zeroline); % plot psi and r^2*|psi|^2
axis([r_min r_max -psi_max psi_max]);
xlabel('Radius r (units of a_o)');
ylabel('Function Value');
legend(sprintf('r^2'), ...
sprintf('R_%i_%i(r)', n, l), ...
sprintf('r^2[R*_%i_%i(r)][R_%i_%i(r)]', n, l, n, l), ...
'Location','SouthEast');
text(0.18*r_range + r_min, 0.9*psi_max, ... % title
'Hydrogen Atom Radial Wavefunction and R.D.F.');
text(0.12*r_range + r_min, -0.8*psi_max, ... % energy
sprintf('E_%i = -(1/%i)*(m_ee^4) / (8E_o^2h^2)', n, n^2));
Anybody can help to find out the solution of this problem error? ERROR LOG:
error:
% Not enough input arguments.
Error in radial_plot (line 11)
psi_max = 2 * (Z / (2*ao))^(3/2); % maximum y value

답변 (1개)

Star Strider
Star Strider 2018년 10월 28일
You must call ‘’ as a function, with arguments. You cannot run it using the green ‘Run’ triangle in the Editor.
n = some_value;
l = some_other_value;
Z = yet_another_value;
h_atom_radial_plot(n, l, Z)

카테고리

Help CenterFile Exchange에서 Quantum Chemistry에 대해 자세히 알아보기

태그

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by