mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-15 00:21:56 -05:00
First cut at displaying a Q65 sync curve for both current sequence and accumulated average. May not be quite right, yet...
This commit is contained in:
parent
4024eac6db
commit
dda3c9d0cc
@ -20,6 +20,8 @@ module q65
|
|||||||
real, allocatable :: s1raw(:,:) !Symbol spectra, 1/8-symbol steps
|
real, allocatable :: s1raw(:,:) !Symbol spectra, 1/8-symbol steps
|
||||||
real, allocatable :: s1(:,:) !Symbol spectra w/suppressed peaks
|
real, allocatable :: s1(:,:) !Symbol spectra w/suppressed peaks
|
||||||
real, allocatable,save :: s1a(:,:,:) !Cumulative symbol spectra
|
real, allocatable,save :: s1a(:,:,:) !Cumulative symbol spectra
|
||||||
|
real, allocatable,save :: ccf2(:) !Max CCF(freq) at any lag, single seq
|
||||||
|
real, allocatable,save :: ccf2_avg(:) !Like ccf2, but for accumulated average
|
||||||
real sync(85) !sync vector
|
real sync(85) !sync vector
|
||||||
real df,dtstep,dtdec,f0dec,ftol
|
real df,dtstep,dtdec,f0dec,ftol
|
||||||
|
|
||||||
@ -64,7 +66,6 @@ subroutine q65_dec0(iavg,nutc,iwave,ntrperiod,nfqso,ntol,ndepth,lclearave, &
|
|||||||
logical first,lclearave
|
logical first,lclearave
|
||||||
real, allocatable :: s3(:,:) !Data-symbol energies s3(LL,63)
|
real, allocatable :: s3(:,:) !Data-symbol energies s3(LL,63)
|
||||||
real, allocatable :: ccf1(:) !CCF(freq) at fixed lag (red)
|
real, allocatable :: ccf1(:) !CCF(freq) at fixed lag (red)
|
||||||
real, allocatable :: ccf2(:) !Max CCF(freq) at any lag (orange)
|
|
||||||
data first/.true./
|
data first/.true./
|
||||||
save first
|
save first
|
||||||
|
|
||||||
@ -98,9 +99,6 @@ subroutine q65_dec0(iavg,nutc,iwave,ntrperiod,nfqso,ntol,ndepth,lclearave, &
|
|||||||
|
|
||||||
allocate(s3(-64:LL-65,63))
|
allocate(s3(-64:LL-65,63))
|
||||||
allocate(ccf1(-ia2:ia2))
|
allocate(ccf1(-ia2:ia2))
|
||||||
allocate(ccf2(iz))
|
|
||||||
ccf1=0.
|
|
||||||
ccf2=0.
|
|
||||||
if(LL.ne.LL0 .or. iz.ne.iz0 .or. jz.ne.jz0 .or. lclearave) then
|
if(LL.ne.LL0 .or. iz.ne.iz0 .or. jz.ne.jz0 .or. lclearave) then
|
||||||
if(allocated(s1raw)) deallocate(s1raw)
|
if(allocated(s1raw)) deallocate(s1raw)
|
||||||
allocate(s1raw(iz,jz))
|
allocate(s1raw(iz,jz))
|
||||||
@ -108,6 +106,10 @@ subroutine q65_dec0(iavg,nutc,iwave,ntrperiod,nfqso,ntol,ndepth,lclearave, &
|
|||||||
allocate(s1(iz,jz))
|
allocate(s1(iz,jz))
|
||||||
if(allocated(s1a)) deallocate(s1a)
|
if(allocated(s1a)) deallocate(s1a)
|
||||||
allocate(s1a(iz,jz,0:1))
|
allocate(s1a(iz,jz,0:1))
|
||||||
|
if(allocated(ccf2)) deallocate(ccf2)
|
||||||
|
allocate(ccf2(iz))
|
||||||
|
if(allocated(ccf2_avg)) deallocate(ccf2_avg)
|
||||||
|
allocate(ccf2_avg(iz))
|
||||||
s1=0.
|
s1=0.
|
||||||
s1a=0.
|
s1a=0.
|
||||||
navg=0
|
navg=0
|
||||||
@ -116,6 +118,8 @@ subroutine q65_dec0(iavg,nutc,iwave,ntrperiod,nfqso,ntol,ndepth,lclearave, &
|
|||||||
jz0=jz
|
jz0=jz
|
||||||
lclearave=.false.
|
lclearave=.false.
|
||||||
endif
|
endif
|
||||||
|
ccf1=0.
|
||||||
|
ccf2_avg=0.
|
||||||
dtstep=nsps/(NSTEP*12000.0) !Step size in seconds
|
dtstep=nsps/(NSTEP*12000.0) !Step size in seconds
|
||||||
lag1=-1.0/dtstep
|
lag1=-1.0/dtstep
|
||||||
lag2=1.0/dtstep + 0.9999
|
lag2=1.0/dtstep + 0.9999
|
||||||
@ -147,7 +151,7 @@ subroutine q65_dec0(iavg,nutc,iwave,ntrperiod,nfqso,ntol,ndepth,lclearave, &
|
|||||||
enddo
|
enddo
|
||||||
|
|
||||||
dat4=0
|
dat4=0
|
||||||
if(ncw.gt.0 .and. iavg.lt.2) then
|
if(ncw.gt.0 .and. iavg.le.1) then
|
||||||
! Try list decoding via "Deep Likelihood".
|
! Try list decoding via "Deep Likelihood".
|
||||||
call timer('ccf_85 ',0)
|
call timer('ccf_85 ',0)
|
||||||
! Try to synchronize using all 85 symbols
|
! Try to synchronize using all 85 symbols
|
||||||
@ -159,8 +163,14 @@ subroutine q65_dec0(iavg,nutc,iwave,ntrperiod,nfqso,ntol,ndepth,lclearave, &
|
|||||||
call timer('list_dec',1)
|
call timer('list_dec',1)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
! Get 2d CCF and ccf2 using sync symbols only
|
if(iavg.eq.0) then
|
||||||
call q65_ccf_22(s1,iz,jz,nfqso,ipk,jpk,f0a,xdta,ccf2)
|
call q65_ccf_22(s1,iz,jz,nfqso,ipk,jpk,f0a,xdta,ccf2)
|
||||||
|
endif
|
||||||
|
|
||||||
|
! Get 2d CCF and ccf2 using sync symbols only
|
||||||
|
if(iavg.eq.2) then
|
||||||
|
call q65_ccf_22(s1,iz,jz,nfqso,ipk,jpk,f0a,xdta,ccf2_avg)
|
||||||
|
endif
|
||||||
if(idec.lt.0) then
|
if(idec.lt.0) then
|
||||||
f0=f0a
|
f0=f0a
|
||||||
xdt=xdta
|
xdt=xdta
|
||||||
@ -190,7 +200,7 @@ subroutine q65_dec0(iavg,nutc,iwave,ntrperiod,nfqso,ntol,ndepth,lclearave, &
|
|||||||
width=df*(i2-i1)
|
width=df*(i2-i1)
|
||||||
|
|
||||||
if(ncw.eq.0) ccf1=0.
|
if(ncw.eq.0) ccf1=0.
|
||||||
call q65_write_red(iz,ia2,xdt,ccf1,ccf2)
|
call q65_write_red(iz,xdt,ccf2_avg,ccf2)
|
||||||
|
|
||||||
if(iavg.eq.2) then
|
if(iavg.eq.2) then
|
||||||
call q65_dec_q012(s3,LL,snr2,dat4,idec,decoded)
|
call q65_dec_q012(s3,LL,snr2,dat4,idec,decoded)
|
||||||
@ -557,24 +567,21 @@ subroutine q65_s1_to_s3(s1,iz,jz,ipk,jpk,LL,mode_q65,sync,s3)
|
|||||||
return
|
return
|
||||||
end subroutine q65_s1_to_s3
|
end subroutine q65_s1_to_s3
|
||||||
|
|
||||||
subroutine q65_write_red(iz,ia2,xdt,ccf1,ccf2)
|
subroutine q65_write_red(iz,xdt,ccf2_avg,ccf2)
|
||||||
|
|
||||||
! Write data for the red and orange sync curves to LU 17.
|
! Write data for the red and orange sync curves to LU 17.
|
||||||
|
|
||||||
real ccf1(-ia2:ia2)
|
real ccf2_avg(iz)
|
||||||
real ccf2(iz)
|
real ccf2(iz)
|
||||||
|
|
||||||
call q65_sync_curve(ccf1,-ia2,ia2,rms1)
|
call q65_sync_curve(ccf2_avg,1,iz,rms1)
|
||||||
call q65_sync_curve(ccf2,1,iz,rms2)
|
call q65_sync_curve(ccf2,1,iz,rms2)
|
||||||
|
|
||||||
rewind 17
|
rewind 17
|
||||||
write(17,1000) xdt
|
write(17,1000) xdt
|
||||||
do i=nint(nfa/df),nint(nfb/df)
|
do i=nint(nfa/df),nint(nfb/df)
|
||||||
freq=i*df
|
freq=i*df
|
||||||
ii=i-i0
|
write(17,1000) freq,ccf2_avg(i),ccf2(i)
|
||||||
ccf1a=-99.0
|
|
||||||
if(ii.ge.-ia2 .and. ii.le.ia2) ccf1a=ccf1(ii)
|
|
||||||
write(17,1000) freq,ccf1a,ccf2(i)
|
|
||||||
1000 format(f10.3,2e12.3)
|
1000 format(f10.3,2e12.3)
|
||||||
enddo
|
enddo
|
||||||
flush(17)
|
flush(17)
|
||||||
|
Loading…
Reference in New Issue
Block a user