22 lines
		
	
	
		
			369 B
		
	
	
	
		
			Fortran
		
	
	
	
	
	
		
		
			
		
	
	
			22 lines
		
	
	
		
			369 B
		
	
	
	
		
			Fortran
		
	
	
	
	
	
|   | subroutine degrade_snr(d2,npts,db,bw)
 | ||
|  | 
 | ||
|  | ! Degrade S/N by specified number of dB.
 | ||
|  | 
 | ||
|  |   integer*2 d2(npts)
 | ||
|  |   
 | ||
|  |   p0=0.
 | ||
|  |   do i=1,npts
 | ||
|  |      x=d2(i)
 | ||
|  |      p0=p0 + x*x
 | ||
|  |   enddo
 | ||
|  |   p0=p0/npts
 | ||
|  |   if(bw.gt.0.0) p0=p0*6000.0/bw
 | ||
|  |   s=sqrt(p0*(10.0**(0.1*db) - 1.0))
 | ||
|  |   fac=sqrt(p0/(p0+s*s))
 | ||
|  |   do i=1,npts
 | ||
|  |      d2(i)=nint(fac*(d2(i) + s*gran()))
 | ||
|  |   enddo
 | ||
|  | 
 | ||
|  |   return
 | ||
|  | end subroutine degrade_snr
 |