-
Notifications
You must be signed in to change notification settings - Fork 62
/
amsynchronousdemodulator.lua
47 lines (40 loc) · 1.79 KB
/
amsynchronousdemodulator.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
---
-- Demodulate a double-sideband amplitude modulated complex-valued signal with
-- a synchronous detector. The input signal should be centered on the specified
-- intermediate frequency.
--
-- $$ y[n] = \text{AMDemodulate}(x[n], \text{IF}, \text{bandwidth}) $$
--
-- @category Demodulation
-- @block AMSynchronousDemodulator
-- @tparam number ifreq Intermediate frequency in Hz
-- @tparam[opt=5e3] number bandwidth Bandwidth in Hz
--
-- @signature in:ComplexFloat32 > out:Float32
--
-- @usage
-- -- AM demodulator with 100 kHz IF, 5 kHz bandwidth
-- local demod = radio.AMSynchronousDemodulator(100e3, 5e3)
local block = require('radio.core.block')
local types = require('radio.types')
local blocks = require('radio.blocks')
local AMSynchronousDemodulator = block.factory("AMSynchronousDemodulator", blocks.CompositeBlock)
function AMSynchronousDemodulator:instantiate(ifreq, bandwidth)
blocks.CompositeBlock.instantiate(self)
assert(ifreq, "Missing argument #1 (ifreq)")
bandwidth = bandwidth or 5e3
local rf_filter = blocks.ComplexBandpassFilterBlock(129, {ifreq - bandwidth, ifreq + bandwidth})
local pll = blocks.PLLBlock(1000, ifreq - 100, ifreq + 100)
local mixer = blocks.MultiplyConjugateBlock()
local am_demod = blocks.ComplexToRealBlock()
local dcr_filter = blocks.SinglepoleHighpassFilterBlock(100)
local af_filter = blocks.LowpassFilterBlock(128, bandwidth)
self:connect(rf_filter, pll)
self:connect(rf_filter, 'out', mixer, 'in1')
self:connect(pll, 'out', mixer, 'in2')
self:connect(mixer, am_demod, dcr_filter, af_filter)
self:add_type_signature({block.Input("in", types.ComplexFloat32)}, {block.Output("out", types.Float32)})
self:connect(self, "in", rf_filter, "in")
self:connect(self, "out", af_filter, "out")
end
return AMSynchronousDemodulator