aboutsummaryrefslogtreecommitdiff
path: root/octave/qam16.m
blob: 5b0f047cba94258112939c416cb4862f43e99fbf (plain)
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
% qam16.m
% David Rowe May 2020
%
% Octave QAM16 functions

1;

function symbol = qam16_mod(constellation, four_bits)
    bits_decimal = sum(four_bits .* [8 4 2 1]);
    symbol = constellation(bits_decimal+1);
endfunction

function four_bits = qam16_demod(constellation, symbol, amp_est=1)
    assert (amp_est != 0);
    symbol /= amp_est;
    dist = abs(symbol - constellation(1:16));
    [tmp decimal] = min(dist);
    four_bits = zeros(1,4);
    for i=1:4
      four_bits(1,5-i) = bitand(bitshift(decimal-1,1-i),1);
    end
endfunction

function test_qam16_mod_demod(constellation)
    for decimal=0:15
      tx_bits = zeros(1,4);
      for i=1:4
        tx_bits(1,5-i) = bitand(bitshift(decimal-1,1-i),1);
      end
      symbol = qam16_mod(constellation, tx_bits);
      rx_bits = qam16_demod(constellation,symbol);
      assert(tx_bits == rx_bits);
    end
endfunction