model = sqw_sine3d(p, h,k,l,w, {signal}) : sine dispersion(HKL) with DHO(energy) iFunc/sqw_sine3d: a 4D S(q,w) with a 3D HKL sine dispersion, and a DHO line shape. The sine dispersion can be tuned with energy gaps at zone centre and boundary, as well as a periodicity of the sine wave. WARNING: Single intensity and line width parameters are used here. Along a principal Q axis, the dispersion has the form: w = E0 + (E1-E0)*sin(Q_freq*pi*(Q-Q0)); This is a sine wave which goes from w=E0 at Q=Q0, up to w=E1 at 1/2Q_freq. The inter-atomic distance between the scattering units (atoms) is thus: d=a*Q_freq/2 [in Angs, with a=lattice parameter] A spin wave could for instance mostly use Q0=0, Q_freq=1, E0=0, E1>0 For a simple ferromagnetic magnon the gap width is E1-E0=4JS with J=exchange energy and S=magnetic moment of spins. An acoustic branch could use Q0=0, Q_freq=.5, E0=0, E1>0 The sound velocity in acoustic branches is: c=E1*Q_freq*pi*1.519e2*a/2 [in m/s, with a=lattice parameter] An optical branch could use Q0=0, Q_freq=.2, E0>E1 E1>0 To shift the minimum/maximum Q of the dispersion, move QH0,QK0,QL0 To change the extent of the dispersion in Q, vary QH_freq,QK_freq,QL_freq To change to minimum and maximum energy, move E0 and E1_qh,E1_qk,E1_ql To model an incomensurate dispersion, move both QH0,QK0,QL0 and the QH_freq,QL_freq,QK_freq to incomensurate (non rational) values. To quickly create predefined models, use: model=sqw_sine3d(Emax) creates an acoustic dispersion up to Emax model=sqw_sine3d([ E0 E1 ]) creates an optical dispersion from E0 to E1 model=sqw_sine3d([ E0 E1 Q_freq ]) creates a dispersion from E0 to E1 with given Q frequency, e.g. .5, 1 or 2 Of course, as for any iFunc model, parameter values can be changed afterwards. To model more than one branch, just add these models together, e.g.: disp3 = sqw_sine3d(5) + sqw_sine3d([ 10 8 ]) + sqw_sine3d([ 2 4 1 ]) which is an acoustic plus optical branch, and a spin wave with 2 meV gap. Example: s=sqw_sine3d(5); qh=linspace(0,1,50);qk=qh; ql=qh'; w=linspace(0.01,10,50); f=iData(s,s.p,qh,qk,ql,w); plot(log(f(:,:,1,:))); Reference: https://en.wikipedia.org/wiki/Phonon input: p: sqw_sine3d model parameters (double) p(1)= E1_qh energy at QH half period [meV] p(2)= E1_qk energy at QK half period [meV] p(3)= E1_ql energy at QL half period [meV] p(4)= E0 zone-centre energy gap [meV] p(5)= QH0 QH zone-centre [rlu] p(6)= QK0 QK zone-centre [rlu] p(7)= QL0 QL zone-centre [rlu] p(8)= QH_freq QH frequency [multiples of pi] p(9)= QK_freq QK frequency [multiples of pi] p(10)=QL_freq QL frequency [multiples of pi] p(11)=Gamma dispersion DHO half-width in energy [meV] p(12)=Temperature of the material [K] p(13)=Amplitude p(14)=Background (constant) or p='guess' qh: axis along QH in rlu (row,double) qk: axis along QK in rlu (column,double) ql: axis along QL in rlu (page,double) w: axis along energy in meV (double) signal: when values are given, a guess of the parameters is performed (double) output: signal: model value Version: Nov. 26, 2018 See also iData, iFunc/fits, iFunc/plot, gauss, sqw_phonons, sqw_cubic_monoatomic, sqw_vaks <a href="matlab:doc(iFunc,'Models')">iFunc:Models</a> (c) E.Farhi, ILL. License: EUPL.