1 #pragma rtGlobals=3// Use modern global access method and strict wave access. 2 #pragma IgorVersion = 6.2 3 #pragma ModuleName = PearlFitFuncs 5 #include "mm-physconst" 48 variable np = numpnts(w)
51 variable v = w[0] + x * w[1]
52 for (ip = 2; ip < np; ip += 3)
53 v += w[ip] * exp( -( (x - w[ip+1]) / w[ip+2] )^2 )
84 variable np = numpnts(pw)
87 yw = pw[0] + xw[p] * pw[1]
88 for (ip = 2; ip < np; ip += 3)
89 yw += pw[ip] * exp( -( (xw[p] - pw[ip+1]) / pw[ip+2] )^2 )
114 variable np = numpnts(w)
117 variable v = w[0] + x * w[1]
118 for (ip = 2; ip < np; ip += 4)
119 v += w[ip] * VoigtFunc((x - w[ip+1]) / w[ip+2], w[ip+3])
140 threadsafe variable
DoniachSunjic(variable x, variable amp, variable pos, variable sing, variable fwhm){
148 nom = cos(pi * sing / 2 + (1 - sing) * atan((x - pos) / fwhm * 2))
149 denom = ((x - pos)^2 + fwhm^2 / 4)^((1 - sing) / 2)
151 return amp * nom / denom * fwhm / 2
171 variable np = numpnts(w)
174 variable v = w[0] + x * w[1]
175 for (ip = 2; ip < np; ip += 4)
183 threadsafe variable
ds1_bg(wave w, variable x){
206 threadsafe variable
ds2_bg(wave w, variable x){
231 return w[0] + ds1 + ds2
263 Variable ds1, ds2, ds3, ds4
264 ds1=( w[1]*cos(pi*w[3]/2+(1-w[3])*atan((x-w[2])/w[4])))/(((x-w[2])^2+w[4]^2)^((1-w[3])/2))
265 ds2=( w[5]*cos(pi*w[7]/2+(1-w[7])*atan((x-w[6])/w[8])))/(((x-w[6])^2+w[8]^2)^((1-w[7])/2))
266 ds3=( w[9]*cos(pi*w[11]/2+(1-w[11])*atan((x-w[10])/w[12])))/(((x-w[10])^2+w[12]^2)^((1-w[11])/2))
267 ds4=( w[13]*cos(pi*w[15]/2+(1-w[15])*atan((x-w[14])/w[16])))/(((x-w[14])^2+w[16]^2)^((1-w[15])/2))
270 return w[0]+ds1+ds2+ds3+ds4
324 Variable ds1, ds2, ds3, ds4, ds5, ds6
325 ds1=( w[1]*cos(pi*w[3]/2+(1-w[3])*atan((x-w[2])/w[4])))/(((x-w[2])^2+w[4]^2)^((1-w[3])/2))
326 ds2=( w[5]*cos(pi*w[7]/2+(1-w[7])*atan((x-w[6])/w[8])))/(((x-w[6])^2+w[8]^2)^((1-w[7])/2))
327 ds3=( w[9]*cos(pi*w[11]/2+(1-w[11])*atan((x-w[10])/w[12])))/(((x-w[10])^2+w[12]^2)^((1-w[11])/2))
328 ds4=( w[13]*cos(pi*w[15]/2+(1-w[15])*atan((x-w[14])/w[16])))/(((x-w[14])^2+w[16]^2)^((1-w[15])/2))
329 ds5=( w[17]*cos(pi*w[19]/2+(1-w[19])*atan((x-w[18])/w[20])))/(((x-w[18])^2+w[20]^2)^((1-w[19])/2))
330 ds6=( w[21]*cos(pi*w[23]/2+(1-w[23])*atan((x-w[22])/w[24])))/(((x-w[22])^2+w[24]^2)^((1-w[23])/2))
332 return w[0]+ds1+ds2+ds3+ds4+ds5+ds6
391 if (WaveExists(s.
xdw))
400 wave fs.model = model
401 wave fs.broadening = broadening
402 wave fs.convolution = convolution
406 differentiate /p xw /d=xdw
408 variable xd = wavemin(xdw) / oversampling
411 variable x0b = pw[6] * precision
412 variable nb = 2 * floor(x0b / xd) + 1
415 variable x0m = max(abs(wavemax(xw) - pw[1]), abs(wavemin(xw) - pw[1])) + x0b
416 variable nm = 2 * floor(x0m / xd) + 1
417 nb = min(nb, nm * 10)
420 redimension /n=(nb) broadening
421 redimension /n=(nm) model
422 setscale/i x -x0b, x0b,
"", broadening
423 setscale/i x -x0m, x0m,
"", model
425 broadening = exp( - (x / pw[6])^2 * 4 * ln(2))
426 variable nrm = area(broadening)
433 variable scale = pw[0] / wavemax(model)
438 x0m = xd * (nm - 1) / 2
439 setscale/i x -x0m, x0m,
"", model
441 yw =
model(xw[p] - pw[1]) + pw[7] + pw[8] * xw[p]
442 yw = numtype(yw) ? 0 : yw
478 dfref df = root:packages:pearl_fitfuncs:doniach_sunjic
479 if (DataFolderRefStatus(df) == 0)
480 newdatafolder root:packages:pearl_fitfuncs:doniach_sunjic
481 dfref df = root:packages:pearl_fitfuncs:doniach_sunjic
484 wave /z /sdfr=df fs.
xdw =
xdw 489 if (WaveExists(fs.
xdw) == 0)
490 dfref savedf = GetDataFolderDFR()
494 wave fs.
model = model
517 duplicate /free
pw, fs.
pw 518 duplicate /free
yw, fs.
xw 520 duplicate /free
yw, fs.
yw 542 duplicate /free
pw, fs.
pw 544 duplicate /free
xw, fs.
xw 546 duplicate /free
yw, fs.
xw 549 duplicate /free
yw, fs.
yw 551 variable v_chisq = nan
552 variable V_FitMaxIters = 100
553 make /n=1 /t /free constraints = {
"K0 >= 0",
"K2 > 0",
"K2 < 10",
"K3 >= 0",
"K3 < 1",
"K4 >= -10",
"K4 <= 10",
"K5 >= 0",
"K5 <= 1",
"K6 >= 0",
"K6 < 10"}
564 variable
Au4f(wave w, variable x){
596 variable vc1, vc2, vc3, vc4
597 vc2 = 2 * sqrt(ln(2)) / w[ip0-1]
598 for (ip = ip0; ip < np; ip += 3)
599 vc1 = w[ip] / sqrt(pi) * vc2
601 vc4 = vc2 * w[ip+2] / 2
602 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
626 variable bg = w[0] + w[1] * x
633 vc2 = 2 * sqrt(ln(2)) / w[2]
636 vc1 = w[3] / sqrt(pi) * vc2
639 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
642 vc1 = w[3] / sqrt(pi) * vc2 * w[9]
645 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
648 vc1 = w[6] / sqrt(pi) * vc2
651 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
654 vc1 = w[6] / sqrt(pi) * vc2 * w[9]
657 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
667 duplicate /free coef_wave, coef1, coef2
669 coef2[3] *= coef_wave[9]
670 coef2[4] += coef_wave[10]
671 coef2[6] *= coef_wave[9]
672 coef2[7] += coef_wave[10]
675 string s_fit_wave = NameOfWave(fit_wave)
676 string s_fit_p1 = s_fit_wave +
"_p1" 677 string s_fit_p2 = s_fit_wave +
"_p2" 678 duplicate /o fit_wave, $(s_fit_p1) /wave=fit_p1
679 duplicate /o fit_wave, $(s_fit_p2) /wave=fit_p2
684 string traces = TraceNameList(
"",
";", 1)
685 if ((WhichListItem(s_fit_wave, traces,
";") >= 0) && (WhichListItem(s_fit_p1, traces,
";") < 0))
686 appendtograph fit_p1, fit_p2
687 ModifyGraph lstyle($s_fit_p1)=2
688 ModifyGraph lstyle($s_fit_p2)=2
689 ModifyGraph rgb($s_fit_p1)=(0,0,65280)
690 ModifyGraph rgb($s_fit_p2)=(0,0,65280)
713 variable bg = w[0] + w[1] * x
720 vc2 = 2 * sqrt(ln(2)) / w[2]
723 vc1 = w[3] / sqrt(pi) * vc2
726 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
729 vc1 = w[3] / sqrt(pi) * vc2 * w[9]
732 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
735 vc1 = w[3] / sqrt(pi) * vc2 * w[11]
738 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
741 vc1 = w[6] / sqrt(pi) * vc2
744 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
747 vc1 = w[6] / sqrt(pi) * vc2 * w[9]
750 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
753 vc1 = w[6] / sqrt(pi) * vc2 * w[11]
756 v += vc1 * VoigtFunc(vc2 * (x - vc3), vc4)
766 duplicate /free coef_wave, coef1, coef2, coef3
770 coef2[3] *= coef_wave[9]
771 coef2[4] += coef_wave[10]
772 coef2[6] *= coef_wave[9]
773 coef2[7] += coef_wave[10]
777 coef3[3] *= coef_wave[11]
778 coef3[4] += coef_wave[12]
779 coef3[6] *= coef_wave[11]
780 coef3[7] += coef_wave[12]
784 string s_fit_wave = NameOfWave(fit_wave)
785 string s_fit_p1 = s_fit_wave +
"_p1" 786 string s_fit_p2 = s_fit_wave +
"_p2" 787 string s_fit_p3 = s_fit_wave +
"_p3" 788 duplicate /o fit_wave, $(s_fit_p1) /wave=fit_p1
789 duplicate /o fit_wave, $(s_fit_p2) /wave=fit_p2
790 duplicate /o fit_wave, $(s_fit_p3) /wave=fit_p3
796 string traces = TraceNameList(
"",
";", 1)
797 if ((WhichListItem(s_fit_wave, traces,
";") >= 0) && (WhichListItem(s_fit_p1, traces,
";") < 0))
798 appendtograph fit_p1, fit_p2, fit_p3
799 ModifyGraph lstyle($s_fit_p1)=2
800 ModifyGraph lstyle($s_fit_p2)=2
801 ModifyGraph lstyle($s_fit_p3)=2
802 ModifyGraph rgb($s_fit_p1)=(0,0,65280)
803 ModifyGraph rgb($s_fit_p2)=(0,0,65280)
804 ModifyGraph rgb($s_fit_p3)=(0,0,65280)
821 variable precision_g = 5
825 duplicate /free
xw,
xdw 826 differentiate /p xw /d=
xdw 828 variable xd = wavemin(xdw) / oversampling
831 variable x0g = abs(pw[5]) * precision_g
832 variable ng = 2 * floor(x0g / xd) + 1
835 variable emax = wavemax(xw)
836 variable emin = wavemin(xw)
837 variable x0f = max(abs(emax - pw[3]), abs(emin - pw[3])) + x0g
838 variable ne = 2 * floor(x0f / xd) + 1
841 make /d /n=(ng) /free gausswave
842 make /d /n=(ne) /free fermiwave
843 setscale/i x -x0g, x0g,
"", gausswave
844 setscale/i x -x0f, x0f,
"", fermiwave
846 gausswave = exp( - (x / pw[5] )^2 )
847 fermiwave = 1 / (exp( x / (kBoltzmann * pw[4])) + 1.0 )
850 duplicate /free fermiwave, resultwave
851 Convolve /a gausswave, resultwave
852 variable rmax = wavemax(resultwave)
856 ng = numpnts(resultwave)
857 x0g = xd * (ng - 1) / 2
858 setscale/i x -x0g, x0g,
"", resultwave
860 yw = pw[2] * resultwave(xw[p] - pw[3]) + pw[0] + pw[1] * xw[p]
threadsafe variable MultiGaussLinBG(wave w, variable x)
multiple gaussian peaks on a linear background fit function.
variable DoniachSunjicBroad(wave pw, wave yw, wave xw)
threadsafe variable MultiGaussLinBG_AO(wave pw, wave yw, wave xw)
multiple gaussian peaks on a linear background fit function (all at once).
variable ds4_bg(wave w, variable x)
variable FermiGaussConv(wave pw, wave yw, wave xw)
convolution of Fermi-Dirac distribution and a Gaussian.
threadsafe variable DoniachSunjicBroadS(DoniachSunjicStruct *s)
threadsafe variable DoniachSunjic(variable x, variable amp, variable pos, variable sing, variable fwhm)
Doniach-Sunjic line shape.
variable Au4f(wave w, variable x)
variable Au4f_2p3(wave w, variable x)
variable Au4f_2p2(wave w, variable x)
variable ShowComponents_Au4f_2p2(wave coef_wave, wave fit_wave)
variable Calc_DoniachSunjicBroad(wave pw, wave yw)
variable ShowComponents_Au4f_2p3(wave coef_wave, wave fit_wave)
variable Fit_DoniachSunjicBroad(wave pw, wave yw, wave xw, wave ww)
threadsafe variable ds2_bg(wave w, variable x)
variable ds6_bg(wave w, variable x)
variable MultiDoniachSunjicLinBG(wave w, variable x)
multiple doniach-sunjic peaks on a linear background fit function.
threadsafe variable ds1_bg(wave w, variable x)
variable MultiVoigtLinBG(wave w, variable x)
multiple voigt peaks on a linear background fit function.