 c24e931f09
			
		
	
	
		c24e931f09
		
	
	
	
	
		
			
			commit 0d6833b23da2519155ee93b98b4144240b356730
Author: Jordan Sherer <jordan@widefido.com>
Date:   Thu Sep 5 14:06:47 2019 -0400
    Bump version
commit 17705fcff6a22529f3dec45aa95cad90feb78c63
Author: Jordan Sherer <jordan@widefido.com>
Date:   Thu Sep 5 10:36:03 2019 -0400
    Updated configration labeling for idle timeout
commit a9f8aa9549c1c6b62201a6c102d91649ee17b9a5
Author: Jordan Sherer <jordan@widefido.com>
Date:   Thu Sep 5 10:07:11 2019 -0400
    Decoder params tests
commit 94e524741020fd8b3925233a189cedf0a8a282cc
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Sep 4 21:24:23 2019 -0400
    Fixed decoder bug that crashed the software
commit 4fdbfc8d9082e0f52513a5c215489b13558972f9
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Sep 4 21:02:52 2019 -0400
    Decoder params tweak
commit 1e25ac41d442372f09b254d957e0d9e31773254e
Merge: 97a0fb5 552cd7f
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Sep 4 18:17:40 2019 -0400
    Merge branch 'fortran-cleanup' of bitbucket.org:widefido/js8call-private into fortran-cleanup
commit 97a0fb51b37c24e2638400dc5694fc4e988ae4f2
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Sep 4 18:15:25 2019 -0400
    Heartbeat as a mode does not work if slow mode does not work. Tabling this idea for now.
commit 552cd7fe5fc81c712b57b5f3ea79599177e53f69
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 23:35:14 2019 +0000
    js8_params.f90 edited online with Bitbucket
commit 7c9e960b863148a4ecbca4f61584536471623ea2
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 16:28:52 2019 -0400
    Do not randomize offset at startup
commit cff7b90dbb9aada2944e668a9bcf078470af4608
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 16:20:19 2019 -0400
    Slow label for button
commit 977145dee89ccd7da4d43ce0bc2f9b79243aa200
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 16:17:36 2019 -0400
    Experimental slow mode
commit 27c128e0b327e1c077a9b49e11750bef2f3c26eb
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 15:26:01 2019 -0400
    HBs are Normal
commit 89792f91abf22dcd7c512bf7362f5e2e1cb36374
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 14:16:27 2019 -0400
    Update heartbeat UI for more clarity
commit f5cebbcdabe37d90b75ca7e8d1675a553e107c83
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 11:58:53 2019 -0400
    Optimize decode params
commit b14003bb34d93f9e93d7d4ad4241d619963c3a65
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 11:30:00 2019 -0400
    Shrink speed column for Joe ;)
commit 35f4446146efc9fd7044af3b56b0b93664238b24
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 10:54:28 2019 -0400
    Fixed fast mode decoder for directed messages
commit 64212acc30dd360348a72b354899a5b0de28aa83
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 10:05:11 2019 -0400
    Simplified decoder callbacks
commit a026766517d282a3fda0258356f6f22fee2a916f
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Sep 3 09:50:33 2019 -0400
    Commentary
commit 9d28b1ff5bd5cda7a04028218a01639e3902bf7b
Author: Jordan Sherer <jordan@widefido.com>
Date:   Mon Sep 2 23:33:22 2019 -0400
    Let's experiment with a new UI for HB
commit a013d66d8b8d16cc941a14eb76af2ce23b7bb6d5
Author: Jordan Sherer <jordan@widefido.com>
Date:   Mon Sep 2 21:44:26 2019 -0400
    31.25 baud experiment
commit 0671458bf588dd94710c5ba34f20695e13a28d31
Author: Jordan Sherer <jordan@widefido.com>
Date:   Mon Sep 2 15:31:43 2019 -0400
    Added basic foundation for slow mode, coming soon.
commit 8b9aed6e29b093e8fb736ebdbdf0fbe12a820e8e
Author: Jordan Sherer <jordan@widefido.com>
Date:   Mon Sep 2 09:59:08 2019 -0400
    Display SPEED+AUTO
commit 5f5af250c1c5b610e8969b32c01654d3467f0973
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sun Sep 1 09:45:39 2019 -0400
    Added mode speed option to the activity tables
commit 82fa0335fdd41f0a578149e0211d6307293c739d
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 31 23:14:07 2019 -0400
    Remember mode speed setting
commit 79ec805b223099bb4d552dc612a6c97a8982525e
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 31 21:14:04 2019 -0400
    Remove unused sync vars
commit fc52dfcc320e59f6c7ca58ba277cb70469419587
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 31 21:12:11 2019 -0400
    Timing delta max
commit 62b8fc5054d3611d40d7441d57d695df594b8446
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 31 17:14:08 2019 -0400
    Fast modes optionally can use huff encoding for data... we'll see which is best
commit 44c357aff3e1c6687e93fb843917bd420888b397
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 31 17:03:21 2019 -0400
    Added ability to use a different message packing algorithm for fast modes
