2021-09-20 16:14:23 +02:00
|
|
|
from csdr.chain.demodulator import BaseDemodulatorChain, FixedAudioRateChain, FixedIfSampleRateChain, DialFrequencyReceiver, MetaProvider, SlotFilterChain
|
2021-09-09 15:11:33 +02:00
|
|
|
from pycsdr.modules import FmDemod, Agc, Writer, Buffer
|
2021-07-31 00:10:10 +02:00
|
|
|
from pycsdr.types import Format
|
2021-08-10 14:03:49 +02:00
|
|
|
from digiham.modules import DstarDecoder, DcBlock, FskDemodulator, GfskDemodulator, DigitalVoiceFilter, MbeSynthesizer, NarrowRrcFilter, NxdnDecoder, DmrDecoder, WideRrcFilter, YsfDecoder
|
2021-07-31 00:10:10 +02:00
|
|
|
from digiham.ambe import Modes
|
2021-09-09 15:11:33 +02:00
|
|
|
from owrx.meta import MetaParser
|
2021-07-30 00:06:21 +02:00
|
|
|
|
|
|
|
|
2021-09-20 16:14:23 +02:00
|
|
|
class DigihamChain(BaseDemodulatorChain, FixedIfSampleRateChain, FixedAudioRateChain, DialFrequencyReceiver, MetaProvider):
|
2021-08-10 14:03:49 +02:00
|
|
|
def __init__(self, fskDemodulator, decoder, mbeMode, filter=None, codecserver: str = ""):
|
|
|
|
self.decoder = decoder
|
2021-07-31 00:10:10 +02:00
|
|
|
if codecserver is None:
|
|
|
|
codecserver = ""
|
2021-08-06 20:02:59 +02:00
|
|
|
agc = Agc(Format.SHORT)
|
|
|
|
agc.setMaxGain(30)
|
|
|
|
agc.setInitialGain(3)
|
2021-08-10 14:03:49 +02:00
|
|
|
workers = [FmDemod(), DcBlock()]
|
|
|
|
if filter is not None:
|
|
|
|
workers += [filter]
|
|
|
|
workers += [
|
|
|
|
fskDemodulator,
|
|
|
|
decoder,
|
|
|
|
MbeSynthesizer(mbeMode, codecserver),
|
2021-07-31 00:10:10 +02:00
|
|
|
DigitalVoiceFilter(),
|
2021-08-06 20:02:59 +02:00
|
|
|
agc
|
2021-07-30 00:06:21 +02:00
|
|
|
]
|
2021-09-09 15:11:33 +02:00
|
|
|
self.metaParser = None
|
2021-09-09 22:24:41 +02:00
|
|
|
self.dialFrequency = None
|
2021-08-23 14:25:28 +02:00
|
|
|
super().__init__(workers)
|
|
|
|
|
|
|
|
def getFixedIfSampleRate(self):
|
|
|
|
return 48000
|
|
|
|
|
|
|
|
def getFixedAudioRate(self):
|
|
|
|
return 8000
|
2021-07-30 00:06:21 +02:00
|
|
|
|
2021-09-20 16:14:23 +02:00
|
|
|
def setMetaWriter(self, writer: Writer) -> None:
|
2021-09-09 15:11:33 +02:00
|
|
|
if self.metaParser is None:
|
|
|
|
self.metaParser = MetaParser()
|
|
|
|
buffer = Buffer(Format.CHAR)
|
|
|
|
self.decoder.setMetaWriter(buffer)
|
|
|
|
self.metaParser.setReader(buffer.getReader())
|
2021-09-09 22:24:41 +02:00
|
|
|
if self.dialFrequency is not None:
|
|
|
|
self.metaParser.setDialFrequency(self.dialFrequency)
|
2021-09-09 15:11:33 +02:00
|
|
|
self.metaParser.setWriter(writer)
|
2021-07-30 00:06:21 +02:00
|
|
|
|
2021-08-23 14:25:28 +02:00
|
|
|
def supportsSquelch(self):
|
|
|
|
return False
|
|
|
|
|
2021-09-09 15:11:33 +02:00
|
|
|
def setDialFrequency(self, frequency: int) -> None:
|
2021-09-09 22:24:41 +02:00
|
|
|
self.dialFrequency = frequency
|
2021-09-09 15:11:33 +02:00
|
|
|
if self.metaParser is None:
|
|
|
|
return
|
|
|
|
self.metaParser.setDialFrequency(frequency)
|
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
if self.metaParser is not None:
|
|
|
|
self.metaParser.stop()
|
|
|
|
super().stop()
|
|
|
|
|
2021-08-01 00:49:20 +02:00
|
|
|
|
|
|
|
class Dstar(DigihamChain):
|
2021-07-30 00:06:21 +02:00
|
|
|
def __init__(self, codecserver: str = ""):
|
2021-08-10 14:03:49 +02:00
|
|
|
super().__init__(
|
|
|
|
fskDemodulator=FskDemodulator(samplesPerSymbol=10),
|
|
|
|
decoder=DstarDecoder(),
|
|
|
|
mbeMode=Modes.DStarMode,
|
|
|
|
codecserver=codecserver
|
|
|
|
)
|
2021-08-01 00:49:20 +02:00
|
|
|
|
|
|
|
|
|
|
|
class Nxdn(DigihamChain):
|
|
|
|
def __init__(self, codecserver: str = ""):
|
2021-08-10 14:03:49 +02:00
|
|
|
super().__init__(
|
|
|
|
fskDemodulator=GfskDemodulator(samplesPerSymbol=20),
|
|
|
|
decoder=NxdnDecoder(),
|
|
|
|
mbeMode=Modes.NxdnMode,
|
|
|
|
filter=NarrowRrcFilter(),
|
|
|
|
codecserver=codecserver
|
|
|
|
)
|
2021-08-06 20:02:59 +02:00
|
|
|
|
2021-08-07 00:09:40 +02:00
|
|
|
|
2021-09-20 16:14:23 +02:00
|
|
|
class Dmr(DigihamChain, SlotFilterChain):
|
2021-08-06 20:02:59 +02:00
|
|
|
def __init__(self, codecserver: str = ""):
|
2021-08-10 14:03:49 +02:00
|
|
|
super().__init__(
|
|
|
|
fskDemodulator=GfskDemodulator(samplesPerSymbol=10),
|
|
|
|
decoder=DmrDecoder(),
|
|
|
|
mbeMode=Modes.DmrMode,
|
|
|
|
filter=WideRrcFilter(),
|
|
|
|
codecserver=codecserver,
|
|
|
|
)
|
|
|
|
|
|
|
|
def setSlotFilter(self, slotFilter: int) -> None:
|
|
|
|
self.decoder.setSlotFilter(slotFilter)
|
2021-08-07 00:09:40 +02:00
|
|
|
|
2021-08-10 14:03:49 +02:00
|
|
|
|
|
|
|
class Ysf(DigihamChain):
|
|
|
|
def __init__(self, codecserver: str = ""):
|
|
|
|
super().__init__(
|
|
|
|
fskDemodulator=GfskDemodulator(samplesPerSymbol=10),
|
|
|
|
decoder=YsfDecoder(),
|
|
|
|
mbeMode=Modes.YsfMode,
|
|
|
|
filter=WideRrcFilter(),
|
|
|
|
codecserver=codecserver
|
|
|
|
)
|