mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-30 20:40:28 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			523 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
			
		
		
	
	
			523 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
| module jt65_decode
 | |
| 
 | |
|   integer, parameter :: NSZ=3413, NZMAX=60*12000
 | |
| 
 | |
|   type :: jt65_decoder
 | |
|      procedure(jt65_decode_callback), pointer :: callback => null()
 | |
|    contains
 | |
|      procedure :: decode
 | |
|   end type jt65_decoder
 | |
| 
 | |
| ! Callback function to be called with each decode
 | |
|   abstract interface
 | |
|      subroutine jt65_decode_callback(this,sync,snr,dt,freq,drift,     &
 | |
|           nflip,width,decoded,ft,qual,nsmo,nsum,minsync)
 | |
| 
 | |
|        import jt65_decoder
 | |
|        implicit none
 | |
|        class(jt65_decoder), intent(inout) :: this
 | |
|        real, intent(in) :: sync
 | |
|        integer, intent(in) :: snr
 | |
|        real, intent(in) :: dt
 | |
|        integer, intent(in) :: freq
 | |
|        integer, intent(in) :: drift
 | |
|        integer, intent(in) :: nflip
 | |
|        real, intent(in) :: width
 | |
|        character(len=22), intent(in) :: decoded
 | |
|        integer, intent(in) :: ft
 | |
|        integer, intent(in) :: qual
 | |
|        integer, intent(in) :: nsmo
 | |
|        integer, intent(in) :: nsum
 | |
|        integer, intent(in) :: minsync
 | |
| 
 | |
|      end subroutine jt65_decode_callback
 | |
|   end interface
 | |
| 
 | |
| contains
 | |
| 
 | |
|   subroutine decode(this,callback,dd0,npts,newdat,nutc,nf1,nf2,nfqso,     &
 | |
|        ntol,nsubmode,minsync,nagain,n2pass,nrobust,ntrials,naggressive,   &
 | |
|        ndepth,emedelay,clearave,mycall,hiscall,hisgrid,nexp_decode,       &
 | |
|        nQSOProgress,ljt65apon)
 | |
| 
 | |
| !  Process dd0() data to find and decode JT65 signals.
 | |
| 
 | |
|     use jt65_mod
 | |
|     use timer_module, only: timer
 | |
| 
 | |
|     include 'constants.f90'
 | |
| 
 | |
|     class(jt65_decoder), intent(inout) :: this
 | |
|     procedure(jt65_decode_callback) :: callback
 | |
|     real, intent(in) :: dd0(NZMAX),emedelay
 | |
|     integer, intent(in) :: npts, nutc, nf1, nf2, nfqso, ntol     &
 | |
|          , nsubmode, minsync, n2pass, ntrials, naggressive, ndepth      &
 | |
|          , nexp_decode, nQSOProgress
 | |
|     logical, intent(in) :: newdat, nagain, nrobust, clearave, ljt65apon
 | |
|     character(len=12), intent(in) :: mycall, hiscall
 | |
|     character(len=6), intent(in) :: hisgrid
 | |
| 
 | |
|     real dd(NZMAX)
 | |
|     real ss(552,NSZ)
 | |
|     real savg(NSZ)
 | |
|     real a(5)
 | |
|     character*22 decoded,decoded0,avemsg,deepave
 | |
|     type candidate
 | |
|        real freq
 | |
|        real dt
 | |
|        real sync
 | |
|        real flip
 | |
|     end type candidate
 | |
|     type(candidate) ca(300)
 | |
|     type accepted_decode
 | |
|        real freq
 | |
|        real dt
 | |
|        real sync
 | |
|        character*22 decoded
 | |
|     end type accepted_decode
 | |
|     type(accepted_decode) dec(50)
 | |
|     logical :: first_time,prtavg,single_decode,bVHF,clear_avg65
 | |
| 
 | |
|     integer h0(0:11),d0(0:11)
 | |
|     real r0(0:11)
 | |
|     common/decstats/ntry65a,ntry65b,n65a,n65b,num9,numfano
 | |
|     common/steve/thresh0
 | |
|     common/sync/ss
 | |
| 
 | |
| !            0  1  2  3  4  5  6  7  8  9 10 11
 | |
|     data h0/41,42,43,43,44,45,46,47,48,48,49,49/
 | |