commit e075a078eb75509ef690e6c78c0e797ada569b94
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 31 16:18:14 2019 -0400
    Fixed symbol offset in sync code for turbo mode
commit a130b5d4a594e9bceece003be0ba72abb05a9f90
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 31 16:09:27 2019 -0400
    Added WPM to menu
commit 98cacab7bfc243492b6dec703d216d378cc3d34d
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 30 23:18:58 2019 -0400
    Key eater
commit eef58e2c88d010c7f3917a111243eae744a425c3
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 30 16:07:31 2019 -0400
    Reorganizing js8dec for better understanding and less confusion between it and JS8b
commit 08c14f966e1cda836ca90a8bd1ccd5ae68ec8dd7
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 30 14:20:52 2019 -0400
    Do no expose relay and messaging to fast and turbo modes
commit c605a31c266866f78eb043812af837ead6442ede
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 30 12:02:41 2019 -0400
    Do not allow mode speed changes if transmitting
commit add062e657a5215f9a4a1ae3ee82063aa85cf0e4
Author: Jordan Sherer <jordan@widefido.com>
Date:   Thu Aug 29 23:02:31 2019 -0400
    Fixed bug where tones were not generated with the correct costas arrays...causing really poor synchronization and failed decodes. I'm surprised it worked at all :P
commit cd492b5dd9fd62b5518a5711a1ef8ec522ea08fe
Author: Jordan Sherer <jordan@widefido.com>
Date:   Thu Aug 29 21:56:45 2019 -0400
    Back to 20 baud. It has the best decodability, imho
commit a2266cd00b8bd14c77bdbc8fc18818689e969858
Author: Jordan Sherer <jordan@widefido.com>
Date:   Thu Aug 29 14:27:29 2019 -0400
    Back to 20 baud with some decoder optimizations
commit 86413042e75873585bcb40236da67f2d64870859
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 28 23:04:47 2019 -0400
    Try 24 baud
commit a6704162b37d1c0704f43a64ab6b8a0a6e3c1cba
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 28 17:09:12 2019 -0400
    Fixed legacy compiler issue with mode text
commit 2fdbcc12e5f0c8cc8062c745af0930db4472cd9c
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 28 10:17:23 2019 -0400
    Function for determining current mode
commit 82e70345baa665418a51307f0309f2b7dcb3d3b7
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 28 09:59:26 2019 -0400
    Don't write the log
commit d3380e01676537f4bab9a05932cb5a59de3cf45f
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 28 09:59:03 2019 -0400
    Fixed issues with turbo decode with partial sync code
commit c2a8ebb8f305e67fcb2597d25e062663722a0d73
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 28 03:30:02 2019 -0400
    Working through better decoding of fast modes
commit 7ca93f8c6a7970559577c9dfd833eb92a1b91a0c
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 23:23:34 2019 -0400
    Trying for better TX/RX delays
commit b99271b4feaa7e41c7b88219cb3c7d43dbe7b48d
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 22:57:02 2019 -0400
    Added flags to easily enable/disable the faster modes
commit 32d913a7f7d3deb6a8d66651d51673ec451d2500
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 22:43:20 2019 -0400
    Added mode button
commit c7cc90548591638bfc5a4a8895036dd67b155aaa
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 22:17:42 2019 -0400
    Updated start delay for the modes
commit b91dc63f92101cd8b6adbf9de588c4ffd10bfc10
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 21:55:57 2019 -0400
    Late threshold for turbo mode is 1/2 the delay
commit 09ec95fab1307e65aa9bd462d60525afd2a770fe
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 21:52:55 2019 -0400
    Renamed mode menu items
commit a4e5a9ed9bce66c625e4df1182cd3c91a6ba44dd
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 21:50:45 2019 -0400
    Only enable networking and autoreply for normal JS8
commit fc558d5823c46fc5d3dc651610b7af43e7519165
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 21:14:12 2019 -0400
    Fixed spot button tooltip
commit 9a9965d543540a2d215bcbfff34934846afe507a
Author: Jordan Sherer <jordan@widefido.com>
Date:   Tue Aug 27 10:04:31 2019 -0400
    Working selectable decoder
commit 4a9cdbc52dae1d857c102d8777f1aded4fac87bb
Author: Jordan Sherer <jordan@widefido.com>
Date:   Mon Aug 26 20:53:30 2019 -0400
    Mode menu selection of the submodes. Turbo decoder disabled right now. Naming to be determined
commit a3acbf7c243f7aa740c229ae178fffa528e68933
Merge: 8ea554d daa8cc2
Author: Jordan Sherer <jordan@widefido.com>
Date:   Mon Aug 26 13:29:14 2019 -0400
    Merge branch 'ft8call-develop' into fortran-cleanup
commit 8ea554d79904c9b2f3ccf1027bf4d41fb25e6fe3
Author: Jordan Sherer <jordan@widefido.com>
Date:   Mon Aug 26 09:53:21 2019 -0400
    Use indx variable instead of computed
commit 067e65500328133f921b172e515babbcc0df831b
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sun Aug 25 22:41:00 2019 -0400
    Make it easier to flip between modes
