From a250b5da21e8ceb94d568c1eaf009d482ff7008c Mon Sep 17 00:00:00 2001 From: whitequark Date: Tue, 22 Dec 2015 11:16:51 +0800 Subject: [PATCH] language.core: implement round(value, width) (fixes #203). --- artiq/language/core.py | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/artiq/language/core.py b/artiq/language/core.py index 917a6e11a..6c6985e42 100644 --- a/artiq/language/core.py +++ b/artiq/language/core.py @@ -10,7 +10,7 @@ from functools import wraps from artiq.coredevice.runtime import source_loader -__all__ = ["host_int", "int", +__all__ = ["host_int", "int", "host_round", "round", "kernel", "portable", "syscall", "set_time_manager", "set_watchdog_factory", "ARTIQException", @@ -161,6 +161,11 @@ class int: __lt__ = _compareop(host_int.__lt__, "__ge__") __le__ = _compareop(host_int.__le__, "__gt__") +host_round = round + +def round(value, width=32): + return int(host_round(value), width) + _ARTIQEmbeddedInfo = namedtuple("_ARTIQEmbeddedInfo", "core_name function syscall") @@ -316,7 +321,7 @@ def seconds_to_mu(seconds, core=None): """ if core is None: raise ValueError("Core device must be specified for time conversion") - return round64(seconds//core.ref_period) + return round(seconds//core.ref_period, width=64) def mu_to_seconds(mu, core=None):