1
0
Fork 0
mirror of https://github.com/hb9fxq/gr-digitalhf synced 2024-12-22 15:10:00 +00:00

almost complete description of 188-110 App C

This commit is contained in:
cmayer 2018-11-06 20:54:58 +01:00
parent 39a8426822
commit 9298637d69

View file

@ -97,11 +97,36 @@ REINSERTED_PREAMBLE=n_psk(8, np.array(
6, 6,
4,4,4,4,4,6,0,2,4,0,4,0,4,2,0,6,4,4,4,4,4,6,0,2,4,0,4,0,4,2,0])) ## MP- 4,4,4,4,4,6,0,2,4,0,4,0,4,2,0,6,4,4,4,4,4,6,0,2,4,0,4,0,4,2,0])) ## MP-
## length 31 ## length 31
MINI_PROBE_PLUS=n_psk(8, np.array( MINI_PROBE=[n_psk(8, np.array([0,0,0,0,0,2,4,6,0,4,0,4,0,6,4,2,0,0,0,0,0,2,4,6,0,4,0,4,0,6,4])), ## sign = + (0)
[0,0,0,0,0,2,4,6,0,4,0,4,0,6,4,2,0,0,0,0,0,2,4,6,0,4,0,4,0,6,4])) n_psk(8, np.array([4,4,4,4,4,6,0,2,4,0,4,0,4,2,0,6,4,4,4,4,4,6,0,2,4,0,4,0,4,2,0]))] ## sign = - (1)
## length 31
MINI_PROBE_MINUS=n_psk(8, np.array( ## ---- di-bits ----------------------------------------------------------------
[4,4,4,4,4,6,0,2,4,0,4,0,4,2,0,6,4,4,4,4,4,6,0,2,4,0,4,0,4,2,0])) TO_DIBIT=[(0,0),(0,1),(1,1),(1,0)]
## ---- rate -------------------------------------------------------------------
TO_RATE={(0,0,0): {'baud': 0, 'bits_per_symbol': 0}, ## reserved
(0,0,1): {'baud': 3200, 'bits_per_symbol': 2, 'ci': MODE_QPSK},
(0,1,0): {'baud': 4800, 'bits_per_symbol': 3, 'ci': MODE_8PSK},
(0,1,1): {'baud': 6400, 'bits_per_symbol': 4, 'ci': MODE_16QAM},
(1,0,0): {'baud': 8000, 'bits_per_symbol': 5, 'ci': MODE_32QAM},
(1,0,1): {'baud': 9600, 'bits_per_symbol': 6, 'ci': MODE_64QAM},
(1,1,0): {'baud':12800, 'bits_per_symbol': 6, 'ci': MODE_64QAM},
(1,1,1): {'baud': 0, 'bits_per_symbol': 0}} ## reserved
## ---- interleaver ------------------------------------------------------------
TO_INTERLEAVER={(0,0,0): {'frames': -1, 'name': 'illegal'},
(0,0,1): {'frames': 1, 'name': 'Ultra Short (US)'},
(0,1,0): {'frames': 3, 'name': 'Very Short (VS)'},
(0,1,1): {'frames': 9, 'name': 'Short (S)'},
(1,0,0): {'frames': 18, 'name': 'Medium (M)'},
(1,0,1): {'frames': 36, 'name': 'Long (L)'},
(1,1,0): {'frames': 72, 'name': 'very Long (VL)'},
(1,1,1): {'frames': -1, 'name': 'illegal'}}
MP_COUNTER=[(0,0,1),
(0,1,0),
(0,1,1),
(1,0,0)]
## ---- physcal layer class ----------------------------------------------------- ## ---- physcal layer class -----------------------------------------------------
class PhysicalLayer(object): class PhysicalLayer(object):
@ -113,7 +138,6 @@ class PhysicalLayer(object):
self._frame_counter = -1 self._frame_counter = -1
self._constellations = [BPSK, QPSK, PSK8, QAM16, QAM32, QAM64] self._constellations = [BPSK, QPSK, PSK8, QAM16, QAM32, QAM64]
self._preamble = self.get_preamble() self._preamble = self.get_preamble()
self._scr_data = ScrambleData()
def get_constellations(self): def get_constellations(self):
return self._constellations return self._constellations
@ -129,14 +153,15 @@ class PhysicalLayer(object):
self._frame_counter) self._frame_counter)
## --- preamble frame ---- ## --- preamble frame ----
if self._frame_counter == -1: if self._frame_counter == -1:
self._preamble_offset = 0
return [self._preamble,MODE_BPSK,True,False] return [self._preamble,MODE_BPSK,True,False]
## ----- (re)inserted preamble ------ ## ----- (re)inserted preamble ------
if self._frame_counter == 0: if self._frame_counter == 0:
self.a = self.make_reinserted_preamble() self.a = self.make_reinserted_preamble(self._preamble_offset)
return [self.a, MODE_QPSK,False,False] return [self.a, MODE_QPSK,False,False]
if self._frame_counter >= 1: if self._frame_counter >= 1:
self.a = self.make_data_frame() self.a = self.make_data_frame()
return [self.a, MODE_64QAM,False,True] return [self.a, self._constellation_index,False,True]
def get_doppler(self, symbols, iq_samples): def get_doppler(self, symbols, iq_samples):
"""returns a tuple """returns a tuple
@ -153,12 +178,38 @@ class PhysicalLayer(object):
for s in symbols: for s in symbols:
print(s) print(s)
self._frame_counter = 0 self._frame_counter = 0
elif self._frame_counter >= 0 and self._frame_counter <5: ## -- reinserted preamble ---- elif self._frame_counter == 0: ## -- reinserted preamble ----
for s in symbols: ## decode D0,D1,D2
print(s) idx = np.arange(13)
z = np.array([np.mean(symbols[32+13*i+idx]) for i in range(3)])
d0d1d2 = map(np.uint8, np.mod(np.round(np.angle(z)/np.pi*2),4))
dibits = [TO_DIBIT[idx] for idx in d0d1d2]
self._mode = {'rate': tuple([x[0] for x in dibits]),
'interleaver': tuple([x[1] for x in dibits])}
print('======== rate,interleaver:',
TO_RATE[self._mode['rate']],
TO_INTERLEAVER[self._mode['interleaver']])
rate_info = TO_RATE[self._mode['rate']]
self._constellation_index = rate_info['ci']
print('constellation index', self._constellation_index)
scr = ScrambleData()
iscr = [scr.next(rate_info['bits_per_symbol']) for _ in range(256)]
if rate_info['ci'] > MODE_8PSK:
self._data_scramble = np.ones(256, dtype=np.complex64)
else:
constell = self._constellations[rate_info['ci']]
self._data_scramble = constell[iscr]
self._frame_counter += 1 self._frame_counter += 1
success = True success = True
else: ## ------------------------ data frame ---- elif self._frame_counter <=72: ## -- data -------------------
print(np.abs(symbols[:16]), symbols[-31:], np.mean(symbols[-31:]))
success = np.abs(np.mean(symbols[-31:])) > 0.5
if success:
self._frame_counter += 1
else:
self._frame_counter = -1
else: ## ------------------------ re-inserted preamble -------
## TODO
for s in symbols: for s in symbols:
print(s) print(s)
success = False success = False
@ -188,19 +239,28 @@ class PhysicalLayer(object):
print('success=', success, 'doppler=', doppler) print('success=', success, 'doppler=', doppler)
return success,doppler return success,doppler
def make_reinserted_preamble(self): def make_reinserted_preamble(self, offset):
a=np.array(zip(REINSERTED_PREAMBLE, """ offset= 0 -> 1st reinserted preamble
REINSERTED_PREAMBLE), offset=-72 -> all following reinserted preambles"""
a=np.array(zip(REINSERTED_PREAMBLE[offset:],
REINSERTED_PREAMBLE[offset:]),
dtype=[('symb', np.complex64), dtype=[('symb', np.complex64),
('scramble', np.complex64)]) ('scramble', np.complex64)])
a['symb'][32:32+3*13] = 0 ## D0,D1,D2 a['symb'][-72:-72+3*13] = 0 ## D0,D1,D2
return a return a
def make_data_frame(self): def make_data_frame(self):
a=np.zeros(256+31, dtype=[('symb', np.complex64), self._preamble_offset = -72 ## all following reinserted preambles start at index -72
('scramble', np.complex64)]) a=np.zeros(256+31, dtype=[('symb', np.complex64),
a['scramble'] = 1 ('scramble', np.complex64)])
a['symb'][256:] = MINI_PROBE_MINUS a['scramble'][:256] = self._data_scramble
a['scramble'][256:] = MINI_PROBE_MINUS n = self._frame_counter -1
m = n%18
if m == 0:
cnt = n//18
self._mp = (1,1,1,1,1,1,1,0)+self._mode['rate']+self._mode['interleaver']+MP_COUNTER[cnt]+(0,)
print('new mini-probe signs n=',n,'m=',m,self._mp)
a['symb'][256:] = MINI_PROBE[self._mp[m]]
a['scramble'][256:] = MINI_PROBE[self._mp[m]]
return a return a
@staticmethod @staticmethod