commit a544a7635201072f3ea20483353edf2e79dc813d
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sun Aug 25 21:18:46 2019 -0400
    Fixed sync issues with multi costas. Added log statements for future debugging
commit a8f3ead932017ae7d98fdb9a779bf3bb44bd395d
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sun Aug 25 15:54:59 2019 -0400
    Playing around with different costas arrays
commit fa89fe11a15d26abadd5102c8980620cfeffccd9
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sun Aug 25 15:51:45 2019 -0400
    Added reference to 7x7 costas arrays
commit 2417ebed6139534214f76ce94bdf1f54a966760a
Merge: 6011f1e 32fcabd
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 24 23:41:39 2019 -0400
    Merge branch 'ft8call-develop' into fortran-cleanup
commit 6011f1e807b1814399477d3c172db46831a090c6
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 24 23:35:42 2019 -0400
    Back to 10 baud. Update late threshold to be computed to 3/4 dead air time.
commit 41d3995861226f7208b2773430010a48abc125c1
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 24 15:36:12 2019 -0400
    Trying out 20 baud
commit a8d77e9e5b98f3f0bf19f68b53199b5952e8aaad
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 24 15:23:36 2019 -0400
    Fixed up sync quarter symbol constant
commit 7050722436b9c629ea00649e6b3c81d7af7be82a
Author: Jordan Sherer <jordan@widefido.com>
Date:   Sat Aug 24 14:43:48 2019 -0400
    Computed symbol stop
commit f130fe87abdccbabd2e71f2771b789c7f46d57ca
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 23 20:56:59 2019 -0400
    Added reference to 7x7 costas arrays
commit 53e91858f5a4e9ce78c38ef65c77e87f1903c058
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 23 16:34:51 2019 -0400
    Back to 10 baud
commit 1ae79d566ebd9a40ad3cf4a07977ef0e09615d91
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 23 15:14:41 2019 -0400
    Testing 31.25 baud
commit 7e033c28ae090d6c3f5a63fa651ee51c3243d61c
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 23 15:14:17 2019 -0400
    Experimenting with a few different baudrates
commit 050e24ad3a040924ded6d641004ae63da47e4251
Author: Jordan Sherer <jordan@widefido.com>
Date:   Fri Aug 23 12:25:50 2019 -0400
    Added ldpcsim for js8
commit d309a75d860e39737dec732560432a191290b258
Author: Jordan Sherer <jordan@widefido.com>
Date:   Thu Aug 22 22:42:11 2019 -0400
    Experimental submode switching
commit 74f72bb24a22631b8b69942ea0633bb0564b8aa3
Author: Jordan Sherer <jordan@widefido.com>
Date:   Thu Aug 22 22:41:53 2019 -0400
    Allow switching decoders based on submode
commit f8740a23b27e80fa53350e140d4638a27cd6e975
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 21 23:43:18 2019 -0400
    Initial spike of js8 fortran code
commit 31625316639f79246b4a2e3d0cea4507bf0547f9
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 21 23:09:00 2019 -0400
    Remove fix contest message
commit c0e0862afa8ae2d47e9577562399b8c9bc929c6a
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 21 21:05:05 2019 -0400
    Cleanup unused text files and batch files
commit 1b3aa55869f0c310e6c911a7cbb3fe269bc7421a
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 21 21:00:38 2019 -0400
    Removed fast_decode and dx
commit 49e5cabff25c13620a9d2c6fc6ddd4988f1be217
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 21 20:54:39 2019 -0400
    Cleaning up msk stuff
commit 8bde6f391f4b23d2a2e9d55685d96bc647a462f6
Author: Jordan Sherer <jordan@widefido.com>
Date:   Wed Aug 21 20:44:39 2019 -0400
    Initial cleanup pass of qra, ftrsd, and wsprd
		
	
			
		
			
				
	
	
		
			487 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
			
		
		
	
	
			487 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Fortran
		
	
	
	
	
	
| subroutine js8dec(dd0,newdat,nQSOProgress,nfqso,nftx,ndepth,lapon,lapcqonly,   &
 | |
|      napwid,lsubtract,nagain,iaptype,mycall12,mygrid6,hiscall12,bcontest,    &
 | |
|      sync0,f1,xdt,xbase,apsym,nharderrors,dmin,nbadcrc,ipass,iera,msg37,xsnr)  
 | |
| 
 | |
|   use crc
 | |
|   use timer_module, only: timer
 | |
| 
 | |
|   !include 'js8_params.f90'
 | |
|   
 | |
|   parameter(NP=3200) ! why 3200? not sure...
 | |
|   parameter(NP2=2812)
 | |
|   character*37 msg37
 | |
|   character message*22,msgsent*22,origmsg*22
 | |
|   character*12 mycall12,hiscall12
 | |
|   character*6 mycall6,mygrid6,hiscall6,c1,c2
 | |
|   character*87 cbits
 | |
|   logical bcontest
 | |
|   real a(5)
 | |
|   real s1(0:7,ND),s2(0:7,NN),s1sort(8*ND)
 | |
|   real ps(0:7),psl(0:7)
 | |