|     data d0/71,72,73,74,76,77,78,80,81,82,83,83/
 | |
| 
 | |
| !             0    1    2    3    4    5    6    7    8    9   10   11
 | |
|     data r0/0.70,0.72,0.74,0.76,0.78,0.80,0.82,0.84,0.86,0.88,0.90,0.90/
 | |
|     data nutc0/-999/,nfreq0/-999/,nsave/0/,clear_avg65/.true./
 | |
|     save
 | |
| 
 | |
|     this%callback => callback
 | |
|     first_time=nrobust .and. (emedelay.eq.-999.9)    !Silence compiler warning
 | |
|     first_time=newdat
 | |
|     dd=dd0
 | |
|     ndecoded=0
 | |
|     ndecoded0=0
 | |
|     single_decode=iand(nexp_decode,32).ne.0 .or. nagain
 | |
|     bVHF=iand(nexp_decode,64).ne.0
 | |
| 
 | |
|     if(bVHF) then
 | |
|       nvec=ntrials
 | |
|       npass=1
 | |
|       if(n2pass.gt.1) npass=2
 | |
|     else
 | |
|       nvec=1000
 | |
|       if(ndepth.eq.1) then
 | |
|          npass=2
 | |
|          nvec=100
 | |
|       elseif(ndepth.eq.2) then
 | |
|          npass=2
 | |
|          nvec=1000
 | |
|       else 
 | |
|          npass=4
 | |
|          nvec=1000
 | |
|       endif
 | |
|     endif
 | |
|     do ipass=1,npass 
 | |
|        first_time=.true.
 | |
|        if(ipass.eq.1) then                        !First-pass parameters
 | |
|           thresh0=2.5
 | |
|           nsubtract=1
 | |
|           nrob=0
 | |
|        elseif( ipass.eq.2 ) then                  !Second-pass parameters
 | |
|           thresh0=2.0
 | |
|           nsubtract=1
 | |
|           nrob=0
 | |
|        elseif( ipass.eq.3 ) then 
 | |
|           thresh0=2.0
 | |
|           nsubtract=1
 | |
|           nrob=0
 | |
|        elseif( ipass.eq.4 ) then 
 | |
|           thresh0=2.0
 | |
|           nsubtract=0
 | |
|           nrob=1
 | |
|        endif
 | |
|        if(npass.eq.1) then
 | |
|          nsubtract=0
 | |
|          thresh0=2.0
 | |
|        endif
 | |
| 
 | |
|        call timer('symsp65 ',0)
 | |
|        ss=0.
 | |
|        call symspec65(dd,npts,nqsym,savg)    !Get normalized symbol spectra
 | |
|        call timer('symsp65 ',1)
 | |
|        nfa=nf1
 | |
|        nfb=nf2
 | |
| 
 | |
| !### Q: should either of the next two uses of "single_decode" be "bVHF" instead?       
 | |
|        if(single_decode .or. (bVHF .and. ntol.lt.1000)) then
 | |
|           nfa=max(200,nfqso-ntol)
 | |
|           nfb=min(4000,nfqso+ntol)
 | |
|           thresh0=1.0
 | |
|        endif
 | |
|        df=12000.0/8192.0                     !df = 1.465 Hz
 | |
|        if(bVHF) then
 | |
|           ia=max(1,nint((nfa-100)/df))
 | |
|           ib=min(NSZ,nint((nfb+100)/df))
 | |
|           nz=ib-ia+1
 | |
|           if(nz.lt.50) go to 900
 | |
|           if(isnan(sum(savg(ia:ia+nz-1)))) go to 900
 | |
|           call lorentzian(savg(ia),nz,a)
 | |
|           baseline=a(1)
 | |
|           amp=a(2)
 | |
|           f0=(a(3)+ia-1)*df
 | |
|           width=a(4)*df
 | |
|        endif
 | |
| 
 | |
|        ncand=0
 | |
|        call timer('sync65  ',0)
 | |
|        call sync65(nfa,nfb,ntol,nqsym,ca,ncand,nrob,bVHF)
 | |
|        ncand=min(ncand,50/ipass)
 | |
|        call timer('sync65  ',1)
 | |
| 
 | |
|        mode65=2**nsubmode
 | |
|        nflip=1
 | |
|        nqd=0
 | |
|        decoded='                      '
 | |
|        decoded0=""
 | |
