implement new buffer input / output api
This commit is contained in:
@ -1,19 +1,34 @@
|
||||
from pycsdr import Buffer
|
||||
|
||||
import logging
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class Chain(object):
|
||||
def __init__(self, *workers):
|
||||
self.input = None
|
||||
self.output = None
|
||||
self.workers = workers
|
||||
stage = None
|
||||
for w in self.workers:
|
||||
if stage is not None:
|
||||
w.setInput(stage.getBuffer())
|
||||
stage = w
|
||||
self.buffer = stage.getBuffer()
|
||||
for i in range(1, len(self.workers)):
|
||||
self._connect(self.workers[i - 1], self.workers[i])
|
||||
|
||||
def _connect(self, w1, w2):
|
||||
buffer = Buffer()
|
||||
w1.setOutput(buffer)
|
||||
w2.setInput(buffer)
|
||||
|
||||
def stop(self):
|
||||
for w in self.workers:
|
||||
w.stop()
|
||||
|
||||
def setInput(self, buffer):
|
||||
if self.input == buffer:
|
||||
return
|
||||
self.input = buffer
|
||||
self.workers[0].setInput(buffer)
|
||||
|
||||
def getBuffer(self):
|
||||
return self.buffer
|
||||
def setOutput(self, buffer):
|
||||
if self.output == buffer:
|
||||
return
|
||||
self.output = buffer
|
||||
self.workers[-1].setOutput(buffer)
|
||||
|
@ -1,25 +1,45 @@
|
||||
from csdr.chain import Chain
|
||||
from pycsdr import Fft, LogAveragePower, FftExchangeSides, CompressFftAdpcm
|
||||
from pycsdr import Fft, LogPower, LogAveragePower, FftExchangeSides, CompressFftAdpcm
|
||||
|
||||
import logging
|
||||
logger = logging.getLogger(__name__)
|
||||
logger.setLevel(logging.INFO)
|
||||
|
||||
|
||||
class FftAverager(Chain):
|
||||
def __init__(self, fft_size, fft_averages):
|
||||
self.fftSize = fft_size
|
||||
self.fftAverages = fft_averages
|
||||
self.worker = LogAveragePower(add_db=-70, fft_size=self.fftSize, avg_number=self.fftAverages)
|
||||
self.fftAverages = None
|
||||
self.worker = None
|
||||
self.input = None
|
||||
self.output = None
|
||||
self.setFftAverages(fft_averages)
|
||||
workers = [self.worker]
|
||||
super().__init__(*workers)
|
||||
|
||||
def setFftAverages(self, fft_averages):
|
||||
if self.fftAverages == fft_averages:
|
||||
return
|
||||
if fft_averages == 0 and self.fftAverages != 0:
|
||||
if self.worker is not None:
|
||||
self.worker.stop()
|
||||
self.worker = LogPower(add_db=70)
|
||||
if self.output is not None:
|
||||
self.worker.setOutput(self.output)
|
||||
if self.input is not None:
|
||||
self.worker.setInput(self.input)
|
||||
elif fft_averages != 0:
|
||||
if self.fftAverages == 0 or self.worker is None:
|
||||
if self.worker is not None:
|
||||
self.worker.stop()
|
||||
self.worker = LogAveragePower(add_db=-70, fft_size=self.fftSize, avg_number=fft_averages)
|
||||
if self.output is not None:
|
||||
self.worker.setOutput(self.output)
|
||||
if self.input is not None:
|
||||
self.worker.setInput(self.input)
|
||||
else:
|
||||
self.worker.setFftAverages(avg_number=fft_averages)
|
||||
self.workers = [self.worker]
|
||||
self.fftAverages = fft_averages
|
||||
# TODO replace worker with LogPower if fft_averages == 0
|
||||
self.worker.setFftAverages(avg_number=self.fftAverages)
|
||||
|
||||
|
||||
class FftChain(Chain):
|
||||
@ -32,7 +52,7 @@ class FftChain(Chain):
|
||||
self.blockSize = 0
|
||||
|
||||
self.fft = Fft(size=self.size, every_n_samples=self.blockSize)
|
||||
self.averager = FftAverager(fft_size=self.size, fft_averages=0)
|
||||
self.averager = FftAverager(fft_size=self.size, fft_averages=10)
|
||||
self.fftExchangeSides = FftExchangeSides(fft_size=self.size)
|
||||
workers = [
|
||||
self.fft,
|
||||
|
Reference in New Issue
Block a user