diff options
author | Nao Pross <np@0hm.ch> | 2021-12-13 18:31:10 +0100 |
---|---|---|
committer | Nao Pross <np@0hm.ch> | 2021-12-13 18:31:10 +0100 |
commit | 24b37dbe14c1685619961e3595c48329f7249a2c (patch) | |
tree | 21d62a5d6de3206761e9affeebfab5ba720cd739 /src/gr-fadingui/python/ber.py | |
parent | Clean up GUI code, set up network constellation plots (diff) | |
parent | Ber block mit socket ergänzt (diff) | |
download | Fading-24b37dbe14c1685619961e3595c48329f7249a2c.tar.gz Fading-24b37dbe14c1685619961e3595c48329f7249a2c.zip |
Merge remote-tracking branch 'origin/master'
Diffstat (limited to 'src/gr-fadingui/python/ber.py')
-rw-r--r-- | src/gr-fadingui/python/ber.py | 41 |
1 files changed, 37 insertions, 4 deletions
diff --git a/src/gr-fadingui/python/ber.py b/src/gr-fadingui/python/ber.py index 5b71f35..205dcd4 100644 --- a/src/gr-fadingui/python/ber.py +++ b/src/gr-fadingui/python/ber.py @@ -19,6 +19,8 @@ # Boston, MA 02110-1301, USA. # +import socket +from urllib.parse import urlparse import numpy as np from gnuradio import gr @@ -32,7 +34,7 @@ class ber(gr.sync_block): """ docstring for block ber """ - def __init__(self, vgl, vlen): + def __init__(self, vgl, vlen, address): gr.sync_block.__init__(self, name="ber", in_sig=[np.dtype(str(vlen) + "b")], @@ -40,9 +42,34 @@ class ber(gr.sync_block): self.vgl=vgl self.vlen=vlen + # Create a socket and parse remote machine url + self.socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) + self.url = urlparse(address) + self.srv = (self.url.hostname, self.url.port) + + + def send(self, data): + """ + Send the data to self.srv + + @param data Data as python bytes + @return Number of bytes that were actually sent + """ + assert type(data) == bytes + return self.socket.sendto(data, self.srv) + + def encode(self, data): + """ + Encode the data into a dead simple format + """ + # FIXME: this could be (very) slow, is there a faster way with numpy? + # Maybe numpy.array2string + return bytes(str(data) + "\n", "ascii") + + def work(self, input_items, output_items): - inp = input_items[0] + log.debug(f"Length: {len(inp)}") log.debug(f"Inp_vector:{inp}") @@ -52,7 +79,13 @@ class ber(gr.sync_block): ber = sum(np.unpackbits(v)) trueber = ber - 32 - log.debug(f"BER {trueber if trueber > 0 else 0} in Paket {i}") + if trueber < 0: + trueber = 0 + log.debug(f"BER {trueber} in Paket {i}") + + self.send(self.encode(trueber)) + + return len(inp) - return len(input_items[0]) + #return len(input_items[0]) |