1
0
forked from M-Labs/artiq

ad9910: Add inverse FTW/ASF conversions

This commit is contained in:
David Nadlinger 2019-01-08 02:16:42 +00:00
parent 4d793d7149
commit 7bcdeb825b

View File

@ -468,23 +468,37 @@ class AD9910:
""" """
return int32(round(self.ftw_per_hz*frequency)) return int32(round(self.ftw_per_hz*frequency))
@portable(flags={"fast-math"})
def ftw_to_frequency(self, ftw):
"""Return the frequency corresponding to the given frequency tuning
word.
"""
return ftw / self.ftw_per_hz
@portable(flags={"fast-math"}) @portable(flags={"fast-math"})
def turns_to_pow(self, turns): def turns_to_pow(self, turns):
"""Return the phase offset word corresponding to the given phase """Return the phase offset word corresponding to the given phase
in turns.""" in turns."""
return int32(round(turns*0x10000)) return int32(round(turns*0x10000))
@portable(flags={"fast-math"})
def amplitude_to_asf(self, amplitude):
"""Return amplitude scale factor corresponding to given amplitude."""
return int32(round(amplitude*0x3ffe))
@portable(flags={"fast-math"}) @portable(flags={"fast-math"})
def pow_to_turns(self, pow_): def pow_to_turns(self, pow_):
"""Return the phase in turns corresponding to a given phase offset """Return the phase in turns corresponding to a given phase offset
word.""" word."""
return pow_/0x10000 return pow_/0x10000
@portable(flags={"fast-math"})
def amplitude_to_asf(self, amplitude):
"""Return amplitude scale factor corresponding to given fractional
amplitude."""
return int32(round(amplitude*0x3ffe))
@portable(flags={"fast-math"})
def asf_to_amplitude(self, asf):
"""Return amplitude as a fraction of full scale corresponding to given
amplitude scale factor."""
return asf / float(0x3ffe)
@kernel @kernel
def set_frequency(self, frequency): def set_frequency(self, frequency):
return self.set_ftw(self.frequency_to_ftw(frequency)) return self.set_ftw(self.frequency_to_ftw(frequency))