summaryrefslogtreecommitdiff
path: root/gr-digital/lib
diff options
context:
space:
mode:
authorBen Reynwar2012-09-30 17:23:19 -0700
committerBen Reynwar2012-09-30 17:23:19 -0700
commit33d9cf8800d3b4c0bbbff09b7588c21ed35e3220 (patch)
tree8c34108db2e071d1ab9dd7143b97b3c2da725221 /gr-digital/lib
parent96f181f29afbae43fa449297a232637fadf426d0 (diff)
downloadgnuradio-33d9cf8800d3b4c0bbbff09b7588c21ed35e3220.tar.gz
gnuradio-33d9cf8800d3b4c0bbbff09b7588c21ed35e3220.tar.bz2
gnuradio-33d9cf8800d3b4c0bbbff09b7588c21ed35e3220.zip
digital: Fixed scaling bug in QAM constellations.
Diffstat (limited to 'gr-digital/lib')
-rw-r--r--gr-digital/lib/digital_constellation.cc13
1 files changed, 13 insertions, 0 deletions
diff --git a/gr-digital/lib/digital_constellation.cc b/gr-digital/lib/digital_constellation.cc
index d9a53c493..da79f2caa 100644
--- a/gr-digital/lib/digital_constellation.cc
+++ b/gr-digital/lib/digital_constellation.cc
@@ -49,6 +49,17 @@ digital_constellation::digital_constellation (std::vector<gr_complex> constellat
d_rotational_symmetry(rotational_symmetry),
d_dimensionality(dimensionality)
{
+ // Scale constellation points so that average magnitude is 1.
+ float summed_mag = 0;
+ unsigned int constsize = d_constellation.size();
+ for (unsigned int i=0; i<constsize; i++) {
+ gr_complex c = d_constellation[i];
+ summed_mag += sqrt(c.real()*c.real() + c.imag()*c.imag());
+ }
+ d_scalefactor = constsize/summed_mag;
+ for (unsigned int i=0; i<constsize; i++) {
+ d_constellation[i] = d_constellation[i]*d_scalefactor;
+ }
if (pre_diff_code.size() == 0)
d_apply_pre_diff_code = false;
else if (pre_diff_code.size() != constellation.size())
@@ -293,6 +304,8 @@ digital_constellation_rect::digital_constellation_rect (std::vector<gr_complex>
n_real_sectors(real_sectors), n_imag_sectors(imag_sectors),
d_width_real_sectors(width_real_sectors), d_width_imag_sectors(width_imag_sectors)
{
+ d_width_real_sectors *= d_scalefactor;
+ d_width_imag_sectors *= d_scalefactor;
find_sector_values();
}