|   real bmeta(3*ND),bmetb(3*ND),bmetap(3*ND)
 | |
|   real llr(3*ND),llra(3*ND),llr0(3*ND),llr1(3*ND),llrap(3*ND)           !Soft symbols
 | |
|   real dd0(NMAX)
 | |
|   integer*1 decoded(KK),decoded0(KK),apmask(3*ND),cw(3*ND)
 | |
|   integer*1 msgbits(KK)
 | |
|   integer apsym(KK)
 | |
|   integer mcq(28),mde(28),mrrr(16),m73(16),mrr73(16)
 | |
|   integer itone(NN)
 | |
|   integer indxs1(8*ND)
 | |
|   integer ip(1)
 | |
|   integer nappasses(0:5)  !Number of decoding passes to use for each QSO state
 | |
|   integer naptypes(0:5,4) ! (nQSOProgress, decoding pass)  maximum of 4 passes for now
 | |
|   integer*1, target:: i1hiscall(12)
 | |
|   complex cd0(0:NP-1)
 | |
|   complex ctwk(4*NSPS/NDOWN)
 | |
|   complex csymb(NDOWNSPS)
 | |
|   logical first,newdat,lsubtract,lapon,lapcqonly,nagain
 | |
|   equivalence (s1,s1sort)
 | |
|   data mcq/1,1,1,1,1,0,1,0,0,0,0,0,1,0,0,0,0,0,1,1,0,0,0,1,1,0,0,1/
 | |
|   data mrrr/0,1,1,1,1,1,1,0,1,1,0,0,1,1,1,1/
 | |
|   data m73/0,1,1,1,1,1,1,0,1,1,0,1,0,0,0,0/
 | |
|   data mde/1,1,1,1,1,1,1,1,0,1,1,0,0,1,0,0,0,0,0,1,1,1,0,1,0,0,0,1/
 | |
|   data mrr73/0,0,0,0,0,0,1,0,0,0,0,1,0,1,0,1/
 | |
|   data first/.true./
 | |
|   save nappasses,naptypes
 | |
| 
 | |
|   integer icos7a(0:6), icos7b(0:6), icos7c(0:6)
 | |
|   if(NCOSTAS.eq.1) then
 | |
|     icos7a = (/4,2,5,6,1,3,0/)                  !Beginning Costas 7x7 tone pattern
 | |
|     icos7b = (/4,2,5,6,1,3,0/)                  !Middle Costas 7x7 tone pattern
 | |
|     icos7c = (/4,2,5,6,1,3,0/)                  !End Costas 7x7 tone pattern
 | |
|   else
 | |
|     icos7a = (/0,6,2,3,5,4,1/)                  !Beginning Costas 7x7 tone pattern
 | |
|     icos7b = (/1,5,0,2,3,6,4/)                  !Middle Costas 7x7 tone pattern
 | |
|     icos7c = (/2,5,0,6,4,1,3/)                  !End Costas 7x7 tone pattern
 | |
|   endif
 | |
| 
 | |
|   if(first) then
 | |
|      mcq=2*mcq-1
 | |
|      mde=2*mde-1
 | |
|      mrrr=2*mrrr-1
 | |
|      m73=2*m73-1
 | |
|      mrr73=2*mrr73-1
 | |
|      nappasses(0)=2
 | |
|      nappasses(1)=2
 | |
|      nappasses(2)=2
 | |
|      nappasses(3)=4
 | |
|      nappasses(4)=4
 | |
|      nappasses(5)=3
 | |
| 
 | |
| ! iaptype
 | |
| !------------------------
 | |
| !   1        CQ     ???    ???
 | |
| !   2        MyCall ???    ???
 | |
| !   3        MyCall DxCall ???
 | |
| !   4        MyCall DxCall RRR
 | |
| !   5        MyCall DxCall 73
 | |
| !   6        MyCall DxCall RR73
 | |
| !   7        ???    DxCall ???
 | |
| 
 | |
|      naptypes(0,1:4)=(/1,2,0,0/)
 | |
|      naptypes(1,1:4)=(/2,3,0,0/)
 | |
|      naptypes(2,1:4)=(/2,3,0,0/)
 | |
|      naptypes(3,1:4)=(/3,4,5,6/)
 | |
|      naptypes(4,1:4)=(/3,4,5,6/)
 | |
|      naptypes(5,1:4)=(/3,1,2,0/)  
 | |
|      first=.false.
 | |
|   endif
 | |
| 
 | |
|   max_iterations=30
 | |
|   nharderrors=-1
 | |
|   fs2=12000.0/NDOWN
 | |
|   dt2=1.0/fs2
 | |
|   twopi=8.0*atan(1.0)
 | |
|   delfbest=0.
 | |
|   ibest=0
 | |
| 
 | |
|   call timer('js8_down',0)
 | |
|   call js8_downsample(dd0,newdat,f1,cd0)   !Mix f1 to baseband and downsample
 | |
|   call timer('js8_down',1)
 | |
| 
 | |
|   xdt=xdt+ASTART
 | |
|   i0=nint(xdt*fs2)                   !Initial guess for start of signal
 | |