|        freq0=0.
 | |
|        prtavg=.false.
 | |
|        if(.not.nagain) nsum=0
 | |
|        if(clearave) then
 | |
|           nsum=0
 | |
|           nsave=0
 | |
|           clear_avg65=.true.
 | |
|        endif
 | |
| 
 | |
|        if(bVHF) then
 | |
| ! Be sure to search for shorthand message at nfqso +/- ntol
 | |
|           if(ncand.lt.300) ncand=ncand+1
 | |
|           ca(ncand)%sync=5.0
 | |
|           ca(ncand)%dt=2.5
 | |
|           ca(ncand)%freq=nfqso
 | |
|           ca(ncand)%flip=0
 | |
|        endif
 | |
|        do icand=1,ncand
 | |
|           sync1=ca(icand)%sync
 | |
|           dtx=ca(icand)%dt
 | |
|           freq=ca(icand)%freq
 | |
|           if(bVHF) then
 | |
|              flip=ca(icand)%flip
 | |
|              nflip=int(flip)
 | |
|           endif
 | |
|           if(sync1.lt.float(minsync)) nflip=0
 | |
|           if(ipass.eq.1) ntry65a=ntry65a + 1
 | |
|           if(ipass.eq.2) ntry65b=ntry65b + 1
 | |
|           call timer('decod65a',0)
 | |
|           nft=0
 | |
|           nspecial=0
 | |
|           call decode65a(dd,npts,first_time,nqd,freq,nflip,mode65,nvec,     &
 | |
|                naggressive,ndepth,ntol,mycall,hiscall,hisgrid,nQSOProgress, &
 | |
|                ljt65apon,bVHF,sync2,a,dtx,nft,nspecial,qual,                &
 | |
|                nhist,nsmo,decoded)
 | |
|           call timer('decod65a',1)
 | |
| 
 | |
|           if(.not.bVHF) then   
 | |
|              if(abs(a(1)).gt.10.0/ipass) cycle
 | |
|              ibad=0
 | |
|              if(abs(a(1)).gt.5.0) ibad=1
 | |
|              if(abs(a(2)).gt.2.0) ibad=ibad+1
 | |
|              if(abs(dtx-1.0).gt.2.5) ibad=ibad+1
 | |
|              if(ibad.ge.2) cycle
 | |
|           endif
 | |
|           
 | |
|           if(nspecial.eq.0 .and. sync1.eq.5.0 .and. dtx.eq.2.5) cycle
 | |
|           if(nspecial.eq.2) decoded='RO'
 | |
|           if(nspecial.eq.3) decoded='RRR'
 | |
|           if(nspecial.eq.4) decoded='73'
 | |
|           if(sync1.lt.float(minsync) .and.                                  &
 | |
|                decoded.eq.'                      ') nflip=0
 | |
|           if(nft.ne.0) nsum=1
 | |
|           
 | |
|           nhard_min=param(1)
 | |
|           nrtt1000=param(4)
 | |
|           ntotal_min=param(5)
 | |
|           nsmo=param(9)
 | |
|           
 | |
|           nfreq=nint(freq+a(1))
 | |
|           ndrift=nint(2.0*a(2))
 | |
|           if(bVHF) then
 | |
|             xtmp=10**((sync1+16.0)/10.0) ! sync comes to us in dB
 | |
|             s2db=1.1*db(xtmp)+1.4*(dB(width)-4.3)-52.0 
 | |
| !             s2db=sync1 - 30.0 + db(width/3.3)       !### VHF/UHF/microwave
 | |
|              if(nspecial.gt.0) s2db=sync2
 | |
|           else
 | |
|              s2db=10.0*log10(sync2) - 35             !### Empirical (HF) 
 | |
|           endif
 | |
|           nsnr=nint(s2db)
 | |
|           if(nsnr.lt.-30) nsnr=-30
 | |
|           if(nsnr.gt.-1) nsnr=-1
 | |
|           nftt=0
 | |
| !********* DOES THIS STILL WORK WHEN NFT INCLUDES # OF AP SYMBOLS USED??
 | |
|           if(nft.ne.1 .and. iand(ndepth,16).eq.16 .and.                    &
 | |
|                sync1.ge.float(minsync) .and. (.not.prtavg)) then
 | |
| ! Single-sequence FT decode failed, so try for an average FT decode.
 | |
