166 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
		
		
			
		
	
	
			166 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
|   | program fox_sim
 | ||
|  | 
 | ||
|  | ! Simulates QSO exchanges using the proposed FT8 "DXpedition" mode.
 | ||
|  |   parameter (MAXSIG=5,NCALLS=268)  
 | ||
|  |   character*6 xcall(NCALLS)
 | ||
|  |   character*4 xgrid(NCALLS)
 | ||
|  |   integer isnr(NCALLS)
 | ||
|  | 
 | ||
|  |   character*32 fmsg(MAXSIG),fm
 | ||
|  |   character*22 hmsg(MAXSIG),hm
 | ||
|  |   character*16 log
 | ||
|  |   character*6 called(MAXSIG)
 | ||
|  |   character*4 gcalled(MAXSIG)
 | ||
|  |   character*6 MyCall
 | ||
|  |   character*4 MyGrid
 | ||
|  |   character*8 arg
 | ||
|  |   character*1 c1,c2,c3,c4
 | ||
|  |   integer ntot(MAXSIG),irate(MAXSIG),ntimes(MAXSIG)
 | ||
|  |   logical logit
 | ||
|  |   common/dxpfifo/nc,isnr,xcall,xgrid
 | ||
|  |   
 | ||
|  |   nargs=iargc()
 | ||
|  |   if(nargs.ne.2 .and. nargs.ne.4) then
 | ||
|  |      print*,'Usage: fox_sim  nseq maxtimes'
 | ||
|  |      print*,'       fox_sim  nseq maxtimes nsig fail'
 | ||
|  |      print*,' '
 | ||
|  |      print*,' nseq:     number of T/R sequences to execute'
 | ||
|  |      print*,' maxtimes: number of repeats of same Tx message'
 | ||
|  |      print*,' nsig:     number of simultaneous Tx sigals'
 | ||
|  |      print*,' fail:     receiving error rate'
 | ||
|  |      go to 999
 | ||
|  |   endif
 | ||
|  |   ii1=1
 | ||
|  |   ii2=5
 | ||
|  |   jj1=0
 | ||
|  |   jj2=5
 | ||
|  |   nseq=80
 | ||
|  |   if(nargs.ge.2) then
 | ||
|  |      call getarg(1,arg)
 | ||
|  |      read(arg,*) nseq
 | ||
|  |      call getarg(2,arg)
 | ||
|  |      read(arg,*) maxtimes
 | ||
|  |   endif
 | ||
|  |   if(nargs.eq.4) then
 | ||
|  |      call getarg(3,arg)
 | ||
|  |      read(arg,*) nsig
 | ||
|  |      call getarg(4,arg)
 | ||
|  |      read(arg,*) fail
 | ||
|  |      ii1=nsig
 | ||
|  |      ii2=nsig
 | ||
|  |      jj1=nint(10*fail)
 | ||
|  |      jj2=nint(10*fail)
 | ||
|  |   endif
 | ||
|  | 
 | ||
|  | ! Read a file with calls and grids; insert random S/N values.
 | ||
|  | ! This is used in place of an operator-selected FIFO
 | ||
|  |   open(10,file='xcall.txt',status='old')
 | ||
|  |   do i=1,NCALLS
 | ||
|  |      read(10,1000) xcall(i),xgrid(i)
 | ||
|  | 1000 format(a6,7x,a4)
 | ||
|  |      if(i.ne.-99) cycle
 | ||
|  |      j=mod(i-1,26)
 | ||
|  |      c1=char(ichar('A')+j)
 | ||
|  |      k=mod((i-1)/26,26)
 | ||
|  |      c2=char(ichar('A')+k)     
 | ||
|  |      n=mod((i-1)/260,10)
 | ||
|  |      c3=char(ichar('0')+n)     
 | ||
|  |      xcall(i)='K'//c2//c3//c1//c1//c1
 | ||
|  | 
 | ||
|  |      j=mod(i-1,18)
 | ||
|  |      c1=char(ichar('A')+j)
 | ||
|  |      k=mod((i-1)/18,18)
 | ||
|  |      c2=char(ichar('A')+k)     
 | ||
|  |      n=mod((i-1)/10,10)
 | ||
|  |      c4=char(ichar('0')+n)     
 | ||
|  |      n=mod((i-1)/100,10)
 | ||
|  |      c3=char(ichar('0')+n)     
 | ||
|  |      xgrid(i)=c1//c2//c3//c4
 | ||
|  |      
 | ||
|  |      call random_number(x)
 | ||
|  |      isnr(i)=-20+int(40*x)
 | ||
|  |   enddo
 | ||
|  | !  close(10)
 | ||
|  | 
 | ||
|  | ! Write headings for the summary file
 | ||
