-
Notifications
You must be signed in to change notification settings - Fork 29
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support subtraction in preconditions in domains. #100
Comments
@marcofavorito @francescofuggitti Can I get your take on this one? I've banged my head against the proverbial Lark wall for quite some time now, and am convinced that our choice of parser (LALR) prohibits us from handling both I should note that I went as far as having a new symbol ( Thoughts? You can see the proposed changes over at #104 |
Hi @haz , what about this: diff --git a/pddl/parser/domain.lark b/pddl/parser/domain.lark
index 6703c10..629ae9e 100644
--- a/pddl/parser/domain.lark
+++ b/pddl/parser/domain.lark
@@ -77,7 +77,7 @@ constant: NAME
f_exp: NUMBER
| LPAR binary_op f_exp f_exp RPAR
| LPAR multi_op f_exp f_exp+ RPAR
- | LPAR MINUS f_exp RPAR
+ | LPAR MINUS f_exp+ RPAR
| f_head
f_head: NAME
diff --git a/pddl/parser/domain.py b/pddl/parser/domain.py
index e08bfdd..fc58d74 100644
--- a/pddl/parser/domain.py
+++ b/pddl/parser/domain.py
@@ -368,6 +368,9 @@ class DomainTransformer(Transformer):
return args[0]
op = None
if args[1] == Symbols.MINUS.value:
+ if len(args[2:-1]) == 1:
+ return Negate(args[2])
+ # else as usual
op = Minus
if args[1] == Symbols.PLUS.value:
op = Plus
We disambiguate the use of |
In fact, I think we should have a class that represents the expression |
Ah, I see. Just leave it up to the post-grammar parsing. Allowing any number of arguments to a minus is kind of risky...put in a test to force it to explicitly fail. How's it look now? |
Allowing any number of arguments was the same approach taken for the other operators, and I don't see why the minus should be considered different in that respect. We have to decide which route to take for the numeric operators: either (i) allowing any number of operands (to be interpreted as left-associative), or (ii) just two operators (ending up in a binary syntax tree). I also think that, for compatibility with "standard" PDDL (which I assume marries option (ii)), we should configure the printer class to generate the PDDL spec in binary form. I could not spot examples in which option (i) is used in the PDDL book. Overall, supporting both (i) and (ii) might surprising our users, and can add some complexity to the maintenance. |
Ya, I think sticking to the available bnf makes sense. This means handling minus in two ways, and having 3+ operands only work for addition and multiplication. Do we want to maintain the PDDL fed to the parser as the same spat back out? Current proposal has the single operand minus converted to the multiplication of -1 and the f_exp. |
Thank you very much @haz for your PR! My preference is to have a specific class that represents the |
Hi all,
Aren't problems (e.g., on the printing side?) of not having this already implemented now? In case not, it's totally fine as it is, but we might want to consider it in the future if we want to support additional features requiring the info being kept. |
Let's leave this open for a full fix. I'm partway through. One issue that just arose is the inheritance. Functions inherit from Atomic, which inherits from Formula. This means you can start using &, |, etc on functions. This isn't intended, right? More broadly, there seems to be little in the way of testing cases that should fail. I added one to test if a 3 operand minus failed in the right way, but it is kind of a hack (substring match on the error message). There a well crafted example that tests for intended failures? |
Is your feature request related to a problem? Please describe.
The DomainParser cannot seem to handle
(- (function_name object_name) 1)
as part of a precondition.Here is an example domain showing this issue. (In this domain, the arithmetic in the precondition isn't needed since we compare to a constant
1
, but in my actual domain of interest we compare to another numeric function).Describe the solution you'd like
Parse the subtraction correctly.
Describe alternatives you've considered
As a workaround, I can do
(+ (function_name object_name) (- 1))
Additional context
Add any other context or screenshots about the feature request here.
The text was updated successfully, but these errors were encountered: