update to match pycsdr chaanges
This commit is contained in:
parent
aeca8265c3
commit
7d7cec1ec3
@ -35,6 +35,7 @@ from owrx.audio.chopper import AudioChopper
|
|||||||
|
|
||||||
from csdr.pipe import Pipe
|
from csdr.pipe import Pipe
|
||||||
|
|
||||||
|
from pycsdr.modules import Buffer
|
||||||
from csdr.chain.demodulator import DemodulatorChain
|
from csdr.chain.demodulator import DemodulatorChain
|
||||||
from csdr.chain.fm import Fm
|
from csdr.chain.fm import Fm
|
||||||
from csdr.chain.am import Am
|
from csdr.chain.am import Am
|
||||||
@ -49,6 +50,7 @@ class Dsp(DirewolfConfigSubscriber):
|
|||||||
def __init__(self, output: Output):
|
def __init__(self, output: Output):
|
||||||
self.pycsdr_enabled = True
|
self.pycsdr_enabled = True
|
||||||
self.pycsdr_chain = None
|
self.pycsdr_chain = None
|
||||||
|
self.pycsdr_reader = None
|
||||||
self.buffer = None
|
self.buffer = None
|
||||||
|
|
||||||
self.samp_rate = 250000
|
self.samp_rate = 250000
|
||||||
@ -729,7 +731,10 @@ class Dsp(DirewolfConfigSubscriber):
|
|||||||
self.set_bpf(self.low_cut, self.high_cut)
|
self.set_bpf(self.low_cut, self.high_cut)
|
||||||
self.set_offset_freq(self.offset_freq)
|
self.set_offset_freq(self.offset_freq)
|
||||||
chain.setInput(self.buffer)
|
chain.setInput(self.buffer)
|
||||||
self.output.send_output("audio", chain.getOutput().read)
|
outputBuffer = Buffer(chain.getOutputFormat())
|
||||||
|
chain.setWriter(outputBuffer)
|
||||||
|
self.pycsdr_reader = outputBuffer.getReader()
|
||||||
|
self.output.send_output("audio", self.pycsdr_reader.read)
|
||||||
return
|
return
|
||||||
|
|
||||||
command_base = " | ".join(chain)
|
command_base = " | ".join(chain)
|
||||||
@ -824,6 +829,8 @@ class Dsp(DirewolfConfigSubscriber):
|
|||||||
if self.pycsdr_enabled and self.pycsdr_chain is not None:
|
if self.pycsdr_enabled and self.pycsdr_chain is not None:
|
||||||
self.pycsdr_chain.stop()
|
self.pycsdr_chain.stop()
|
||||||
self.pycsdr_chain = None
|
self.pycsdr_chain = None
|
||||||
|
self.pycsdr_reader.stop()
|
||||||
|
self.pycsdr_reader = None
|
||||||
if self.process is not None:
|
if self.process is not None:
|
||||||
try:
|
try:
|
||||||
os.killpg(os.getpgid(self.process.pid), signal.SIGTERM)
|
os.killpg(os.getpgid(self.process.pid), signal.SIGTERM)
|
||||||
|
@ -1,56 +1,65 @@
|
|||||||
from pycsdr.modules import Buffer
|
from pycsdr.modules import Buffer, Writer
|
||||||
|
|
||||||
|
|
||||||
class Chain:
|
class Chain:
|
||||||
def __init__(self, *workers):
|
def __init__(self, *workers):
|
||||||
self.input = None
|
self.input = None
|
||||||
self.output = None
|
self.output = None
|
||||||
|
self.reader = None
|
||||||
self.workers = list(workers)
|
self.workers = list(workers)
|
||||||
for i in range(1, len(self.workers)):
|
filtered = self._filterWorkers()
|
||||||
self._connect(self.workers[i - 1], self.workers[i])
|
for i in range(1, len(filtered)):
|
||||||
|
self._connect(filtered[i - 1], filtered[i])
|
||||||
|
|
||||||
|
def _filterWorkers(self):
|
||||||
|
return [w for w in self.workers if not isinstance(w, Chain) or not w.empty()]
|
||||||
|
|
||||||
|
def empty(self):
|
||||||
|
return len(self.workers) <= 0
|
||||||
|
|
||||||
def _connect(self, w1, w2):
|
def _connect(self, w1, w2):
|
||||||
if isinstance(w1, Chain):
|
writer = Buffer(w1.getOutputFormat())
|
||||||
buffer = w1.getOutput()
|
w1.setWriter(writer)
|
||||||
|
if isinstance(w2, Chain):
|
||||||
|
w2.setInput(writer)
|
||||||
else:
|
else:
|
||||||
buffer = Buffer(w1.getOutputFormat())
|
w2.setReader(writer.getReader())
|
||||||
w1.setOutput(buffer)
|
|
||||||
w2.setInput(buffer)
|
|
||||||
|
|
||||||
def stop(self):
|
def stop(self):
|
||||||
for w in self.workers:
|
for w in self.workers:
|
||||||
w.stop()
|
w.stop()
|
||||||
self.setInput(None)
|
if self.reader is not None:
|
||||||
if self.output is not None:
|
self.reader.stop()
|
||||||
self.output.stop()
|
self.reader = None
|
||||||
|
|
||||||
def setInput(self, buffer):
|
def setInput(self, buffer: Buffer):
|
||||||
if self.input == buffer:
|
if self.input == buffer:
|
||||||
return
|
return
|
||||||
self.input = buffer
|
self.input = buffer
|
||||||
if self.workers:
|
if self.workers:
|
||||||
self.workers[0].setInput(buffer)
|
firstWorker = self.workers[0]
|
||||||
|
if isinstance(firstWorker, Chain):
|
||||||
|
firstWorker.setInput(buffer)
|
||||||
|
else:
|
||||||
|
firstWorker.setReader(buffer.getReader())
|
||||||
else:
|
else:
|
||||||
self.output = self.input
|
self.output = self.input
|
||||||
|
|
||||||
def getOutput(self):
|
def setWriter(self, writer: Writer):
|
||||||
if self.output is None:
|
if self.output == writer:
|
||||||
|
return
|
||||||
|
self.output = writer
|
||||||
if self.workers:
|
if self.workers:
|
||||||
lastWorker = self.workers[-1]
|
lastWorker = self.workers[-1]
|
||||||
if isinstance(lastWorker, Chain):
|
lastWorker.setWriter(self.output)
|
||||||
self.output = lastWorker.getOutput()
|
|
||||||
else:
|
else:
|
||||||
self.output = Buffer(self.getOutputFormat())
|
raise BufferError("setOutput on empty chain")
|
||||||
self.workers[-1].setOutput(self.output)
|
|
||||||
else:
|
|
||||||
self.output = self.input
|
|
||||||
return self.output
|
|
||||||
|
|
||||||
def getOutputFormat(self):
|
def getOutputFormat(self):
|
||||||
if self.workers:
|
if self.workers:
|
||||||
return self.workers[-1].getOutputFormat()
|
return self.workers[-1].getOutputFormat()
|
||||||
else:
|
else:
|
||||||
return self.input.getOutputFormat()
|
raise BufferError("getOutputFormat on empty chain")
|
||||||
|
|
||||||
def replace(self, index, newWorker):
|
def replace(self, index, newWorker):
|
||||||
if index >= len(self.workers):
|
if index >= len(self.workers):
|
||||||
@ -60,36 +69,41 @@ class Chain:
|
|||||||
self.workers[index] = newWorker
|
self.workers[index] = newWorker
|
||||||
|
|
||||||
if index == 0:
|
if index == 0:
|
||||||
newWorker.setInput(self.input)
|
writer = self.input
|
||||||
else:
|
else:
|
||||||
previousWorker = self.workers[index - 1]
|
previousWorker = self.workers[index - 1]
|
||||||
if isinstance(previousWorker, Chain):
|
writer = Buffer(previousWorker.getOutputFormat())
|
||||||
newWorker.setInput(previousWorker.getOutput())
|
previousWorker.setWriter(writer)
|
||||||
|
|
||||||
|
if writer is not None:
|
||||||
|
if isinstance(newWorker, Chain):
|
||||||
|
newWorker.setInput(writer)
|
||||||
else:
|
else:
|
||||||
buffer = Buffer(previousWorker.getOutputFormat())
|
newWorker.setReader(writer.getReader())
|
||||||
previousWorker.setOutput(buffer)
|
|
||||||
newWorker.setInput(buffer)
|
|
||||||
|
|
||||||
if index < len(self.workers) - 1:
|
if index < len(self.workers) - 1:
|
||||||
nextWorker = self.workers[index + 1]
|
nextWorker = self.workers[index + 1]
|
||||||
if isinstance(newWorker, Chain):
|
writer = Buffer(newWorker.getOutputFormat())
|
||||||
nextWorker.setInput(newWorker.getOutput())
|
newWorker.setWriter(writer)
|
||||||
|
if isinstance(nextWorker, Chain):
|
||||||
|
nextWorker.setInput(writer)
|
||||||
else:
|
else:
|
||||||
buffer = Buffer(newWorker.getOutputFormat())
|
nextWorker.setReader(writer.getReader())
|
||||||
newWorker.setOutput(buffer)
|
|
||||||
nextWorker.setInput(buffer)
|
|
||||||
else:
|
else:
|
||||||
newWorker.setOutput(self.output)
|
if self.output is not None:
|
||||||
|
newWorker.setWriter(self.output)
|
||||||
|
|
||||||
def pump(self, write):
|
def pump(self, write):
|
||||||
output = self.getOutput()
|
if self.output is None:
|
||||||
|
self.setWriter(Buffer(self.getOutputFormat()))
|
||||||
|
self.reader = self.output.getReader()
|
||||||
|
|
||||||
def copy():
|
def copy():
|
||||||
run = True
|
run = True
|
||||||
while run:
|
while run:
|
||||||
data = None
|
data = None
|
||||||
try:
|
try:
|
||||||
data = output.read()
|
data = self.reader.read()
|
||||||
except ValueError:
|
except ValueError:
|
||||||
pass
|
pass
|
||||||
if data is None or (isinstance(data, bytes) and len(data) == 0):
|
if data is None or (isinstance(data, bytes) and len(data) == 0):
|
||||||
|
@ -252,13 +252,13 @@ class SdrSource(ABC):
|
|||||||
def _getTcpSource(self):
|
def _getTcpSource(self):
|
||||||
with self.modificationLock:
|
with self.modificationLock:
|
||||||
if self.tcpSource is None:
|
if self.tcpSource is None:
|
||||||
self.tcpSource = TcpSource(self.port)
|
self.tcpSource = TcpSource(self.port, Format.COMPLEX_FLOAT)
|
||||||
return self.tcpSource
|
return self.tcpSource
|
||||||
|
|
||||||
def getBuffer(self):
|
def getBuffer(self):
|
||||||
if self.buffer is None:
|
if self.buffer is None:
|
||||||
self.buffer = Buffer(Format.COMPLEX_FLOAT)
|
self.buffer = Buffer(Format.COMPLEX_FLOAT)
|
||||||
self._getTcpSource().setOutput(self.buffer)
|
self._getTcpSource().setWriter(self.buffer)
|
||||||
return self.buffer
|
return self.buffer
|
||||||
|
|
||||||
def getCommandValues(self):
|
def getCommandValues(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user