function [psi] = setupWavefunction(~,Params,Transf) X = Transf.X; Y = Transf.Y; Z = Transf.Z; ellx = sqrt(Params.hbar/(Params.m*Params.wx))/Params.l0; elly = sqrt(Params.hbar/(Params.m*Params.wy))/Params.l0; ellz = sqrt(Params.hbar/(Params.m*Params.wz))/Params.l0; Rx = 8*ellx; Ry = 8*elly; Rz = 8*ellz; X0 = 0.0*Transf.Xmax; Y0 = 0.0*Transf.Ymax; Z0 = 0*Transf.Zmax; psi = exp(-(X-X0).^2/Rx^2-(Y-Y0).^2/Ry^2-(Z-Z0).^2/Rz^2); cur_norm = trapz(abs(psi(:)).^2)*Transf.dx*Transf.dy*Transf.dz; psi = psi/sqrt(cur_norm); % add some noise r = normrnd(0,1,size(X)); theta = rand(size(X)); noise = r.*exp(2*pi*1i*theta); psi = psi + 0.01*noise; Norm = trapz(abs(psi(:)).^2)*Transf.dx*Transf.dy*Transf.dz; psi = sqrt(Params.N)*psi/sqrt(Norm); end