aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/rfnoc
diff options
context:
space:
mode:
authorWade Fife <wade.fife@ettus.com>2021-10-25 12:53:19 -0500
committerAaron Rossetto <aaron.rossetto@ni.com>2021-10-27 07:56:09 -0700
commit4e6531f30648ede5be8f93fa49fdcd4973b73813 (patch)
tree92bc21a7a5d0a962cb2cce873ada1d8581b91739 /host/lib/rfnoc
parent170c3767da67ea7ad0f0103658d17590b080fe67 (diff)
downloaduhd-4e6531f30648ede5be8f93fa49fdcd4973b73813.tar.gz
uhd-4e6531f30648ede5be8f93fa49fdcd4973b73813.tar.bz2
uhd-4e6531f30648ede5be8f93fa49fdcd4973b73813.zip
siggen: Fix direction of rotation
The I and Q were swapped in sine_tone, which caused confusion and made the rotation of REG_CARTESIAN clockwise by default. This effectively made the resulting frequency negative. This PR makes the I and Q order consistent with RFNoC and fixes the direction of rotation so that a positive value for REG_PHASE_INC (phase increment) results in a counter-clockwise rotation, which yields a positive frequency.
Diffstat (limited to 'host/lib/rfnoc')
-rw-r--r--host/lib/rfnoc/siggen_block_control.cpp18
1 files changed, 9 insertions, 9 deletions
diff --git a/host/lib/rfnoc/siggen_block_control.cpp b/host/lib/rfnoc/siggen_block_control.cpp
index 7fbe79337..2628d66ab 100644
--- a/host/lib/rfnoc/siggen_block_control.cpp
+++ b/host/lib/rfnoc/siggen_block_control.cpp
@@ -307,16 +307,16 @@ private:
// The rotator that rotates the phasor to generate the sinusoidal
// data has an initial phase offset which is impossible to predict.
// Thus, the Cartesian parameter is largely immaterial, as long as
- // the phasor's amplitude matchines with the client has specified.
+ // the phasor's amplitude matches what the client has specified.
// For simplicity, the Cartesian parameter is chosen to have a real
- // (X) component of 0.0 and an imaginary (Y) component of the desired
- // amplitude.
- const int16_t cartesian_i_fp = clamp<int16_t>(amplitude * 32767.0);
-
- // Bits 31:16 represent the imaginary component (the pre-scaled
- // fixed point amplitude), while bits 15:0 represents the real
- // component (which are zeroed).
- const uint32_t cartesian_reg_value = (uint32_t(cartesian_i_fp) << 16);
+ // (X) component of the desired amplitude and an imaginary (Y)
+ // component of 0.0.
+ const int16_t cartesian_x_fp = clamp<int16_t>(amplitude * 32767.0);
+
+ // Bits 31:16 represent the real component (the pre-scaled fixed-point
+ // amplitude), while bits 15:0 represent the imaginary component (which
+ // is zeroed).
+ const uint32_t cartesian_reg_value = (uint32_t(cartesian_x_fp) << 16);
_siggen_reg_iface.poke32(REG_CARTESIAN_OFFSET, cartesian_reg_value, port);
}