|              if(nutc.ne.nutc0 .or. abs(nfreq-nfreq0).gt.ntol) then
 | |
| ! This is a new minute or a new frequency, so call avg65.
 | |
|                 nutc0=nutc
 | |
|                 nfreq0=nfreq
 | |
|                 nsave=nsave+1
 | |
|                 nsave=mod(nsave-1,64)+1
 | |
|                 call avg65(nutc,nsave,sync1,dtx,nflip,nfreq,mode65,ntol,     &
 | |
|                      ndepth,nagain,ntrials,naggressive,clear_avg65,neme,     &
 | |
|                      mycall,hiscall,hisgrid,nftt,avemsg,qave,deepave,nsum,   &
 | |
|                      ndeepave,nQSOProgress,ljt65apon)
 | |
|                 nsmo=param(9)
 | |
|                 nqave=int(qave)
 | |
| 
 | |
|                 if (associated(this%callback) .and.nftt.ge.1 .and. nsum.ge.2) then
 | |
| ! Display a decoded message obtained by averaging 2 or more transmissions
 | |
|                    call this%callback(sync1,nsnr,dtx-1.0,nfreq,ndrift,  &
 | |
|                         nflip,width,avemsg,nftt,nqave,nsmo,nsum,minsync)
 | |
|                    prtavg=.true.
 | |
|                 end if
 | |
| 
 | |
|              endif
 | |
|           endif
 | |
| 
 | |
|           if(nftt.eq.0) go to 5
 | |
| !          if(nftt.eq.1) then
 | |
| !!             nft=1
 | |
| !             decoded=avemsg
 | |
| !             go to 5
 | |
| !          endif
 | |
|           n=naggressive
 | |
|           rtt=0.001*nrtt1000
 | |
|           if(nft.lt.2 .and. minsync.ge.0 .and. nspecial.eq.0 .and. .not.bVHF) then
 | |
|              if(nhard_min.gt.50) cycle
 | |
|              if(nhard_min.gt.h0(n)) cycle
 | |
|              if(ntotal_min.gt.d0(n)) cycle
 | |
|              if(rtt.gt.r0(n)) cycle
 | |
|           endif
 | |
| 
 | |
| 5         continue
 | |
|           if(decoded.eq.decoded0 .and. abs(freq-freq0).lt. 3.0 .and.    &
 | |
|                minsync.ge.0) cycle                  !Don't display dupes
 | |
| !          if(decoded.ne.'                      ' .or. minsync.lt.0) then
 | |
|           if(decoded.ne.'                      ' .or. bVHF) then
 | |
|              if(nsubtract.eq.1) then
 | |
|                 call timer('subtr65 ',0)
 | |
|                 call subtract65(dd,npts,freq,dtx)
 | |
|                 call timer('subtr65 ',1)
 | |
|              endif
 | |
| 
 | |
|              ndupe=0 ! de-dedupe
 | |
|              do i=1, ndecoded
 | |
|                 if(decoded==dec(i)%decoded) then
 | |
|                    ndupe=1
 | |
|                    exit
 | |
|                 endif
 | |
|              enddo
 | |
|              if(ndupe.ne.1 .and. ((sync1.ge.float(minsync)) .or. bVHF)) then
 | |
|                 if(ipass.eq.1) n65a=n65a + 1
 | |
|                 if(ipass.eq.2) n65b=n65b + 1
 | |
|                 if(ndecoded.lt.50) ndecoded=ndecoded+1
 | |
|                 dec(ndecoded)%freq=freq+a(1)
 | |
|                 dec(ndecoded)%dt=dtx
 | |
|                 dec(ndecoded)%sync=sync2
 | |
|                 dec(ndecoded)%decoded=decoded
 | |
|                 nqual=min(int(qual),9999)
 | |
| 
 | |
|                 if(associated(this%callback)) then
 | |
|                    call this%callback(sync1,nsnr,dtx-1.0,nfreq,ndrift,  &
 | |
|                         nflip,width,decoded,nft,nqual,nsmo,1,minsync)
 | |
|                 end if
 | |
|              endif
 | |
|              decoded0=decoded
 | |
|              freq0=freq
 | |
|              if(decoded0.eq.'                      ') decoded0='*'
 | |
|              if(single_decode .and. ndecoded.gt.0) go to 900
 | |
