mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 18:10:21 -04:00 
			
		
		
		
	Commit most of what's necessary for decoding MSK144 short messages, including
the hash test. git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@6889 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									d4909beced
								
							
						
					
					
						commit
						5d2ed82517
					
				| @ -1,4 +1,4 @@ | |||||||
| subroutine detectmsk32(cbig,n,lines,nmessages,nutc) | subroutine detectmsk32(cbig,n,mycall,partnercall,lines,nmessages,nutc) | ||||||
|   use timer_module, only: timer |   use timer_module, only: timer | ||||||
| 
 | 
 | ||||||
|   parameter (NSPM=192, NPTS=3*NSPM, MAXSTEPS=7500, NFFT=3*NSPM, MAXCAND=40) |   parameter (NSPM=192, NPTS=3*NSPM, MAXSTEPS=7500, NFFT=3*NSPM, MAXCAND=40) | ||||||
| @ -6,7 +6,6 @@ subroutine detectmsk32(cbig,n,lines,nmessages,nutc) | |||||||
|   character*6 mycall,partnercall |   character*6 mycall,partnercall | ||||||
|   character*22 msg,hashmsg,msgreceived,allmessages(20) |   character*22 msg,hashmsg,msgreceived,allmessages(20) | ||||||
|   character*80 lines(100) |   character*80 lines(100) | ||||||
| !  character*512 pchk_file,gen_file |  | ||||||
|   complex cbig(n) |   complex cbig(n) | ||||||
|   complex cdat(NPTS)                    !Analytic signal |   complex cdat(NPTS)                    !Analytic signal | ||||||
|   complex cdat2(NPTS) |   complex cdat2(NPTS) | ||||||
| @ -98,19 +97,19 @@ subroutine detectmsk32(cbig,n,lines,nmessages,nutc) | |||||||
|      first=.false. |      first=.false. | ||||||
|   endif |   endif | ||||||
| 
 | 
 | ||||||
|   ! define the 32 likely messages  | ! Define the 32 likely messages  | ||||||
|   do irpt=0,31 |   do irpt=0,31 | ||||||
|     hashmsg='K9AN K1JT '//rpt(irpt) |     hashmsg=mycall//' '//partnercall//' '//rpt(irpt) | ||||||
|     call fmtmsg(hashmsg,iz) |     call fmtmsg(hashmsg,iz) | ||||||
|     call hash(hashmsg,22,ihash) |     call hash(hashmsg,22,ihash) | ||||||
|     ihash=iand(ihash,127) |     ihash=iand(ihash,127) | ||||||
|     ig=32*ihash + irpt |     ig=32*ihash + irpt | ||||||
|     likelymessages(irpt)=ig |     likelymessages(irpt)=ig | ||||||
| !    write(*,*) hashmsg,ig,ig24(ig) | !    write(*,*) irpt,hashmsg,ig,ig24(ig) | ||||||
|   enddo   |   enddo   | ||||||
|   qsocontext=.false. |   qsocontext=.false. | ||||||
| 
 | 
 | ||||||
|   ! fill the detmet, detferr arrays | ! Fill the detmet, detferr arrays | ||||||
|   nstepsize=48  ! 4ms steps |   nstepsize=48  ! 4ms steps | ||||||
|   nstep=(n-NPTS)/nstepsize   |   nstep=(n-NPTS)/nstepsize   | ||||||
|   detmet=0 |   detmet=0 | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| subroutine fast_decode(id2,narg,line,pchk_file) | subroutine fast_decode(id2,narg,line,pchk_file,mycall_12,hiscall_12) | ||||||
| 
 | 
 | ||||||
|   parameter (NMAX=30*12000) |   parameter (NMAX=30*12000) | ||||||
|   integer*2 id2(NMAX) |   integer*2 id2(NMAX) | ||||||
| @ -10,8 +10,12 @@ subroutine fast_decode(id2,narg,line,pchk_file) | |||||||
|   character*6 cfile6 |   character*6 cfile6 | ||||||
|   character*80 line(100) |   character*80 line(100) | ||||||
|   character*512 pchk_file |   character*512 pchk_file | ||||||
|  |   character*12 mycall_12,hiscall_12 | ||||||
|  |   character*6 mycall,hiscall | ||||||
|   save npts |   save npts | ||||||
| 
 | 
 | ||||||
