mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 01:50:30 -04:00 
			
		
		
		
	Partial implementation of Q65 message averaging.
This commit is contained in:
		
							parent
							
								
									008cb37c16
								
							
						
					
					
						commit
						c5a0de6210
					
				| @ -96,7 +96,7 @@ contains | |||||||
|     call q65_sync(nutc,iwave,ntrperiod*12000,mode65,codewords,ncw,nsps,   & |     call q65_sync(nutc,iwave,ntrperiod*12000,mode65,codewords,ncw,nsps,   & | ||||||
|          nfqso,ntol,emedelay,xdt,f0,snr1,width,dat4,snr2,id1) |          nfqso,ntol,emedelay,xdt,f0,snr1,width,dat4,snr2,id1) | ||||||
|     call timer('sync_q65',1) |     call timer('sync_q65',1) | ||||||
|     if(id1.eq.1) then |     if(id1.eq.1 .or. id1.ge.12) then | ||||||
|        xdt1=xdt |        xdt1=xdt | ||||||
|        f1=f0 |        f1=f0 | ||||||
|        go to 100 |        go to 100 | ||||||
|  | |||||||
| @ -24,17 +24,19 @@ subroutine q65_sync(nutc,iwave,nmax,mode_q65,codewords,ncw,nsps,nfqso,ntol, & | |||||||
|   integer dat4(13) |   integer dat4(13) | ||||||
|   integer ijpk(2) |   integer ijpk(2) | ||||||
|   logical unpk77_success |   logical unpk77_success | ||||||
|  |   logical lavg | ||||||
|   character*77 c77,decoded*37 |   character*77 c77,decoded*37 | ||||||
|   real, allocatable :: s1(:,:)           !Symbol spectra, 1/8-symbol steps |   real, allocatable :: s1(:,:)           !Symbol spectra, 1/8-symbol steps | ||||||
|   real, allocatable :: s3(:,:)           !Data-symbol energies s3(LL,63) |   real, allocatable :: s3(:,:)           !Data-symbol energies s3(LL,63) | ||||||
|  |   real, allocatable,save :: s3avg(:,:)   !Averaged data-symbol energies | ||||||
|   real, allocatable :: ccf(:,:)          !CCF(freq,lag) |   real, allocatable :: ccf(:,:)          !CCF(freq,lag) | ||||||
|   real, allocatable :: ccf1(:)           !CCF(freq) at best lag |   real, allocatable :: ccf1(:)           !CCF(freq) at best lag | ||||||
|   real s3prob(0:63,63)                   !Symbol-value probabilities |   real s3prob(0:63,63)                   !Symbol-value probabilities | ||||||
|   real sync(85)                          !sync vector |   real sync(85)                          !sync vector | ||||||
|   complex, allocatable :: c0(:)          !Complex spectrum of symbol |   complex, allocatable :: c0(:)          !Complex spectrum of symbol | ||||||
|   data isync/1,9,12,13,15,22,23,26,27,33,35,38,46,50,55,60,62,66,69,74,76,85/ |   data isync/1,9,12,13,15,22,23,26,27,33,35,38,46,50,55,60,62,66,69,74,76,85/ | ||||||
|   data sync(1)/99.0/ |   data sync(1)/99.0/,LL0/-1/ | ||||||
|   save sync |   save sync,navg,LL0 | ||||||
| 
 | 
 | ||||||
|   snr1=0. |   snr1=0. | ||||||
|   id1=0 |   id1=0 | ||||||
| @ -54,6 +56,12 @@ subroutine q65_sync(nutc,iwave,nmax,mode_q65,codewords,ncw,nsps,nfqso,ntol, & | |||||||
| 
 | 
 | ||||||
|   allocate(s1(iz,jz)) |   allocate(s1(iz,jz)) | ||||||
|   allocate(s3(-64:LL-65,63)) |   allocate(s3(-64:LL-65,63)) | ||||||
|  |   if(LL.ne.LL0) then | ||||||
|  |      if(allocated(s3avg)) deallocate(s3avg) | ||||||
|  |      allocate(s3avg(-64:LL-65,63)) | ||||||
|  |      navg=0 | ||||||
|  |      LL0=LL | ||||||
|  |   endif | ||||||
|   allocate(c0(0:nfft-1)) |   allocate(c0(0:nfft-1)) | ||||||
|   allocate(ccf(-ia2:ia2,-53:214)) |   allocate(ccf(-ia2:ia2,-53:214)) | ||||||
|   allocate(ccf1(-ia2:ia2)) |   allocate(ccf1(-ia2:ia2)) | ||||||
| @ -63,6 +71,8 @@ subroutine q65_sync(nutc,iwave,nmax,mode_q65,codewords,ncw,nsps,nfqso,ntol, & | |||||||
|      do k=1,22 |      do k=1,22 | ||||||
|         sync(isync(k))=1.0               !Sync tone ON |         sync(isync(k))=1.0               !Sync tone ON | ||||||
|      enddo |      enddo | ||||||
|  |      s3avg=0. | ||||||
|  |      navg=0 | ||||||
|   endif |   endif | ||||||
| 
 | 
 | ||||||
|   fac=1/32767.0 |   fac=1/32767.0 | ||||||
| @ -175,7 +185,9 @@ subroutine q65_sync(nutc,iwave,nmax,mode_q65,codewords,ncw,nsps,nfqso,ntol, & | |||||||
|   baud=12000.0/nsps |   baud=12000.0/nsps | ||||||
|   ibwa=1.8*log(baud*mode_q65) + 2 |   ibwa=1.8*log(baud*mode_q65) + 2 | ||||||
|   ibwb=min(10,ibwa+4) |   ibwb=min(10,ibwa+4) | ||||||
|   do ibw=ibwa,ibwb |   lavg=.false. | ||||||
|  | 
 | ||||||
|  | 10 do ibw=ibwa,ibwb | ||||||
|      b90=1.72**ibw |      b90=1.72**ibw | ||||||
|      call q65_intrinsics_ff(s3,nsubmode,b90/baud,nFadingModel,s3prob) |      call q65_intrinsics_ff(s3,nsubmode,b90/baud,nFadingModel,s3prob) | ||||||
|      call q65_dec_fullaplist(s3,s3prob,codewords,ncw,esnodb,dat4,plog,irc) |      call q65_dec_fullaplist(s3,s3prob,codewords,ncw,esnodb,dat4,plog,irc) | ||||||
| @ -196,9 +208,9 @@ subroutine q65_sync(nutc,iwave,nmax,mode_q65,codewords,ncw,nsps,nfqso,ntol, & | |||||||
|         smax=maxval(ccf1) |         smax=maxval(ccf1) | ||||||
|         if(smax.gt.10.0) ccf1=10.0*ccf1/smax |         if(smax.gt.10.0) ccf1=10.0*ccf1/smax | ||||||
|         go to 200 |         go to 200 | ||||||
| !        go to 900 |  | ||||||
|      endif |      endif | ||||||
|   enddo |   enddo | ||||||
|  |   if(lavg) go to 900 | ||||||
| 
 | 
 | ||||||
| !###################################################################### | !###################################################################### | ||||||
| ! Establish xdt, f0, and snr1 using sync symbols (and perhaps some AP symbols) | ! Establish xdt, f0, and snr1 using sync symbols (and perhaps some AP symbols) | ||||||
| @ -241,6 +253,7 @@ subroutine q65_sync(nutc,iwave,nmax,mode_q65,codewords,ncw,nsps,nfqso,ntol, & | |||||||
|   if(snr1.gt.10.0) ccf1=(10.0/snr1)*ccf1 |   if(snr1.gt.10.0) ccf1=(10.0/snr1)*ccf1 | ||||||
| 
 | 
 | ||||||
| 200 smax=maxval(ccf1) | 200 smax=maxval(ccf1) | ||||||
|  |   if(lavg) id1=10+navg                    !This is an average decode | ||||||
|   i1=-9999 |   i1=-9999 | ||||||
|   i2=-9999 |   i2=-9999 | ||||||
|   do i=-ia,ia |   do i=-ia,ia | ||||||
| @ -254,6 +267,21 @@ subroutine q65_sync(nutc,iwave,nmax,mode_q65,codewords,ncw,nsps,nfqso,ntol, & | |||||||
|   enddo |   enddo | ||||||
|   close(17) |   close(17) | ||||||
|   width=df*(i2-i1) |   width=df*(i2-i1) | ||||||
|  |   if(id1.ge.1) then | ||||||
|  |      navg=0 | ||||||
|  |      s3avg=0. | ||||||
|  |      if(lavg) go to 900 | ||||||
|  |   elseif(snr1.ge.0.0) then | ||||||
|  |      s3avg=s3avg+s3 | ||||||
|  |      navg=navg+1 | ||||||
|  |      write(71,3071) nutc,navg,xdt,f0,snr1 | ||||||
|  | 3071 format(2i5,3f10.2) | ||||||
|  |      if(navg.ge.2) then | ||||||
|  |         s3=s3avg/navg | ||||||
|  |         lavg=.true. | ||||||
|  |         go to 10 | ||||||
|  |      endif | ||||||
|  |   endif | ||||||
| 
 | 
 | ||||||
| 900 return | 900 return | ||||||
| end subroutine q65_sync | end subroutine q65_sync | ||||||
|  | |||||||
| @ -139,6 +139,10 @@ program test_q65 | |||||||
|         if(ntrperiod.le.30) i0=25 |         if(ntrperiod.le.30) i0=25 | ||||||
|         if(line(i0:i0).ne.' ') read(line(60:),*) idec |         if(line(i0:i0).ne.' ') read(line(60:),*) idec | ||||||
|         if(idec.lt.0) cycle |         if(idec.lt.0) cycle | ||||||
|  |         if(idec.ge.12) then | ||||||
|  |            iavg=idec-10 | ||||||
|  |            idec=1 | ||||||
|  |         endif | ||||||
|         if(decok) then |         if(decok) then | ||||||
|            ndecn=ndecn + 1 |            ndecn=ndecn + 1 | ||||||
|            if(iavg.le.1) ndec1=ndec1 + 1 |            if(iavg.le.1) ndec1=ndec1 + 1 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user