| 
									
										
										
										
											2014-01-17 14:46:23 +00:00
										 |  |  | subroutine symspec(k,ntrperiod,nsps,ingain,nflatten,pxdb,s,df3,ihsym,npts8)
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-01 19:05:22 +00:00
										 |  |  | ! Input:
 | 
					
						
							|  |  |  | !  k         pointer to the most recent new data
 | 
					
						
							|  |  |  | !  ntrperiod T/R sequence length, minutes
 | 
					
						
							| 
									
										
										
										
											2013-04-22 15:43:02 +00:00
										 |  |  | !  nsps      samples per symbol, at 12000 Hz
 | 
					
						
							| 
									
										
										
										
											2012-10-01 19:05:22 +00:00
										 |  |  | !  ndiskdat  0/1 to indicate if data from disk
 | 
					
						
							|  |  |  | !  nb        0/1 status of noise blanker (off/on)
 | 
					
						
							|  |  |  | !  nbslider  NB setting, 0-100
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Output:
 | 
					
						
							|  |  |  | !  pxdb      power (0-60 dB)
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  | !  s()       current spectrum for waterfall display
 | 
					
						
							| 
									
										
										
										
											2013-04-22 15:43:02 +00:00
										 |  |  | !  ihsym     index number of this half-symbol (1-184)
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  | ! jt9com
 | 
					
						
							|  |  |  | !  ss()      JT9 symbol spectra at half-symbol steps
 | 
					
						
							|  |  |  | !  savg()    average spectra for waterfall display
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   include 'constants.f90'
 | 
					
						
							|  |  |  |   real*4 w3(MAXFFT3)
 | 
					
						
							|  |  |  |   real*4 s(NSMAX)
 | 
					
						
							| 
									
										
										
										
											2012-10-11 18:33:50 +00:00
										 |  |  |   real*4 ssum(NSMAX)
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   real*4 xc(0:MAXFFT3-1)
 | 
					
						
							| 
									
										
										
										
											2014-03-05 18:20:40 +00:00
										 |  |  |   real*4 tmp(NSMAX)
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   complex cx(0:MAXFFT3/2)
 | 
					
						
							| 
									
										
										
										
											2012-10-01 19:05:22 +00:00
										 |  |  |   integer*2 id2
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   common/jt9com/ss(184,NSMAX),savg(NSMAX),id2(NMAX),nutc,ndiskdat,         &
 | 
					
						
							| 
									
										
										
										
											2014-01-08 20:55:11 +00:00
										 |  |  |        ntr,mousefqso,newdat,npts8a,nfa,nfsplit,nfb,ntol,kin,nzhsym,         &
 | 
					
						
							|  |  |  |        nsave,nagain,ndepth,ntxmode,nmode,junk(5)
 | 
					
						
							| 
									
										
										
										
											2014-03-05 18:20:40 +00:00
										 |  |  |   common/jt9w/syellow(NSMAX)
 | 
					
						
							| 
									
										
										
										
											2014-01-17 14:46:23 +00:00
										 |  |  |   data rms/999.0/,k0/99999999/,nfft3z/0/
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   equivalence (xc,cx)
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  |   save
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   if(ntrperiod.eq.-999) stop                   !Silence compiler warning
 | 
					
						
							|  |  |  |   nfft3=16384                                  !df=12000.0/16384 = 0.732422
 | 
					
						
							|  |  |  |   jstep=nsps/2                                 !Step size = half-symbol in id2()
 | 
					
						
							|  |  |  |   if(k.gt.NMAX) go to 900
 | 
					
						
							|  |  |  |   if(k.lt.2048) then                !(2048 was nfft3)  (Any need for this ???)
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  |      ihsym=0
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |      go to 900                                 !Wait for enough samples to start
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  |   endif
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-17 14:46:23 +00:00
										 |  |  |   if(nfft3.ne.nfft3z) then
 | 
					
						
							|  |  |  | ! Compute new window
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  |      pi=4.0*atan(1.0)
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |      do i=1,nfft3
 | 
					
						
							|  |  |  |         w3(i)=2.0*(sin(i*pi/nfft3))**2         !Window for nfft3 spectrum
 | 
					
						
							|  |  |  |      enddo
 | 
					
						
							| 
									
										
										
										
											2012-10-01 19:05:22 +00:00
										 |  |  |      nfft3z=nfft3
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  |   endif
 | 
					
						
							| 
									
										
										
										
											2012-10-01 00:02:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-22 15:43:02 +00:00
										 |  |  |   if(k.lt.k0) then                             !Start a new data block
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:06:31 +00:00
										 |  |  |      ja=0
 | 
					
						
							| 
									
										
										
										
											2012-10-11 18:33:50 +00:00
										 |  |  |      ssum=0.
 | 
					
						
							| 
									
										
										
										
											2012-06-04 17:02:50 +00:00
										 |  |  |      ihsym=0
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |      if(ndiskdat.eq.0) id2(k+1:)=0   !Needed to prevent "ghosts". Not sure why.
 | 
					
						
							| 
									
										
										
										
											2012-06-04 17:02:50 +00:00
										 |  |  |   endif
 | 
					
						
							| 
									
										
										
										
											2014-01-17 14:56:11 +00:00
										 |  |  |   gain=10.0**(0.1*ingain)
 | 
					
						
							| 
									
										
										
										
											2013-05-16 23:52:04 +00:00
										 |  |  |   sq=0.
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   do i=k0+1,k
 | 
					
						
							|  |  |  |      x1=id2(i)
 | 
					
						
							|  |  |  |      sq=sq + x1*x1
 | 
					
						
							| 
									
										
										
										
											2012-10-01 19:05:22 +00:00
										 |  |  |   enddo
 | 
					
						
							| 
									
										
										
										
											2014-01-17 14:56:11 +00:00
										 |  |  |   sq=sq * gain
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   rms=sqrt(sq/(k-k0))
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  |   pxdb=0.
 | 
					
						
							| 
									
										
										
										
											2012-10-04 19:03:39 +00:00
										 |  |  |   if(rms.gt.0.0) pxdb=20.0*log10(rms)
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  |   if(pxdb.gt.60.0) pxdb=60.0
 | 
					
						
							| 
									
										
										
										
											2012-10-04 02:05:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   k0=k
 | 
					
						
							|  |  |  |   ja=ja+jstep                         !Index of first sample
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   fac0=0.1
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:09:32 +00:00
										 |  |  |   do i=0,nfft3-1                      !Copy data into cx
 | 
					
						
							|  |  |  |      j=ja+i-(nfft3-1)
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |      xc(i)=0.
 | 
					
						
							|  |  |  |      if(j.ge.1) xc(i)=fac0*id2(j)
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:09:32 +00:00
										 |  |  |   enddo
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:09:32 +00:00
										 |  |  |   if(ihsym.lt.184) ihsym=ihsym+1
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   xc(0:nfft3-1)=w3(1:nfft3)*xc(0:nfft3-1)    !Apply window w3
 | 
					
						
							|  |  |  |   call four2a(xc,nfft3,1,-1,0)               !Real-to-complex FFT
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:09:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   n=min(184,ihsym)
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  |   df3=12000.0/nfft3                   !JT9-1: 0.732 Hz = 0.42 * tone spacing
 | 
					
						
							|  |  |  | !  i0=nint(1000.0/df3)
 | 
					
						
							|  |  |  |   i0=0
 | 
					
						
							|  |  |  |   iz=min(NSMAX,nint(5000.0/df3))
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:09:32 +00:00
										 |  |  |   fac=(1.0/nfft3)**2
 | 
					
						
							|  |  |  |   do i=1,iz
 | 
					
						
							|  |  |  |      j=i0+i-1
 | 
					
						
							|  |  |  |      if(j.lt.0) j=j+nfft3
 | 
					
						
							|  |  |  |      sx=fac*(real(cx(j))**2 + aimag(cx(j))**2)
 | 
					
						
							|  |  |  |      ss(n,i)=sx
 | 
					
						
							|  |  |  |      ssum(i)=ssum(i) + sx
 | 
					
						
							| 
									
										
										
										
											2014-01-17 14:56:11 +00:00
										 |  |  |      s(i)=1000.0*gain*sx
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:09:32 +00:00
										 |  |  |   enddo
 | 
					
						
							| 
									
										
										
										
											2012-05-22 17:09:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-17 14:46:23 +00:00
										 |  |  |   savg=ssum/ihsym
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-05 18:20:40 +00:00
										 |  |  |   if(mod(n,10).eq.0) then
 | 
					
						
							|  |  |  |      mode4=36
 | 
					
						
							|  |  |  |      nsmo=min(10*mode4,150)
 | 
					
						
							|  |  |  |      nsmo=4*nsmo
 | 
					
						
							|  |  |  |      call flat1(savg,iz,nsmo,syellow)
 | 
					
						
							|  |  |  |      if(mode4.ge.9) call smo(syellow,iz,tmp,mode4)
 | 
					
						
							|  |  |  |      ia=500./df3
 | 
					
						
							|  |  |  |      ib=2700.0/df3
 | 
					
						
							|  |  |  |      smin=minval(syellow(ia:ib))
 | 
					
						
							|  |  |  |      smax=maxval(syellow(1:iz))
 | 
					
						
							|  |  |  |      syellow=(50.0/(smax-smin))*(syellow-smin)
 | 
					
						
							|  |  |  |      where(syellow<0) syellow=0.
 | 
					
						
							|  |  |  |   endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-17 14:46:23 +00:00
										 |  |  |   if(nflatten.ne.0) then
 | 
					
						
							| 
									
										
										
										
											2014-01-08 20:55:11 +00:00
										 |  |  |      call flat3(s,iz,nfa,nfb,3,1.0,s)
 | 
					
						
							| 
									
										
										
										
											2014-01-09 00:03:22 +00:00
										 |  |  |      call flat3(savg,iz,nfa,nfb,3,1.0,savg)
 | 
					
						
							|  |  |  |      savg=7.0*savg
 | 
					
						
							| 
									
										
										
										
											2014-01-08 18:38:15 +00:00
										 |  |  |   endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-08 13:17:22 +00:00
										 |  |  | 900 npts8=k/8
 | 
					
						
							| 
									
										
										
										
											2012-10-15 17:43:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-04 19:03:39 +00:00
										 |  |  |   return
 | 
					
						
							| 
									
										
										
										
											2012-10-03 15:22:49 +00:00
										 |  |  | end subroutine symspec
 |