mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-31 13:10:19 -04:00 
			
		
		
		
	git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@8233 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
		
			
				
	
	
		
			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
 |