| 
									
										
										
										
											2017-02-21 20:13:36 +00:00
										 |  |  | subroutine analytic(d,npts,nfft,c,pc,beq)
 | 
					
						
							| 
									
										
										
										
											2012-07-10 13:44:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Convert real data to analytic signal
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  |   parameter (NFFTMAX=1024*1024)
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   real d(npts)              ! passband signal
 | 
					
						
							|  |  |  |   real h(NFFTMAX/2)         ! real BPF magnitude
 | 
					
						
							| 
									
										
										
										
											2017-02-23 16:21:26 +00:00
										 |  |  |   real*8 pc(5),pclast(5)    ! static phase coeffs
 | 
					
						
							|  |  |  |   real*8 ac(5),aclast(5)    ! amp coeffs
 | 
					
						
							|  |  |  |   real*8 fp
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-21 20:13:36 +00:00
										 |  |  |   complex corr(NFFTMAX/2)  ! complex frequency-dependent correction 
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  |   complex c(NFFTMAX)        ! analytic signal
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-21 20:13:36 +00:00
										 |  |  |   logical*1 beq            ! boolean static equalizer flag
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  |   data nfft0/0/
 | 
					
						
							| 
									
										
										
										
											2017-02-21 20:13:36 +00:00
										 |  |  |   data aclast/1.0,0.0,0.0,0.0,0.0/
 | 
					
						
							|  |  |  |   data ac/1.0,0.05532,0.11438,0.12918,0.09274/ ! amp coeffs for TS2000
 | 
					
						
							| 
									
										
										
										
											2016-12-20 03:01:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-21 20:13:36 +00:00
										 |  |  |   save corr,nfft0,h,ac,aclast,pclast,pi,t,beta
 | 
					
						
							| 
									
										
										
										
											2012-07-10 13:44:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  |   df=12000.0/nfft
 | 
					
						
							| 
									
										
										
										
											2012-07-10 13:44:17 +00:00
										 |  |  |   nh=nfft/2
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  |   if( nfft.ne.nfft0 ) then
 | 
					
						
							|  |  |  |      pi=4.0*atan(1.0)
 | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  |      t=1.0/2000.0
 | 
					
						
							| 
									
										
										
										
											2016-06-22 02:29:37 +00:00
										 |  |  |      beta=0.1
 | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  |      do i=1,nh+1
 | 
					
						
							|  |  |  |         ff=(i-1)*df
 | 
					
						
							|  |  |  |         f=ff-1500.0
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  |         h(i)=1.0
 | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  |         if(abs(f).gt.(1-beta)/(2*t) .and. abs(f).le.(1+beta)/(2*t)) then
 | 
					
						
							| 
									
										
										
										
											2016-12-20 03:01:43 +00:00
										 |  |  |            h(i)=h(i)*0.5*(1+cos((pi*t/beta )*(abs(f)-(1-beta)/(2*t))))
 | 
					
						
							| 
									
										
										
										
											2016-12-29 01:52:55 +00:00
										 |  |  |         elseif( abs(f) .gt. (1+beta)/(2*t) ) then
 | 
					
						
							|  |  |  |            h(i)=0.0
 | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  |         endif
 | 
					
						
							|  |  |  |      enddo
 | 
					
						
							|  |  |  |      nfft0=nfft
 | 
					
						
							|  |  |  |   endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-21 20:13:36 +00:00
										 |  |  |   if( any(aclast .ne. ac) .or. any(pclast .ne. pc) ) then
 | 
					
						
							|  |  |  |      aclast=ac
 | 
					
						
							|  |  |  |      pclast=pc
 | 
					
						
							| 
									
										
										
										
											2017-03-20 19:35:17 +00:00
										 |  |  |      write(*,3001) pc
 | 
					
						
							|  |  |  | 3001 format('Phase coeffs:',5f12.6)
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  |      do i=1,nh+1
 | 
					
						
							|  |  |  |         ff=(i-1)*df
 | 
					
						
							|  |  |  |         f=ff-1500.0
 | 
					
						
							|  |  |  |         fp=f/1000.0
 | 
					
						
							| 
									
										
										
										
											2017-02-21 20:13:36 +00:00
										 |  |  |         corr(i)=ac(1)+fp*(ac(2)+fp*(ac(3)+fp*(ac(4)+fp*ac(5))))
 | 
					
						
							|  |  |  |         pd=fp*fp*(pc(3)+fp*(pc(4)+fp*pc(5))) ! ignore 1st two terms
 | 
					
						
							|  |  |  |         corr(i)=corr(i)*cmplx(cos(pd),sin(pd))
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  |      enddo
 | 
					
						
							|  |  |  |   endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-10 13:44:17 +00:00
										 |  |  |   fac=2.0/nfft
 | 
					
						
							|  |  |  |   c(1:npts)=fac*d(1:npts)
 | 
					
						
							|  |  |  |   c(npts+1:nfft)=0.
 | 
					
						
							|  |  |  |   call four2a(c,nfft,1,-1,1)               !Forward c2c FFT
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-21 20:13:36 +00:00
										 |  |  |   if( beq ) then
 | 
					
						
							|  |  |  |     c(1:nh+1)=h(1:nh+1)*corr(1:nh+1)*c(1:nh+1)
 | 
					
						
							|  |  |  |   else
 | 
					
						
							| 
									
										
										
										
											2016-12-22 17:21:23 +00:00
										 |  |  |     c(1:nh+1)=h(1:nh+1)*c(1:nh+1)
 | 
					
						
							|  |  |  |   endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-18 01:28:12 +00:00
										 |  |  |   c(1)=0.5*c(1)                            !Half of DC term
 | 
					
						
							|  |  |  |   c(nh+2:nfft)=0.                          !Zero the negative frequencies
 | 
					
						
							| 
									
										
										
										
											2012-07-10 13:44:17 +00:00
										 |  |  |   call four2a(c,nfft,1,1,1)                !Inverse c2c FFT
 | 
					
						
							|  |  |  |   return
 | 
					
						
							|  |  |  | end subroutine analytic
 |