|   smax=0.0
 | |
| 
 | |
|   if(NWRITELOG.eq.1) then
 | |
|       open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|       write(99,*) 'initial dt guess', i0, xdt
 | |
|       close(99) 
 | |
|   endif
 | |
| 
 | |
|   do idt=i0-NQSYMBOL,i0+NQSYMBOL             !Search over +/- one quarter symbol
 | |
|      call syncjs8d(cd0,idt,ctwk,0,sync)
 | |
|      if(NWRITELOG.eq.1) then
 | |
|          open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|          write(99,*) 'idt', idt, 'sync', sync
 | |
|          close(99) 
 | |
|      endif
 | |
|      if(sync.gt.smax) then
 | |
|         smax=sync
 | |
|         ibest=idt
 | |
|      endif
 | |
|   enddo
 | |
|   xdt2=ibest*dt2                           !Improved estimate for DT
 | |
| 
 | |
|   if(NWRITELOG.eq.1) then
 | |
|     open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|     write(99,*) 'xdt2', xdt2, ibest
 | |
|     close(99) 
 | |
|   endif
 | |
| 
 | |
| ! Now peak up in frequency
 | |
|   i0=nint(xdt2*fs2)
 | |
|   smax=0.0
 | |
| 
 | |
|   do ifr=-5,5                              !Search over +/- 2.5 Hz
 | |
|     delf=ifr*0.5
 | |
|     dphi=twopi*delf*dt2
 | |
|     phi=0.0
 | |
|     do i=1,NDOWNSPS
 | |
|       ctwk(i)=cmplx(cos(phi),sin(phi))
 | |
|       phi=mod(phi+dphi,twopi)
 | |
|     enddo
 | |
|     call syncjs8d(cd0,i0,ctwk,1,sync)
 | |
|     if(NWRITELOG.eq.1) then
 | |
|         open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|         write(99,*) 'df', delf, 'sync', sync
 | |
|         close(99) 
 | |
|     endif
 | |
|     if( sync .gt. smax ) then
 | |
|       smax=sync
 | |
|       delfbest=delf
 | |
|     endif
 | |
|   enddo
 | |
|   a=0.0
 | |
|   a(1)=-delfbest
 | |
|   call twkfreq1(cd0,NP2,fs2,a,cd0)
 | |
|   xdt=xdt2
 | |
|   f1=f1+delfbest                           !Improved estimate of DF
 | |
| 
 | |
|   if(NWRITELOG.eq.1) then
 | |
|     open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|     write(99,*) 'twk', xdt, f1, smax
 | |
|     close(99) 
 | |
|   endif
 | |
| 
 | |
|   call syncjs8d(cd0,i0,ctwk,2,sync)
 | |
| 
 | |
|   j=0
 | |
|   do k=1,NN
 | |
|     i1=ibest+(k-1)*NDOWNSPS
 | |
|     csymb=cmplx(0.0,0.0)
 | |
|     !if( i1.ge.1 .and. i1+31 .le. NP2 ) csymb=cd0(i1:i1+31)
 | |
|     if( i1.ge.0 .and. i1+(NDOWNSPS-1) .le. NP2-1 ) csymb=cd0(i1:i1+(NDOWNSPS-1))
 | |
|     call four2a(csymb,NDOWNSPS,1,-1,1)
 | |
|     s2(0:7,k)=abs(csymb(1:8))/1e3
 | |
|   enddo  
 | |
| 
 | |
| ! sync quality check
 | |
|   is1=0
 | |
|   is2=0
 | |
|   is3=0
 | |
|   do k=1,7
 | |
|     ip=maxloc(s2(:,k))
 | |
|     if(icos7a(k-1).eq.(ip(1)-1)) is1=is1+1
 | |
|     ip=maxloc(s2(:,k+36))
 | |
|     if(icos7b(k-1).eq.(ip(1)-1)) is2=is2+1
 | |
|     ip=maxloc(s2(:,k+72))
 | |
|     if(icos7c(k-1).eq.(ip(1)-1)) is3=is3+1
 | |
|   enddo
 | |
| ! hard sync sum - max is 21
 | |
|   nsync=is1+is2+is3
 | |
| 
 | |
|   if(NWRITELOG.eq.1) then
 | |
|     open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|     write(99,*) 'sync', ibest, nsync   
 | |
|     close(99) 
 | |
|   endif
 | |
| 
 | |
|   if(nsync .le. 6) then ! bail out
 | |
|     call timer('badnsync', 0)
 | |
|     nbadcrc=1
 | |
|     call timer('badnsync', 1)
 | |
|     return
 | |
|   endif
 | |
| 
 | |
|   j=0
 | |
|   do k=1,NN
 | |
|      if(k.le.7) cycle
 | |
|      if(k.ge.37 .and. k.le.43) cycle
 | |
|      if(k.gt.72) cycle
 | |
|      j=j+1
 | |
|      s1(0:7,j)=s2(0:7,k)
 | |
|   enddo  
 | |
| 
 | |
|   call indexx(s1sort,8*ND,indxs1)
 | |
