forked from M-Labs/artiq
parent
25e7e0c177
commit
cdaf554736
@ -181,6 +181,9 @@ def fn_len():
|
||||
def fn_round():
|
||||
return types.TBuiltinFunction("round")
|
||||
|
||||
def fn_abs():
|
||||
return types.TBuiltinFunction("abs")
|
||||
|
||||
def fn_min():
|
||||
return types.TBuiltinFunction("min")
|
||||
|
||||
|
@ -29,6 +29,7 @@ def globals():
|
||||
# Built-in Python functions
|
||||
"len": builtins.fn_len(),
|
||||
"round": builtins.fn_round(),
|
||||
"abs": builtins.fn_abs(),
|
||||
"min": builtins.fn_min(),
|
||||
"max": builtins.fn_max(),
|
||||
"print": builtins.fn_print(),
|
||||
|
@ -1700,6 +1700,16 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
return self.append(ir.Builtin("round", [arg], node.type))
|
||||
else:
|
||||
assert False
|
||||
elif types.is_builtin(typ, "abs"):
|
||||
if len(node.args) == 1 and len(node.keywords) == 0:
|
||||
arg = self.visit(node.args[0])
|
||||
neg = self.append(
|
||||
ir.Arith(ast.Sub(loc=None), ir.Constant(0, arg.type), arg))
|
||||
cond = self.append(
|
||||
ir.Compare(ast.Lt(loc=None), arg, ir.Constant(0, arg.type)))
|
||||
return self.append(ir.Select(cond, neg, arg))
|
||||
else:
|
||||
assert False
|
||||
elif types.is_builtin(typ, "min"):
|
||||
if len(node.args) == 2 and len(node.keywords) == 0:
|
||||
arg0, arg1 = map(self.visit, node.args)
|
||||
|
@ -811,6 +811,28 @@ class Inferencer(algorithm.Visitor):
|
||||
arg.loc, None)
|
||||
else:
|
||||
diagnose(valid_forms())
|
||||
elif types.is_builtin(typ, "abs"):
|
||||
fn = typ.name
|
||||
|
||||
valid_forms = lambda: [
|
||||
valid_form("abs(x:numpy.int?) -> numpy.int?"),
|
||||
valid_form("abs(x:float) -> float")
|
||||
]
|
||||
|
||||
if len(node.args) == 1 and len(node.keywords) == 0:
|
||||
(arg,) = node.args
|
||||
if builtins.is_int(arg.type) or builtins.is_float(arg.type):
|
||||
self._unify(arg.type, node.type,
|
||||
arg.loc, node.loc)
|
||||
elif types.is_var(arg.type):
|
||||
pass # undetermined yet
|
||||
else:
|
||||
diag = diagnostic.Diagnostic("error",
|
||||
"the arguments of abs() must be of a numeric type", {},
|
||||
node.func.loc)
|
||||
self.engine.process(diag)
|
||||
else:
|
||||
diagnose(valid_forms())
|
||||
elif types.is_builtin(typ, "min") or types.is_builtin(typ, "max"):
|
||||
fn = typ.name
|
||||
|
||||
|
@ -30,3 +30,9 @@ len([])
|
||||
|
||||
# CHECK-L: round:<function round>(1.0:float):numpy.int?
|
||||
round(1.0)
|
||||
|
||||
# CHECK-L: abs:<function abs>(1:numpy.int?):numpy.int?
|
||||
abs(1)
|
||||
|
||||
# CHECK-L: abs:<function abs>(1.0:float):float
|
||||
abs(1.0)
|
||||
|
@ -10,5 +10,8 @@ list(1)
|
||||
# CHECK-L: ${LINE:+1}: error: the arguments of min() must be of a numeric type
|
||||
min([1], [1])
|
||||
|
||||
# CHECK-L: ${LINE:+1}: error: the arguments of abs() must be of a numeric type
|
||||
abs([1.0])
|
||||
|
||||
# CHECK-L: ${LINE:+1}: error: strings currently cannot be constructed
|
||||
str(1)
|
||||
|
7
artiq/test/lit/integration/abs.py
Normal file
7
artiq/test/lit/integration/abs.py
Normal file
@ -0,0 +1,7 @@
|
||||
# RUN: %python -m artiq.compiler.testbench.jit %s
|
||||
# RUN: %python %s
|
||||
|
||||
assert abs(1234) == 1234
|
||||
assert abs(-1234) == 1234
|
||||
assert abs(1234.0) == 1234.0
|
||||
assert abs(-1234.0) == 1234
|
Loading…
Reference in New Issue
Block a user