|           endif
 | |
|        enddo   ! icand
 | |
|        if(ipass.gt.1 .and. ndecoded.eq.ndecoded0) exit
 | |
|        ndecoded0=ndecoded
 | |
|     enddo   ! ipass
 | |
| 900 return
 | |
|   end subroutine decode
 | |
| 
 | |
|   subroutine avg65(nutc,nsave,snrsync,dtxx,nflip,nfreq,mode65,ntol,ndepth,    &
 | |
|        nagain, ntrials,naggressive,clear_avg65,neme,mycall,hiscall,hisgrid,   &
 | |
|        nftt,avemsg,qave,deepave,nsum,ndeepave,nQSOProgress,ljt65apon)
 | |
| 
 | |
| ! Decodes averaged JT65 data
 | |
| 
 | |
|     use jt65_mod
 | |
|     parameter (MAXAVE=64)
 | |
|     character*22 avemsg,deepave,deepbest
 | |
|     character mycall*12,hiscall*12,hisgrid*6
 | |
|     character*1 csync,cused(64)
 | |
|     logical nagain
 | |
|     integer iused(64)
 | |
| ! Accumulated data for message averaging
 | |
|     integer iutc(MAXAVE)
 | |
|     integer nfsave(MAXAVE)
 | |
|     integer nflipsave(MAXAVE)
 | |
|     real s1b(-255:256,126)
 | |
|     real s1save(-255:256,126,MAXAVE)
 | |
|     real s2(66,126)
 | |
|     real s3save(64,63,MAXAVE)
 | |
|     real s3b(64,63)
 | |
|     real s3c(64,63)
 | |
|     real dtsave(MAXAVE)
 | |
|     real syncsave(MAXAVE)
 | |
|     logical first,clear_avg65,ljt65apon
 | |
|     data first/.true./
 | |
|     save
 | |
| 
 | |
|     if(first .or. clear_avg65) then
 | |
|        iutc=-1
 | |
|        nfsave=0
 | |
|        dtdiff=0.2
 | |
|        s3save=0.
 | |
|        s1save=0.
 | |
|        nsave=1           !### ???
 | |
| ! Silence compiler warnings
 | |
|        if(nagain .and. ndeepave.eq.-99 .and. neme.eq.-99) stop
 | |
|        first=.false.
 | |
|        clear_avg65=.false.
 | |
|     endif
 | |
| 
 | |
|     do i=1,64
 | |
|        if(iutc(i).lt.0) exit
 | |
|        if(nutc.eq.iutc(i) .and. abs(nfreq-nfsave(i)).le.ntol) go to 10
 | |
|     enddo
 | |
| 
 | |
| ! Save data for message averaging
 | |
|     iutc(nsave)=nutc
 | |
|     syncsave(nsave)=snrsync
 | |
|     dtsave(nsave)=dtxx
 | |
|     nfsave(nsave)=nfreq
 | |
|     nflipsave(nsave)=nflip
 | |
|     s1save(-255:256,1:126,nsave)=s1
 | |
|     s3save(1:64,1:63,nsave)=s3a
 | |
|     avemsg='                      '
 | |
|     deepbest='                      '
 | |
|     nfttbest=0
 | |
|     
 | |
| 10  syncsum=0.
 | |
|     dtsum=0.
 | |
|     nfsum=0
 | |
|     nsum=0
 | |
|     s1b=0.
 | |
|     s3b=0.
 | |
|     s3c=0.
 | |
| 
 | |
|     do i=1,MAXAVE                               !Consider all saved spectra
 | |
|        cused(i)='.'
 | |
|        if(iutc(i).lt.0) exit
 | |
|        if(mod(iutc(i),2).ne.mod(nutc,2)) cycle  !Use only same (odd/even) seq
 | |
|        if(abs(dtxx-dtsave(i)).gt.dtdiff) cycle  !DT must match
 | |
|        if(abs(nfreq-nfsave(i)).gt.ntol) cycle   !Freq must match
 | |
|        if(nflipsave(i).eq.0) cycle              !No sync
 | |