|   xmeds1=s1sort(indxs1(nint(0.5*8*ND)))
 | |
|   s1=s1/xmeds1
 | |
| 
 | |
|   do j=1,ND
 | |
|      i4=3*j-2
 | |
|      i2=3*j-1
 | |
|      i1=3*j
 | |
| ! Max amplitude
 | |
|      ps=s1(0:7,j)
 | |
|      r1=max(ps(1),ps(3),ps(5),ps(7))-max(ps(0),ps(2),ps(4),ps(6))
 | |
|      r2=max(ps(2),ps(3),ps(6),ps(7))-max(ps(0),ps(1),ps(4),ps(5))
 | |
|      r4=max(ps(4),ps(5),ps(6),ps(7))-max(ps(0),ps(1),ps(2),ps(3))
 | |
|      bmeta(i4)=r4
 | |
|      bmeta(i2)=r2
 | |
|      bmeta(i1)=r1
 | |
|      bmetap(i4)=r4
 | |
|      bmetap(i2)=r2
 | |
|      bmetap(i1)=r1
 | |
| ! Max log metric
 | |
|      psl=log(ps+1e-32)
 | |
|      r1=max(psl(1),psl(3),psl(5),psl(7))-max(psl(0),psl(2),psl(4),psl(6))
 | |
|      r2=max(psl(2),psl(3),psl(6),psl(7))-max(psl(0),psl(1),psl(4),psl(5))
 | |
|      r4=max(psl(4),psl(5),psl(6),psl(7))-max(psl(0),psl(1),psl(2),psl(3))
 | |
|      bmetb(i4)=r4
 | |
|      bmetb(i2)=r2
 | |
|      bmetb(i1)=r1
 | |
| 
 | |
| ! Metric for Cauchy noise
 | |
| !     r1=log(ps(1)**3+ps(3)**3+ps(5)**3+ps(7)**3)- &
 | |
| !        log(ps(0)**3+ps(2)**3+ps(4)**3+ps(6)**3)
 | |
| !     r2=log(ps(2)**3+ps(3)**3+ps(6)**3+ps(7)**3)- &
 | |
| !        log(ps(0)**3+ps(1)**3+ps(4)**3+ps(5)**3)
 | |
| !     r4=log(ps(4)**3+ps(5)**3+ps(6)**3+ps(7)**3)- &
 | |
| !        log(ps(0)**3+ps(1)**3+ps(2)**3+ps(3)**3)
 | |
| ! Metric for AWGN, no fading
 | |
| !     bscale=2.5
 | |
| !     b0=bessi0(bscale*ps(0))
 | |
| !     b1=bessi0(bscale*ps(1))
 | |
| !     b2=bessi0(bscale*ps(2))
 | |
| !     b3=bessi0(bscale*ps(3))
 | |
| !     b4=bessi0(bscale*ps(4))
 | |
| !     b5=bessi0(bscale*ps(5))
 | |
| !     b6=bessi0(bscale*ps(6))
 | |
| !     b7=bessi0(bscale*ps(7))
 | |
| !     r1=log(b1+b3+b5+b7)-log(b0+b2+b4+b6)
 | |
| !     r2=log(b2+b3+b6+b7)-log(b0+b1+b4+b5)
 | |
| !     r4=log(b4+b5+b6+b7)-log(b0+b1+b2+b3)
 | |
| 
 | |
|      if(nQSOProgress .eq. 0 .or. nQSOProgress .eq. 5) then
 | |
| ! When bits 88:115 are set as ap bits, bit 115 lives in symbol 39 along
 | |
| ! with no-ap bits 116 and 117. Take care of metrics for bits 116 and 117.
 | |
|         if(j.eq.39) then  ! take care of bits that live in symbol 39
 | |
|            if(apsym(28).lt.0) then
 | |
|               bmetap(i2)=max(ps(2),ps(3))-max(ps(0),ps(1))
 | |
|               bmetap(i1)=max(ps(1),ps(3))-max(ps(0),ps(2))
 | |
|            else 
 | |
|               bmetap(i2)=max(ps(6),ps(7))-max(ps(4),ps(5))
 | |
|               bmetap(i1)=max(ps(5),ps(7))-max(ps(4),ps(6))
 | |
|            endif
 | |
|         endif
 | |
|      endif
 | |
| 
 | |
| ! When bits 116:143 are set as ap bits, bit 115 lives in symbol 39 along
 | |
| ! with ap bits 116 and 117. Take care of metric for bit 115.
 | |
|         if(j.eq.39) then  ! take care of bit 115
 | |
|            iii=2*(apsym(29)+1)/2 + (apsym(30)+1)/2  ! known values of bits 116 & 117
 | |
|            if(iii.eq.0) bmetap(i4)=ps(4)-ps(0)
 | |
|            if(iii.eq.1) bmetap(i4)=ps(5)-ps(1)
 | |
|            if(iii.eq.2) bmetap(i4)=ps(6)-ps(2)
 | |
|            if(iii.eq.3) bmetap(i4)=ps(7)-ps(3)
 | |
|         endif
 | |
| 
 | |
