mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-23 09:00:25 -04:00 
			
		
		
		
	
		
			
	
	
		
			66 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
		
		
			
		
	
	
			66 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
|  | subroutine gen65(msg0,ichk,msgsent,itone,itext)
 | ||
|  | 
 | ||
|  | ! Encodes a JT65 message to yieild itone(1:126)
 | ||
|  | ! Temporarily, does not implement EME shorthands
 | ||
|  | 
 | ||
|  |   character*22 msg0
 | ||
|  |   character*22 message          !Message to be generated
 | ||
|  |   character*22 msgsent          !Message as it will be received
 | ||
|  |   integer itone(126)
 | ||
|  | !  character*3 cok               !'   ' or 'OOO'
 | ||
|  |   integer dgen(13)
 | ||
|  |   integer sent(63)
 | ||
|  |   logical text
 | ||
|  |   integer nprc(126)
 | ||
|  |   data nprc/1,0,0,1,1,0,0,0,1,1,1,1,1,1,0,1,0,1,0,0,  &
 | ||
|  |             0,1,0,1,1,0,0,1,0,0,0,1,1,1,0,0,1,1,1,1,  &
 | ||
|  |             0,1,1,0,1,1,1,1,0,0,0,1,1,0,1,0,1,0,1,1,  &
 | ||
|  |             0,0,1,1,0,1,0,1,0,1,0,0,1,0,0,0,0,0,0,1,  &
 | ||
|  |             1,0,0,0,0,0,0,0,1,1,0,1,0,0,1,0,1,1,0,1,  &
 | ||
|  |             0,1,0,1,0,0,1,1,0,0,1,0,0,1,0,0,0,0,1,1,  &
 | ||
|  |             1,1,1,1,1,1/
 | ||
|  |   save
 | ||
|  | 
 | ||
|  |   message=msg0
 | ||
|  |   do i=1,22
 | ||
|  |      if(ichar(message(i:i)).eq.0) then
 | ||
|  |         message(i:)='                      '
 | ||
|  |         exit
 | ||
|  |      endif
 | ||
|  |   enddo
 | ||
|  | 
 | ||
|  |   do i=1,22                               !Strip leading blanks
 | ||
|  |      if(message(1:1).ne.' ') exit
 | ||
|  |      message=message(i+1:)
 | ||
|  |   enddo
 | ||
|  | 
 | ||
|  |   nspecial=0
 | ||
|  | !  call chkmsg(message,cok,nspecial,flip)
 | ||
|  |   if(nspecial.eq.0) then
 | ||
|  |      call packmsg(message,dgen,text)     !Pack message into 72 bits
 | ||
|  |      itext=0
 | ||
|  |      if(text) itext=1
 | ||
|  |      call unpackmsg(dgen,msgsent)        !Unpack to get message sent
 | ||
|  |      if(ichk.ne.0) go to 999             !Return if checking only
 | ||
|  | 
 | ||
|  |      call rs_encode(dgen,sent)           !Apply Reed-Solomon code
 | ||
|  |      call interleave63(sent,1)           !Apply interleaving
 | ||
|  |      call graycode65(sent,63,1)          !Apply Gray code
 | ||
|  |      nsym=126                            !Symbols per transmission
 | ||
|  |   else
 | ||
|  |      nsym=32
 | ||
|  |   endif
 | ||
|  | 
 | ||
|  |   k=0
 | ||
|  |   do j=1,nsym
 | ||
|  |      if(nprc(j).eq.0) then
 | ||
|  |         k=k+1
 | ||
|  |         itone(j)=sent(k)+2
 | ||
|  |      else
 | ||
|  |         itone(j)=0
 | ||
|  |      endif
 | ||
|  |   enddo
 | ||
|  | 
 | ||
|  | 999 return
 | ||
|  | end subroutine gen65
 |