X-Git-Url: https://fleuret.org/cgi-bin/gitweb/gitweb.cgi?a=blobdiff_plain;f=rpl.py;h=155bc69cc76b4b88a3bd05c75cb2ce977e762df9;hb=0c47d4d8ef8c4938f4765af816349cf30da14cb1;hp=42db38cad4c430f38e8cf38f3872b82e91aa31ff;hpb=c9dbc3abf436df8af1379d04ab51159e821496f1;p=picoclvr.git
diff --git a/rpl.py b/rpl.py
index 42db38c..155bc69 100755
--- a/rpl.py
+++ b/rpl.py
@@ -11,6 +11,7 @@ from torch.nn import functional as F
def rpl_exec(program, stack):
+ stack = stack.copy()
for op in program:
if op == "add":
if len(stack) > 1:
@@ -44,6 +45,8 @@ def rpl_exec(program, stack):
else:
raise ValueError(f"Unknown instruction {op}")
+ return stack
+
rpl_ops = ["add", "min", "max", "swp", "rep", "dup", "del"]
@@ -57,9 +60,8 @@ def generate(nb_values=3, max_input=9, prog_len=6, nb_runs=5):
result = []
for _ in range(nb_runs):
stack = [x.item() for x in torch.randint(max_input + 1, (nb_values,))]
- result = result + [""] + stack
- rpl_exec(prog, stack)
- result = result + ["