|        if(nflip.ne.nflipsave(i)) cycle          !Sync type (*/#) must match
 | |
| 
 | |
|        s3b=s3b + s3save(1:64,1:63,i)
 | |
|        s1b=s1b + s1save(-255:256,1:126,i)
 | |
|        syncsum=syncsum + syncsave(i)
 | |
|        dtsum=dtsum + dtsave(i)
 | |
|        nfsum=nfsum + nfsave(i)
 | |
|        cused(i)='$'
 | |
|        nsum=nsum+1
 | |
|        iused(nsum)=i
 | |
|     enddo
 | |
|     if(nsum.lt.64) iused(nsum+1)=0
 | |
| 
 | |
|     syncave=0.
 | |
|     dtave=0.
 | |
|     fave=0.
 | |
|     if(nsum.gt.0) then
 | |
|        syncave=syncsum/nsum
 | |
|        dtave=dtsum/nsum
 | |
|        fave=float(nfsum)/nsum
 | |
|     endif
 | |
| 
 | |
|     do i=1,nsave
 | |
|        csync=' '
 | |
|        if(nflipsave(i).lt.0.0) csync='#'
 | |
|        if(nflipsave(i).gt.0.0) csync='*'
 | |
|        write(14,1000) cused(i),iutc(i),syncsave(i),dtsave(i)-1.0,nfsave(i),csync
 | |
| 1000   format(a1,i5.4,f6.1,f6.2,i6,1x,a1)
 | |
|     enddo
 | |
|     if(nsum.lt.2) go to 900
 | |
| 
 | |
|     df=1378.125/512.0
 | |
| 
 | |
| ! Do the smoothing loop
 | |
|     qualbest=0.
 | |
|     minsmo=0
 | |
|     maxsmo=0
 | |
|     if(mode65.ge.2) then
 | |
|        minsmo=nint(width/df)
 | |
|        maxsmo=2*minsmo
 | |
|     endif
 | |
|     nn=0
 | |
|     do ismo=minsmo,maxsmo
 | |
|        nftt=0
 | |
|        if(ismo.gt.0) then
 | |
|           do j=1,126
 | |
|              call smo121(s1b(-255,j),512)
 | |
|              if(j.eq.1) nn=nn+1
 | |
|              if(nn.ge.4) then
 | |
|                 call smo121(s1b(-255,j),512)
 | |
|                 if(j.eq.1) nn=nn+1
 | |
|              endif
 | |
|           enddo
 | |
|        endif
 | |
| 
 | |
|        do i=1,66
 | |
|           jj=i
 | |
|           if(mode65.eq.2) jj=2*i-1
 | |
|           if(mode65.eq.4) then
 | |
|              ff=4*(i-1)*df - 355.297852
 | |
|              jj=nint(ff/df)+1
 | |
|           endif
 | |
|           s2(i,1:126)=s1b(jj,1:126)
 | |
|        enddo
 | |
| 
 | |
|        do j=1,63
 | |
|           k=mdat(j)                       !Points to data symbol
 | |
|           if(nflip.lt.0) k=mdat2(j)
 | |
|           do i=1,64
 | |
|              s3c(i,j)=4.e-5*s2(i+2,k)
 | |
|           enddo
 | |
|        enddo
 | |
| 
 | |
|        nadd=nsum*ismo
 | |
|        call extract(s3c,nadd,mode65,ntrials,naggressive,ndepth,nflip,mycall, &
 | |
|             hiscall,hisgrid,nQSOProgress,ljt65apon,ncount,nhist, &
 | |
|             avemsg,ltext,nftt,qual)
 | |
|        if(nftt.eq.1) then
 | |
|           nsmo=ismo
 | |
|           param(9)=nsmo
 | |
|           go to 900
 | |
|        else if(nftt.ge.2) then
 | |
|           if(qual.gt.qualbest) then
 | |
|              deepbest=avemsg
 | |
|              qualbest=qual
 | |
|              nnbest=nn
 | |
|              nsmobest=ismo
 | |
|              nfttbest=nftt
 | |
|           endif
 | |
|        endif
 | |
|     enddo
 | |
|     if(nfttbest.eq.2) then
 | |
|        avemsg=deepbest       !### ???
 | |
|        deepave=deepbest
 | |
|        qave=qualbest
 | |
|        nsmo=nsmobest
 | |
|        param(9)=nsmo
 | |
|        nftt=nfttbest
 | |
|     endif
 | |
| 900 continue
 | |
|     
 | |
|     return
 | |
|   end subroutine avg65
 | |
| 
 | |
| end module jt65_decode
 |