45 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
		
		
			
		
	
	
			45 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
| 
								 | 
							
								subroutine genbpsk(id,f00,ndiff,nref,c)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  parameter (ND=121)                     !Data symbols: LDPC (120,60), r=1/2
							 | 
						||
| 
								 | 
							
								  parameter (NN=ND)                      !Total symbols (121)
							 | 
						||
| 
								 | 
							
								  parameter (NSPS=28800)                 !Samples per symbol at 12000 sps
							 | 
						||
| 
								 | 
							
								  parameter (NZ=NSPS*NN)                 !Samples in waveform (3456000)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  complex c(0:NZ-1)                      !Complex waveform
							 | 
						||
| 
								 | 
							
								  real*8 twopi,dt,fs,baud,f0,dphi,phi
							 | 
						||
| 
								 | 
							
								  integer id(NN)                         !Encoded NRZ data (values +/-1)
							 | 
						||
| 
								 | 
							
								  integer ie(NN)                         !Differentially encoded data
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  f0=f00
							 | 
						||
| 
								 | 
							
								  twopi=8.d0*atan(1.d0)
							 | 
						||
| 
								 | 
							
								  fs=12000.d0
							 | 
						||
| 
								 | 
							
								  dt=1.0/fs
							 | 
						||
| 
								 | 
							
								  baud=1.d0/(NSPS*dt)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  if(ndiff.ne.0) then
							 | 
						||
| 
								 | 
							
								     ie(1)=1                             !First bit is always 1
							 | 
						||
| 
								 | 
							
								     do i=2,NN                           !Differentially encode
							 | 
						||
| 
								 | 
							
								        ie(i)=id(i)*ie(i-1)
							 | 
						||
| 
								 | 
							
								     enddo
							 | 
						||
| 
								 | 
							
								  endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								! Generate the BPSK waveform
							 | 
						||
| 
								 | 
							
								  phi=0.d0
							 | 
						||
| 
								 | 
							
								  k=-1
							 | 
						||
| 
								 | 
							
								  do j=1,NN
							 | 
						||
| 
								 | 
							
								     dphi=twopi*f0*dt
							 | 
						||
| 
								 | 
							
								     x=id(j)
							 | 
						||
| 
								 | 
							
								     if(ndiff.ne.0) x=ie(j)                !Differential
							 | 
						||
| 
								 | 
							
								     if(nref.ne.0) x=1.0                   !Generate reference carrier
							 | 
						||
| 
								 | 
							
								     do i=1,NSPS
							 | 
						||
| 
								 | 
							
								        k=k+1
							 | 
						||
| 
								 | 
							
								        phi=phi+dphi
							 | 
						||
| 
								 | 
							
								        if(phi.gt.twopi) phi=phi-twopi
							 | 
						||
| 
								 | 
							
								        xphi=phi
							 | 
						||
| 
								 | 
							
								        c(k)=x*cmplx(cos(xphi),sin(xphi))
							 | 
						||
| 
								 | 
							
								     enddo
							 | 
						||
| 
								 | 
							
								  enddo
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  return
							 | 
						||
| 
								 | 
							
								end subroutine genbpsk
							 |