2021-09-27 17:46:19 +02:00
|
|
|
from csdr.chain.demodulator import BaseDemodulatorChain, FixedIfSampleRateChain, HdAudio, DeemphasisTauChain
|
2021-08-23 14:25:28 +02:00
|
|
|
from pycsdr.modules import AmDemod, DcBlock, FmDemod, Limit, NfmDeemphasis, Agc, WfmDeemphasis, FractionalDecimator, RealPart
|
|
|
|
from pycsdr.types import Format, AgcProfile
|
|
|
|
|
|
|
|
|
|
|
|
class Am(BaseDemodulatorChain):
|
|
|
|
def __init__(self):
|
|
|
|
agc = Agc(Format.FLOAT)
|
|
|
|
agc.setProfile(AgcProfile.SLOW)
|
|
|
|
agc.setInitialGain(200)
|
|
|
|
workers = [
|
|
|
|
AmDemod(),
|
|
|
|
DcBlock(),
|
|
|
|
agc,
|
|
|
|
]
|
|
|
|
|
|
|
|
super().__init__(workers)
|
|
|
|
|
|
|
|
|
|
|
|
class NFm(BaseDemodulatorChain):
|
|
|
|
def __init__(self, sampleRate: int):
|
2021-09-06 15:05:33 +02:00
|
|
|
self.sampleRate = sampleRate
|
2021-08-23 14:25:28 +02:00
|
|
|
agc = Agc(Format.FLOAT)
|
|
|
|
agc.setProfile(AgcProfile.SLOW)
|
|
|
|
agc.setMaxGain(3)
|
|
|
|
workers = [
|
|
|
|
FmDemod(),
|
|
|
|
Limit(),
|
|
|
|
NfmDeemphasis(sampleRate),
|
|
|
|
agc,
|
|
|
|
]
|
|
|
|
super().__init__(workers)
|
|
|
|
|
2021-09-06 15:05:33 +02:00
|
|
|
def setSampleRate(self, sampleRate: int) -> None:
|
|
|
|
if sampleRate == self.sampleRate:
|
|
|
|
return
|
|
|
|
self.sampleRate = sampleRate
|
|
|
|
self.replace(2, NfmDeemphasis(sampleRate))
|
|
|
|
|
2021-08-23 14:25:28 +02:00
|
|
|
|
2021-09-27 17:46:19 +02:00
|
|
|
class WFm(BaseDemodulatorChain, FixedIfSampleRateChain, DeemphasisTauChain, HdAudio):
|
2021-08-23 14:25:28 +02:00
|
|
|
def __init__(self, sampleRate: int, tau: float):
|
2021-09-27 17:46:19 +02:00
|
|
|
self.sampleRate = sampleRate
|
|
|
|
self.tau = tau
|
2021-08-23 14:25:28 +02:00
|
|
|
workers = [
|
|
|
|
FmDemod(),
|
|
|
|
Limit(),
|
2021-09-27 17:46:19 +02:00
|
|
|
FractionalDecimator(Format.FLOAT, 200000.0 / self.sampleRate, prefilter=True),
|
|
|
|
WfmDeemphasis(self.sampleRate, self.tau),
|
2021-08-23 14:25:28 +02:00
|
|
|
]
|
|
|
|
super().__init__(workers)
|
|
|
|
|
|
|
|
def getFixedIfSampleRate(self):
|
|
|
|
return 200000
|
|
|
|
|
2021-09-27 17:46:19 +02:00
|
|
|
def setDeemphasisTau(self, tau: float) -> None:
|
|
|
|
if tau == self.tau:
|
|
|
|
return
|
|
|
|
self.tau = tau
|
|
|
|
self.replace(3, WfmDeemphasis(self.sampleRate, self.tau))
|
|
|
|
|
|
|
|
def setSampleRate(self, sampleRate: int) -> None:
|
|
|
|
if sampleRate == self.sampleRate:
|
|
|
|
return
|
|
|
|
self.sampleRate = sampleRate
|
|
|
|
self.replace(2, FractionalDecimator(Format.FLOAT, 200000.0 / self.sampleRate, prefilter=True))
|
|
|
|
self.replace(3, WfmDeemphasis(self.sampleRate, self.tau))
|
|
|
|
|
2021-08-23 14:25:28 +02:00
|
|
|
|
|
|
|
class Ssb(BaseDemodulatorChain):
|
|
|
|
def __init__(self):
|
|
|
|
workers = [
|
|
|
|
RealPart(),
|
|
|
|
Agc(Format.FLOAT),
|
|
|
|
]
|
|
|
|
super().__init__(workers)
|