mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-09 11:51:25 -05:00
c26d0b4f29
Divide DT search range into 3 segments. Search central segment (near DT=0) first and try to decode the largest peak. Then find the largest peak in each of the surrounding segments and try to decode those only if the peak is larger than the one found in the central segment. Also re-indent ft4_decode.f90 and some other minor tweaks.
74 lines
1.9 KiB
Fortran
74 lines
1.9 KiB
Fortran
subroutine getcandidates4(dd,fa,fb,syncmin,nfqso,maxcand,savg,candidate, &
|
|
ncand,sbase)
|
|
|
|
include 'ft4_params.f90'
|
|
real s(NH1,NHSYM)
|
|
real savg(NH1),savsm(NH1)
|
|
real sbase(NH1)
|
|
real x(NFFT1)
|
|
real window(NFFT1)
|
|
complex cx(0:NH1)
|
|
real candidate(2,maxcand)
|
|
real dd(NMAX)
|
|
integer ipk(1)
|
|
equivalence (x,cx)
|
|
logical first
|
|
data first/.true./
|
|
save first,window
|
|
|
|
if(first) then
|
|
first=.false.
|
|
pi=4.0*atan(1.)
|
|
window=0.
|
|
call nuttal_window(window,NFFT1)
|
|
endif
|
|
|
|
! Compute symbol spectra, stepping by NSTEP steps.
|
|
savg=0.
|
|
df=12000.0/NFFT1
|
|
fac=1.0/300.0
|
|
do j=1,NHSYM
|
|
ia=(j-1)*NSTEP + 1
|
|
ib=ia+NFFT1-1
|
|
if(ib.gt.NMAX) exit
|
|
x=fac*dd(ia:ib)*window
|
|
call four2a(x,NFFT1,1,-1,0) !r2c FFT
|
|
do i=1,NH1
|
|
s(i,j)=real(cx(i))**2 + aimag(cx(i))**2
|
|
enddo
|
|
savg=savg + s(1:NH1,j) !Average spectrum
|
|
enddo
|
|
savg=savg/NHSYM
|
|
savsm=0.
|
|
do i=8,NH1-7
|
|
savsm(i)=sum(savg(i-7:i+7))/15.
|
|
enddo
|
|
|
|
nfa=fa/df
|
|
if(nfa.lt.nint(200.0/df)) nfa=nint(200.0/df)
|
|
nfb=fb/df
|
|
if(nfb.gt.nint(4910.0/df)) nfb=nint(4910.0/df)
|
|
ncand=0
|
|
call ft4_baseline(savg,nfa,nfb,sbase)
|
|
if(any(sbase(nfa:nfb).le.0)) return
|
|
savsm(nfa:nfb)=savsm(nfa:nfb)/sbase(nfa:nfb)
|
|
f_offset = -1.5*12000.0/NSPS
|
|
do i=nfa+1,nfb-1
|
|
if(savsm(i).ge.savsm(i-1) .and. savsm(i).ge.savsm(i+1) .and. &
|
|
savsm(i).ge.syncmin) then
|
|
den=savsm(i-1)-2*savsm(i)+savsm(i+1)
|
|
del=0.
|
|
if(den.ne.0.0) del=0.5*(savsm(i-1)-savsm(i+1))/den
|
|
fpeak=(i+del)*df+f_offset
|
|
if(fpeak.lt.200.0 .or. fpeak.gt.4910.0) cycle
|
|
speak=savsm(i) - 0.25*(savsm(i-1)-savsm(i+1))*del
|
|
ncand=ncand+1
|
|
candidate(1,ncand)=fpeak
|
|
candidate(2,ncand)=speak
|
|
if(ncand.eq.maxcand) exit
|
|
endif
|
|
enddo
|
|
|
|
return
|
|
end subroutine getcandidates4
|