From 2142b7e38bc52fb7de0a1b1a9da8cded5016f3cc Mon Sep 17 00:00:00 2001 From: Francesco Sacchi Date: Sun, 1 Dec 2013 19:23:38 +0100 Subject: [PATCH] Add first 16-qam modulator --- qam.py | 56 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 qam.py diff --git a/qam.py b/qam.py new file mode 100644 index 0000000..d714d6d --- /dev/null +++ b/qam.py @@ -0,0 +1,56 @@ +import wave +from math import sin +from math import cos +from math import pi +import struct + +class qam: + def __init__(self, filename, samplerate=44100): + w = wave.open(filename, "wb") + w.setnchannels(1) + w.setframerate(samplerate) + w.setsampwidth(2) + self.w = w + + self.samplerate = samplerate + self.carrier = 21000 + self.symrate = 14700 + self.symlen = self.samplerate/self.symrate + self.t = 0 + self.bit_per_level = 3 + levels = 1 << self.bit_per_level; + self.amps = [(1,0), (1,1), (0,1), (-1,1), (-1,0), (-1,-1), (0,-1), (1,-1)] + self.levels = levels + self.carry = 0 + self.carry_len = 0 + + def _mod(self, l): + assert(l < self.levels) + + for j in range(self.symlen): + i = self.amps[l][0] * sin(2 * pi * self.carrier * self.t / self.samplerate) + q = self.amps[l][1] * cos(2 * pi * self.carrier * self.t / self.samplerate) + self.t += 1 + + c = (i + q) / 2 + c = int((c + 1) / 2 * 65535) - 32768 + c = struct.pack("> i) & 1 + self.carry_len += 1 + if self.carry_len == self.bit_per_level: + self._mod(self.carry) + self.carry_len = 0 + self.carry = 0 + +q = qam("qam.wav") +f = open("gpl-3.0.txt") +for c in f: + q.modulate(c) + +print "done."