|  |   minutes=nseq/4
 | ||
|  |   write(13,1002) nseq,minutes,maxtimes
 | ||
|  | 1002 format(/'Nseq:',i4,'   Minutes:',i3,'   Maxtimes:',i2//                   &
 | ||
|  |     18x,'Logged QSOs',22x,'Rate (QSOs/hour)'/                                  &
 | ||
|  |     'fail Nsig: 1     2     3     4     5          1     2     3     4     5'/ &
 | ||
|  |     71('-'))
 | ||
|  | 
 | ||
|  |   write(*,1003)
 | ||
|  | 1003 format('Seq  s n Fox messages                      Hound messages    Logged info        i Rate'/87('-'))
 | ||
|  | 
 | ||
|  |   ntot=0
 | ||
|  |   irate=0
 | ||
|  |   MyCall='KH1DX'
 | ||
|  |   MyGrid='AJ10'
 | ||
|  | 
 | ||
|  |   do jj=jj1,jj2                        !Loop over Rx failure rates
 | ||
|  |      fail=0.1*jj    
 | ||
|  |      do ii=ii1,ii2                     !Loop over range of nsig
 | ||
|  |         nc=0                           !Set FIFO pointer to top
 | ||
|  |         ntimes=1
 | ||
|  |         nsig=ii
 | ||
|  |         nlogged=0
 | ||
|  |         fmsg="CQ KH1DX AJ10"
 | ||
|  |         hmsg=""
 | ||
|  |         called="      "
 | ||
|  |         do iseq=0,nseq                 !Loop over specified number of sequences
 | ||
|  |            if(iand(iseq,1).eq.0) then
 | ||
|  |               do j=1,nsig              !Loop over Fox's Tx slots
 | ||
|  |                  fm=fmsg(j)
 | ||
|  |                  hm=hmsg(j)
 | ||
|  | 
 | ||
|  | ! Call fox_tx to determine the next Tx message for this slot
 | ||
|  |                  call fox_tx(maxtimes,fail,called(j),gcalled(j),hm,fm,    &
 | ||
|  |                       ntimes(j),log,logit)
 | ||
|  | 
 | ||
|  |                  fmsg(j)=fm
 | ||
|  |                  if(logit) then
 | ||
|  | ! Log this QSO
 | ||
|  |                     nlogged=nlogged+1
 | ||
|  |                     nrate=0
 | ||
|  |                     if(iseq.gt.0) nrate=nint(nlogged*240.0/iseq)
 | ||
|  |                     write(*,1010) iseq,j,ntimes(j),fmsg(j),log,nlogged,nrate
 | ||
|  | 1010                format(i4.4,2i2,1x,a32,20x,a16,2i4)
 | ||
|  |                     ! call log_routine()
 | ||
|  |                  else
 | ||
|  |                     write(*,1010) iseq,j,ntimes(j),fmsg(j)
 | ||
|  |                  endif
 | ||
|  |               enddo
 | ||
|  |               ! call transmit()
 | ||
|  |            endif
 | ||
|  |            
 | ||
|  |            if(iand(iseq,1).eq.1) then
 | ||
|  |               do j=1,nsig              !Listen for expected responses
 | ||
|  |                  fm=fmsg(j)
 | ||
|  |                  call fox_rx(fail,called(j),fm,hm)
 | ||
|  |                  if(j.ge.2) then
 | ||
|  |                     if(hm.eq.hmsg(j-1)) hm=""
 | ||
|  |                  endif
 | ||
|  |                  hmsg(j)=hm
 | ||
|  |                  write(*,1020) iseq,j,hmsg(j)
 | ||
|  | 1020             format(i4.4,i2,37x,a22)
 | ||
|  |               enddo
 | ||
|  |            endif
 | ||
|  |            write(*,1021)
 | ||
|  | 1021       format(87('-'))
 | ||
|  |         enddo
 | ||
|  |         ntot(ii)=nlogged
 | ||
|  |         irate(ii)=0
 | ||
|  |         if(iseq.gt.0) irate(ii)=nint(nlogged*3600.0/(15*iseq))
 | ||
|  |         write(*,1030) nsig,fail,nlogged,nc
 | ||
|  | 1030    format(/'Nsig:',i3,'   Fail:',f4.1,'   Logged QSOs:',i4,      &
 | ||
|  |              '   Final nc:',i4)
 | ||
|  |      enddo
 | ||
|  |      
 | ||
|  | ! Write the summary file
 | ||
|  |      write(13,1100) fail,ntot,irate
 | ||
|  | 1100 format(f4.1,2x,5i6,5x,5i6)
 | ||
|  |   enddo
 | ||
|  | 
 | ||
|  | 999 end program fox_sim
 |