| ! bit 144 lives in symbol 48 and will be 1 if it is set as an ap bit.
 | |
| ! take care of metrics for bits 142 and 143
 | |
|      if(j.eq.48) then  ! bit 144 is always 1
 | |
|        bmetap(i4)=max(ps(5),ps(7))-max(ps(1),ps(3))
 | |
|        bmetap(i2)=max(ps(3),ps(7))-max(ps(1),ps(5))
 | |
|      endif 
 | |
|  
 | |
| ! bit 154 lives in symbol 52 and will be 0 if it is set as an ap bit
 | |
| ! take care of metrics for bits 155 and 156
 | |
|      if(j.eq.52) then  ! bit 154 will be 0 if it is set as an ap bit.
 | |
|         bmetap(i2)=max(ps(2),ps(3))-max(ps(0),ps(1))
 | |
|         bmetap(i1)=max(ps(1),ps(3))-max(ps(0),ps(2))
 | |
|      endif  
 | |
| 
 | |
|   enddo
 | |
| 
 | |
|   call normalizebmet(bmeta,3*ND)
 | |
|   call normalizebmet(bmetb,3*ND)
 | |
|   call normalizebmet(bmetap,3*ND)
 | |
| 
 | |
|   scalefac=2.83
 | |
|   llr0=scalefac*bmeta
 | |
|   llr1=scalefac*bmetb
 | |
|   llra=scalefac*bmetap  ! llr's for use with ap
 | |
|   apmag=scalefac*(maxval(abs(bmetap))*1.01)
 | |
| 
 | |
| ! pass #
 | |
| !------------------------------
 | |
| !   1        regular decoding
 | |
| !   2        erase 24
 | |
| !   3        erase 48
 | |
| !   4        ap pass 1
 | |
| !   5        ap pass 2
 | |
| !   6        ap pass 3
 | |
| !   7        ap pass 4, etc.
 | |
| 
 | |
|   !if(lapon) then 
 | |
|   !   if(.not.lapcqonly) then
 | |
|   !      npasses=4+nappasses(nQSOProgress)
 | |
|   !   else
 | |
|   !      npasses=5 
 | |
|   !   endif
 | |
|   !else
 | |
|      npasses=4
 | |
|   !endif
 | |
| 
 | |
|   do ipass=1,npasses 
 | |
|                
 | |
|      llr=llr0
 | |
|      if(ipass.eq.2) llr=llr1
 | |
|      if(ipass.eq.3) llr(1:24)=0. 
 | |
|      if(ipass.eq.4) llr(1:48)=0. 
 | |
|      if(ipass.le.4) then
 | |
|         apmask=0
 | |
|         llrap=llr
 | |
|         iaptype=0
 | |
|      endif
 | |
|         
 | |
|      !if(ipass .gt. 4) then
 | |
|      !   if(.not.lapcqonly) then
 | |
|      !      iaptype=naptypes(nQSOProgress,ipass-4)
 | |
|      !   else
 | |
|      !      iaptype=1
 | |
|      !   endif
 | |
|      !   if(iaptype.ge.3 .and. (abs(f1-nfqso).gt.napwid .and. abs(f1-nftx).gt.napwid) ) cycle 
 | |
|      !   if(iaptype.eq.1 .or. iaptype.eq.2 ) then ! AP,???,??? 
 | |
|      !      apmask=0
 | |
|      !      apmask(88:115)=1    ! first 28 bits are AP
 | |
|      !      apmask(144)=1       ! not free text
 | |
|      !      llrap=llr
 | |
|      !      if(iaptype.eq.1) llrap(88:115)=apmag*mcq
 | |
|      !      if(iaptype.eq.2) llrap(88:115)=apmag*apsym(1:28)
 | |
|      !      llrap(116:117)=llra(116:117)  
 | |
|      !      llrap(142:143)=llra(142:143)
 | |
|      !      llrap(144)=-apmag
 | |
|      !   endif
 | |
|      !   if(iaptype.eq.3) then   ! mycall, dxcall, ???
 | |
|      !      apmask=0
 | |
|      !      apmask(88:115)=1   ! mycall
 | |
|      !      apmask(116:143)=1  ! hiscall
 | |
|      !      apmask(144)=1      ! not free text
 | |
|      !      llrap=llr
 | |
|      !      llrap(88:143)=apmag*apsym(1:56)
 | |
|      !      llrap(144)=-apmag
 | |
|      !   endif
 | |
|      !   if(iaptype.eq.4 .or. iaptype.eq.5 .or. iaptype.eq.6) then  
 | |
|      !      apmask=0
 | |
|      !      apmask(88:115)=1   ! mycall
 | |
|      !      apmask(116:143)=1  ! hiscall
 | |
|      !      apmask(144:159)=1  ! RRR or 73 or RR73
 | |
|      !      llrap=llr
 | |
|      !      llrap(88:143)=apmag*apsym(1:56)
 | |
|      !      if(iaptype.eq.4) llrap(144:159)=apmag*mrrr 
 | |
|      !      if(iaptype.eq.5) llrap(144:159)=apmag*m73 
 | |
