mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-11-03 13:30:52 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			103 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
program rtty_spec
 | 
						|
 | 
						|
! Generate simulated data for standard RTTY and WSJT-X modes FT8, FT4
 | 
						|
 | 
						|
  use wavhdr
 | 
						|
  use packjt
 | 
						|
  parameter (NMAX=15*12000)
 | 
						|
  type(hdr) h
 | 
						|
  complex cwave(NMAX)
 | 
						|
  real wave(NMAX)
 | 
						|
  real*4 dat(NMAX)             !Generated waveform
 | 
						|
  integer*2 iwave(NMAX)        !Generated waveform
 | 
						|
  integer itone(680)           !Channel symbols (values 0-1, 0-3, 0-7)
 | 
						|
  integer*1 msgbits(77)
 | 
						|
  character*37 msg37,msgsent37
 | 
						|
  character*8 arg
 | 
						|
 | 
						|
  nargs=iargc()
 | 
						|
  if(nargs.ne.1) then
 | 
						|
     print*,'Usage:   rtty_spec <snr>'
 | 
						|
     go to 999
 | 
						|
  endif
 | 
						|
  call getarg(1,arg)
 | 
						|
  read(arg,*) snrdb                  !S/N in dB (2500 hz reference BW)
 | 
						|
 | 
						|
  rmsdb=25.
 | 
						|
  rms=10.0**(0.05*rmsdb)
 | 
						|
  sig=10.0**(0.05*snrdb)
 | 
						|
  npts=NMAX
 | 
						|
 | 
						|
  do i=1,NMAX                   !Generate gaussian noise
 | 
						|
     dat(i)=gran()
 | 
						|
  enddo
 | 
						|
 | 
						|
! Add the RTTY signal
 | 
						|
  fsample=12000.0                   !Sample rate (Hz)
 | 
						|
  dt=1.0/fsample                    !Sample interval (s)
 | 
						|
  twopi=8.0*atan(1.0)
 | 
						|
  phi=0.
 | 
						|
  dphi=0.
 | 
						|
  j0=-1
 | 
						|
  do i=6001,NMAX-6000
 | 
						|
     j=nint(i*dt/0.022)
 | 
						|
     if(j.ne.j0) then
 | 
						|
        f0=1415.0
 | 
						|
        call random_number(rr)
 | 
						|
        if(rr.gt.0.5) f0=1585.0
 | 
						|
        dphi=twopi*f0*dt
 | 
						|
        j0=j
 | 
						|
     endif
 | 
						|
     phi=phi+dphi
 | 
						|
     if(phi.gt.twopi) phi=phi-twopi
 | 
						|
     dat(i)=dat(i) + sig*sin(phi)
 | 
						|
  enddo
 | 
						|
 | 
						|
! FT8 signal (FSK)
 | 
						|
  i3=0
 | 
						|
  n3=0
 | 
						|
  msg37='WB9XYZ KA2ABC FN42'
 | 
						|
  call genft8(msg37,i3,n3,msgsent37,msgbits,itone)
 | 
						|
  nsym=79
 | 
						|
  nsps=1920
 | 
						|
  bt=99.0
 | 
						|
  f0=3500.0
 | 
						|
  icmplx=0
 | 
						|
  nwave=nsym*nsps
 | 
						|
  call gen_ft8wave(itone,nsym,nsps,bt,fsample,f0,cwave,wave,icmplx,nwave)
 | 
						|
  dat(6001:6000+nwave)=dat(6001:6000+nwave) + sig*wave(1:nwave)
 | 
						|
 | 
						|
! FT8 signal (GFSK)
 | 
						|
  i3=0
 | 
						|
  n3=0
 | 
						|
  msg37='WB9XYZ KA2ABC FN42'
 | 
						|
  call genft8(msg37,i3,n3,msgsent37,msgbits,itone)
 | 
						|
  nsym=79
 | 
						|
  nsps=1920
 | 
						|
  bt=2.0
 | 
						|
  f0=4000.0
 | 
						|
  icmplx=0
 | 
						|
  nwave=nsym*nsps
 | 
						|
  call gen_ft8wave(itone,nsym,nsps,bt,fsample,f0,cwave,wave,icmplx,nwave)
 | 
						|
  dat(6001:6000+nwave)=dat(6001:6000+nwave) + sig*wave(1:nwave)
 | 
						|
 | 
						|
! Add the FT4 signal
 | 
						|
  ichk=0
 | 
						|
  call genft4(msg37,ichk,msgsent37,msgbits,itone)
 | 
						|
  nsym=103
 | 
						|
  nsps=576
 | 
						|
  f0=4500.0
 | 
						|
  icmplx=0
 | 
						|
  nwave=(nsym+2)*nsps
 | 
						|
  call gen_ft4wave(itone,nsym,nsps,fsample,f0,cwave,wave,icmplx,nwave)
 | 
						|
  dat(6001:6000+nwave)=dat(6001:6000+nwave) + sig*wave(1:nwave)
 | 
						|
 | 
						|
  h=default_header(12000,NMAX)
 | 
						|
  datmax=maxval(abs(dat))
 | 
						|
  iwave=nint(32767.0*dat/datmax)
 | 
						|
  open(10,file='000000_000001.wav',access='stream',status='unknown')
 | 
						|
  write(10) h,iwave
 | 
						|
  close(10)
 | 
						|
 | 
						|
999 end program rtty_spec
 |