-
Notifications
You must be signed in to change notification settings - Fork 62
/
Copy pathpocsagreceiver.lua
55 lines (46 loc) · 2.11 KB
/
pocsagreceiver.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
48
49
50
51
52
53
54
55
---
-- Demodulate and decode POCSAG messages from a baseband, 4.5 kHz shift FSK
-- modulated complex-valued signal.
--
-- @category Receivers
-- @block POCSAGReceiver
--
-- @signature in:ComplexFloat32 > out:POCSAGMessageType
--
-- @usage
-- local receiver = radio.POCSAGReceiver()
-- local snk = radio.JSONSink()
-- top:connect(src, receiver, snk)
local block = require('radio.core.block')
local types = require('radio.types')
local blocks = require('radio.blocks')
local POCSAGReceiver = block.factory("POCSAGReceiver", blocks.CompositeBlock)
function POCSAGReceiver:instantiate(baudrate)
blocks.CompositeBlock.instantiate(self)
local baudrate = baudrate or 1200
assert(baudrate == 512 or baudrate == 1200, "Only 512 and 1200 baudrates supported.")
local space_filter = blocks.ComplexBandpassFilterBlock(129, {3500, 5500})
local space_magnitude = blocks.ComplexMagnitudeBlock()
local mark_filter = blocks.ComplexBandpassFilterBlock(129, {-5500, -3500})
local mark_magnitude = blocks.ComplexMagnitudeBlock()
local subtractor = blocks.SubtractBlock()
local data_filter = blocks.LowpassFilterBlock(128, baudrate)
local clock_recoverer = blocks.ZeroCrossingClockRecoveryBlock(baudrate)
local sampler = blocks.SamplerBlock()
local bit_slicer = blocks.SlicerBlock()
local framer = blocks.POCSAGFramerBlock()
local decoder = blocks.POCSAGDecoderBlock()
self:connect(space_filter, space_magnitude)
self:connect(mark_filter, mark_magnitude)
self:connect(mark_magnitude, 'out', subtractor, 'in1')
self:connect(space_magnitude, 'out', subtractor, 'in2')
self:connect(subtractor, data_filter, clock_recoverer)
self:connect(data_filter, 'out', sampler, 'data')
self:connect(clock_recoverer, 'out', sampler, 'clock')
self:connect(sampler, bit_slicer, framer, decoder)
self:add_type_signature({block.Input("in", types.ComplexFloat32)}, {block.Output("out", blocks.POCSAGDecoderBlock.POCSAGMessageType)})
self:connect(self, "in", space_filter, "in")
self:connect(self, "in", mark_filter, "in")
self:connect(self, "out", decoder, "out")
end
return POCSAGReceiver