|  |   mycall=mycall_12(1:6) | ||||||
|  |   hiscall=hiscall_12(1:6) | ||||||
|   nutc=narg(0) |   nutc=narg(0) | ||||||
|   ndat0=narg(1) |   ndat0=narg(1) | ||||||
|   nsubmode=narg(2) |   nsubmode=narg(2) | ||||||
| @ -33,7 +37,7 @@ subroutine fast_decode(id2,narg,line,pchk_file) | |||||||
|      call jtmsk_decode(id2,narg,line) |      call jtmsk_decode(id2,narg,line) | ||||||
|      go to 900 |      go to 900 | ||||||
|   else if(nmode.eq.104) then |   else if(nmode.eq.104) then | ||||||
|      call msk144_decode(id2,ndat0,nutc,0,pchk_file,line) |      call msk144_decode(id2,ndat0,nutc,0,pchk_file,mycall,hiscall,line) | ||||||
|      go to 900 |      go to 900 | ||||||
|   endif |   endif | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| subroutine msk144_decode(id2,npts,nutc,nprint,pchk_file,line) | subroutine msk144_decode(id2,npts,nutc,nprint,pchk_file,mycall,hiscall,line) | ||||||
| 
 | 
 | ||||||
| ! Calls the experimental decoder for MSK 72ms/16ms messages | ! Calls the experimental decoder for MSK 72ms/16ms messages | ||||||
| 
 | 
 | ||||||
| @ -10,6 +10,7 @@ subroutine msk144_decode(id2,npts,nutc,nprint,pchk_file,line) | |||||||
|   complex c(NFFTMAX)                   !Complex (analytic) data |   complex c(NFFTMAX)                   !Complex (analytic) data | ||||||
|   character*80 line(100)               !Decodes passed back to caller |   character*80 line(100)               !Decodes passed back to caller | ||||||
|   character*512 pchk_file |   character*512 pchk_file | ||||||
|  |   character*6 mycall,hiscall | ||||||
| 
 | 
 | ||||||
|   line(1:100)(1:1)=char(0) |   line(1:100)(1:1)=char(0) | ||||||
| 
 | 
 | ||||||
| @ -37,7 +38,7 @@ subroutine msk144_decode(id2,npts,nutc,nprint,pchk_file,line) | |||||||
|   endif |   endif | ||||||
| 
 | 
 | ||||||
|   if(nline .eq. 0) then |   if(nline .eq. 0) then | ||||||
|     call detectmsk32(c,npts,line,nline,nutc) |     call detectmsk32(c,npts,mycall,hiscall,line,nline,nutc) | ||||||
|     if( nprint .ne. 0 ) then |     if( nprint .ne. 0 ) then | ||||||
|       do i=1,nline |       do i=1,nline | ||||||
|         write(*,'(a80)') line(i) |         write(*,'(a80)') line(i) | ||||||
|  | |||||||
| @ -106,7 +106,8 @@ extern "C" { | |||||||
|                 float* width); |                 float* width); | ||||||
| 
 | 
 | ||||||
|   void fast_decode_(short id2[], int narg[], char msg[], char pchkFile[], |   void fast_decode_(short id2[], int narg[], char msg[], char pchkFile[], | ||||||
|                     int len1, int len2); |                     char mycall[], char hiscall[], int len1, int len2, | ||||||
|  |                     int len3, int len4); | ||||||
|   void hash_calls_(char calls[], int* ih9, int len); |   void hash_calls_(char calls[], int* ih9, int len); | ||||||
|   void degrade_snr_(short d2[], int* n, float* db, float* bandwidth); |   void degrade_snr_(short d2[], int* n, float* db, float* bandwidth); | ||||||
|   void wav12_(short d2[], short d1[], int* nbytes, short* nbitsam2); |   void wav12_(short d2[], short d1[], int* nbytes, short* nbitsam2); | ||||||
| @ -2206,7 +2207,8 @@ void MainWindow::decode()                                       //decode() | |||||||
|     narg[14]=m_config.aggressive(); |     narg[14]=m_config.aggressive(); | ||||||
|     memcpy(d2b,dec_data.d2,2*360000); |     memcpy(d2b,dec_data.d2,2*360000); | ||||||
|     watcher3.setFuture (QtConcurrent::run (std::bind (fast_decode_,&d2b[0], |     watcher3.setFuture (QtConcurrent::run (std::bind (fast_decode_,&d2b[0], | ||||||
|         &narg[0],&m_msg[0][0],&m_pchkFile[0],80,512))); |         &narg[0],&m_msg[0][0],&m_pchkFile[0],dec_data.params.mycall, | ||||||
|  |         dec_data.params.hiscall,80,512,12,12))); | ||||||
|   } else { |   } else { | ||||||
|     memcpy(to, from, qMin(mem_jt9->size(), size)); |     memcpy(to, from, qMin(mem_jt9->size(), size)); | ||||||
|     QFile {m_config.temp_dir ().absoluteFilePath (".lock")}.remove (); // Allow jt9 to start
 |     QFile {m_config.temp_dir ().absoluteFilePath (".lock")}.remove (); // Allow jt9 to start
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user