|      !      if(iaptype.eq.6) llrap(144:159)=apmag*mrr73 
 | |
|      !   endif
 | |
|      !   if(iaptype.eq.7) then   ! ???, dxcall, ???
 | |
|      !      apmask=0
 | |
|      !      apmask(116:143)=1  ! hiscall
 | |
|      !      apmask(144)=1      ! not free text
 | |
|      !      llrap=llr
 | |
|      !      llrap(115)=llra(115)
 | |
|      !      llrap(116:143)=apmag*apsym(29:56)
 | |
|      !      llrap(144)=-apmag
 | |
|      !   endif
 | |
|      !endif
 | |
| 
 | |
|      cw=0
 | |
|      call timer('bpd174  ',0)
 | |
|      call bpdecode174(llrap,apmask,max_iterations,decoded,cw,nharderrors,  &
 | |
|           niterations)
 | |
|      call timer('bpd174  ',1)
 | |
| 
 | |
|      if(NWRITELOG.eq.1) then
 | |
|        open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|        write(99,*) '> bpd174 ', ipass, nharderrors, dmin
 | |
|        close(99) 
 | |
|      endif
 | |
| 
 | |
|      dmin=0.0
 | |
|      if(ndepth.eq.3 .and. nharderrors.lt.0) then
 | |
|         ndeep=3
 | |
|         if(abs(nfqso-f1).le.napwid .or. abs(nftx-f1).le.napwid) then
 | |
|           if((ipass.eq.3 .or. ipass.eq.4) .and. .not.nagain) then
 | |
|             ndeep=3 
 | |
|           else   
 | |
|             ndeep=4  
 | |
|           endif
 | |
|         endif
 | |
|         if(nagain) ndeep=5
 | |
|         call timer('osd174  ',0)
 | |
|         call osd174(llrap,apmask,ndeep,decoded,cw,nharderrors,dmin)
 | |
|         call timer('osd174  ',1)
 | |
|      endif
 | |
|      nbadcrc=1
 | |
|      message='                      '
 | |
|      xsnr=-99.0
 | |
| 
 | |
|      if(NWRITELOG.eq.1) then
 | |
|        open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|        write(99,*) '> osd174', ipass, nharderrors, dmin, nharderrors + dmin, sync
 | |
|        close(99) 
 | |
|      endif
 | |
| 
 | |
|      if(count(cw.eq.0).eq.174) cycle           !Reject the all-zero codeword
 | |
|      if(nharderrors.ge.0 .and. nharderrors+dmin.lt.60.0 .and. &        
 | |
|         .not.(sync.lt.2.0 .and. nharderrors.gt.35)      .and. &
 | |
|         .not.(ipass.gt.2 .and. nharderrors.gt.39)       .and. &
 | |
|         .not.(ipass.eq.4 .and. nharderrors.gt.30)             &
 | |
|        ) then
 | |
|         call chkcrc12a(decoded,nbadcrc)
 | |
| 
 | |
|         if(NWRITELOG.eq.1) then
 | |
|           open(99, file="./js8.log", status="old", position="append", action="write")
 | |
|           write(99,*) '> crc', decoded 
 | |
|           if(nbadcrc.eq.1) then
 | |
|             write(99,*) '> crc failed'
 | |
|           endif
 | |
|           close(99) 
 | |
|         endif
 | |
|      else
 | |
|         nharderrors=-1
 | |
|         cycle 
 | |
|      endif
 | |
|      i3bit=4*decoded(73) + 2*decoded(74) + decoded(75)
 | |
| 
 | |
|      if(nbadcrc.eq.0) then
 | |
|         decoded0=decoded
 | |
|         call extractmessage174(decoded,origmsg,ncrcflag)
 | |
|         decoded=decoded0
 | |
| 
 | |
|         message(1:12)=origmsg(1:12)
 | |
|         call genjs8(message,mygrid6,bcontest,i3bit,msgsent,msgbits,itone)
 | |
|         if(lsubtract) call subtractjs8(dd0,itone,f1,xdt2)
 | |
|         xsig=0.0
 | |
|         xnoi=0.0
 | |
|         do i=1,NN
 | |
|            xsig=xsig+s2(itone(i),i)**2
 | |
|            ios=mod(itone(i)+4,7)
 | |
|            xnoi=xnoi+s2(ios,i)**2
 | |
|         enddo
 | |
|         xsnr=0.001
 | |
|         if(xnoi.gt.0 .and. xnoi.lt.xsig) xsnr=xsig/xnoi-1.0
 | |
|         xsnr=10.0*log10(xsnr)-27.0
 | |
|         xsnr2=db(xsig/xbase - 1.0) - 32.0
 | |
|         if(.not.nagain) xsnr=xsnr2
 | |
|         if(xsnr .lt. -24.0) xsnr=-24.0
 | |
| 
 | |
|         msg37=origmsg//'               '
 | |
| 
 | |
|         msg37(22:22) = char(48 + i3bit)
 | |
|         
 | |
|         return
 | |
|      endif
 | |
|   enddo
 | |
| 
 | |
|   return
 | |
| end subroutine js8dec
 |