mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-10-31 15:47:10 -04:00
124 lines
3.4 KiB
Fortran
124 lines
3.4 KiB
Fortran
|
program JTMSKcode
|
||
|
|
||
|
! Generate simulated data for testing of JTMSK
|
||
|
|
||
|
use iso_c_binding, only: c_loc,c_size_t
|
||
|
use hashing
|
||
|
use packjt
|
||
|
character msg*22,decoded*22,bad*1,msgtype*13
|
||
|
integer*4 i4tone(234) !Channel symbols (values 0-1)
|
||
|
integer*1 e1(201)
|
||
|
integer*1 r1(201)
|
||
|
integer*1, target :: d8(13)
|
||
|
integer mettab(0:255,0:1) !Metric table for BPSK modulation
|
||
|
integer*1 i1hash(4)
|
||
|
integer*4 i4Msg6BitWords(12) !72-bit message as 6-bit words
|
||
|
character*72 c72
|
||
|
! real*8 twopi,dt,f0,f1,f,phi,dphi
|
||
|
real xp(29)
|
||
|
equivalence (ihash,i1hash)
|
||
|
data xp/0.500000, 0.401241, 0.309897, 0.231832, 0.168095, &
|
||
|
0.119704, 0.083523, 0.057387, 0.039215, 0.026890, &
|
||
|
0.018084, 0.012184, 0.008196, 0.005475, 0.003808, &
|
||
|
0.002481, 0.001710, 0.001052, 0.000789, 0.000469, &
|
||
|
0.000329, 0.000225, 0.000187, 0.000086, 0.000063, &
|
||
|
0.000017, 0.000091, 0.000032, 0.000045/
|
||
|
include 'testmsg.f90'
|
||
|
|
||
|
nargs=iargc()
|
||
|
if(nargs.ne.1) then
|
||
|
print*,'Usage: JTMSKcode "message"'
|
||
|
! print*,' JTMSKcode -t'
|
||
|
go to 999
|
||
|
endif
|
||
|
|
||
|
call getarg(1,msg)
|
||
|
nmsg=1
|
||
|
if(msg(1:2).eq."-t") nmsg=NTEST
|
||
|
|
||
|
! Get the metric table
|
||
|
bias=0.0
|
||
|
scale=20.0
|
||
|
xln2=log(2.0)
|
||
|
do i=128,156
|
||
|
x0=log(max(0.0001,2.0*xp(i-127)))/xln2
|
||
|
x1=log(max(0.001,2.0*(1.0-xp(i-127))))/xln2
|
||
|
mettab(i,0)=nint(scale*(x0-bias))
|
||
|
mettab(i,1)=nint(scale*(x1-bias))
|
||
|
mettab(256-i,0)=mettab(i,1)
|
||
|
mettab(256-i,1)=mettab(i,0)
|
||
|
enddo
|
||
|
do i=157,255
|
||
|
mettab(i,0)=mettab(156,0)
|
||
|
mettab(i,1)=mettab(156,1)
|
||
|
mettab(256-i,0)=mettab(i,1)
|
||
|
mettab(256-i,1)=mettab(i,0)
|
||
|
enddo
|
||
|
|
||
|
write(*,1010)
|
||
|
1010 format(" Message Decoded Err? Type"/ &
|
||
|
74("-"))
|
||
|
do imsg=1,nmsg
|
||
|
if(nmsg.gt.1) msg=testmsg(imsg)
|
||
|
call fmtmsg(msg,iz) !To upper case, collapse multiple blanks
|
||
|
ichk=0
|
||
|
call genmsk(msg,ichk,decoded,i4tone,itype) !Encode message into tone #s
|
||
|
msgtype=""
|
||
|
if(itype.eq.1) msgtype="Std Msg"
|
||
|
if(itype.eq.2) msgtype="Type 1 prefix"
|
||
|
if(itype.eq.3) msgtype="Type 1 suffix"
|
||
|
if(itype.eq.4) msgtype="Type 2 prefix"
|
||
|
if(itype.eq.5) msgtype="Type 2 suffix"
|
||
|
if(itype.eq.6) msgtype="Free text"
|
||
|
|
||
|
! Extract the data symbols, skipping over sync and parity bits
|
||
|
n1=35
|
||
|
n2=69
|
||
|
n3=94
|
||
|
|
||
|
r1(1:n1)=i4tone(11+1:11+n1)
|
||
|
r1(n1+1:n1+n2)=i4tone(23+n1+1:23+n1+n2)
|
||
|
r1(n1+n2+1:n1+n2+n3)=i4tone(35+n1+n2+1:35+n1+n2+n3)
|
||
|
where(r1.eq.0) r1=127
|
||
|
where(r1.eq.1) r1=-127
|
||
|
|
||
|
j=0
|
||
|
do i=1,99
|
||
|
j=j+1
|
||
|
e1(j)=r1(i)
|
||
|
j=j+1
|
||
|
e1(j)=r1(i+99)
|
||
|
enddo
|
||
|
|
||
|
nb1=87
|
||
|
call vit213(e1,nb1,mettab,d8,metric)
|
||
|
|
||
|
ihash=nhash(c_loc(d8),int(9,c_size_t),146)
|
||
|
ihash=2*iand(ihash,32767)
|
||
|
decoded=" "
|
||
|
if(d8(10).eq.i1hash(2) .and. d8(11).eq.i1hash(1)) then
|
||
|
write(c72,1012) d8(1:9)
|
||
|
1012 format(9b8.8)
|
||
|
read(c72,1014) i4Msg6BitWords
|
||
|
1014 format(12b6.6)
|
||
|
call unpackmsg(i4Msg6BitWords,decoded) !Unpack to get msgsent
|
||
|
endif
|
||
|
|
||
|
bad=" "
|
||
|
if(decoded.ne.msg) bad="*"
|
||
|
write(*,1020) imsg,msg,decoded,bad,itype,msgtype
|
||
|
1020 format(i2,'.',2x,a22,2x,a22,3x,a1,i3,": ",a13)
|
||
|
|
||
|
enddo
|
||
|
|
||
|
if(nmsg.eq.1) then
|
||
|
open(10,file='JTMSKcode.out',status='unknown')
|
||
|
do j=1,234
|
||
|
write(10,1030) j,i4tone(j)
|
||
|
1030 format(2i5)
|
||
|
enddo
|
||
|
close(10)
|
||
|
endif
|
||
|
|
||
|
999 end program JTMSKcode
|