36 lines
1.0 KiB
Matlab
36 lines
1.0 KiB
Matlab
function E = calculateEnergyComponents(~,psi,Params,Transf,VDk,V)
|
|
|
|
%Parameters
|
|
|
|
KEop= 0.5*(Transf.KX.^2+Transf.KY.^2+Transf.KZ.^2);
|
|
normfac = Params.Lx*Params.Ly*Params.Lz/numel(psi);
|
|
|
|
% DDIs
|
|
frho = fftn(abs(psi).^2);
|
|
Phi = real(ifftn(frho.*VDk));
|
|
|
|
Eddi = 0.5*Params.gdd*Phi.*abs(psi).^2;
|
|
E.Eddi = trapz(Eddi(:))*Transf.dx*Transf.dy*Transf.dz;
|
|
|
|
% EddiTot = trapz(Eddi(:))*Transf.dx*Transf.dy*Transf.dz;
|
|
|
|
%Kinetic energy
|
|
% psik = ifftshift(fftn(fftshift(psi)))*normfac;
|
|
|
|
Ekin = KEop.*abs(fftn(psi)*normfac).^2;
|
|
E.Ekin = trapz(Ekin(:))*Transf.dkx*Transf.dky*Transf.dkz/(2*pi)^3;
|
|
|
|
% Potential energy
|
|
Epot = V.*abs(psi).^2;
|
|
E.Epot = trapz(Epot(:))*Transf.dx*Transf.dy*Transf.dz;
|
|
|
|
%Contact interactions
|
|
Eint = 0.5*Params.gs*abs(psi).^4;
|
|
E.Eint = trapz(Eint(:))*Transf.dx*Transf.dy*Transf.dz;
|
|
|
|
%Quantum fluctuations
|
|
Eqf = 0.4*Params.gammaQF*abs(psi).^5;
|
|
E.Eqf = trapz(Eqf(:))*Transf.dx*Transf.dy*Transf.dz;
|
|
|
|
end
|