Created on 2014-08-08.11:55:08 by malte, last changed by malte.
msg11683 (view) |
Author: malte |
Date: 2024-07-30.13:48:36 |
|
We need unrolling too for "exact" negated axioms, not because of the combinatorial explosion but because the non-unrolled version is incorrect for derived variables with a definition involving cycles. (Using this incorrect negation was a bug that we fixed by overapproximating the cases involving cycles; adding an exact version would be a new feature.)
I suggest using this issue to check that the specific examples that were reported here now behave better when using a suitable planner configuration. If they do, I suggest we close it because the original "bug" -- an unavoidable exponential behaviour -- is no longer there. But we should test the instances discussed in this issue before closing.
This would leave two wishes for the future:
- exact negated axioms
- negated axioms without the exponential CNF-to-DNF transformation
I suggest making both of these new issues.
|
msg11666 (view) |
Author: salome |
Date: 2024-07-22.16:18:33 |
|
Sorry, just realized that we can avoid the explosion with auxiliary variables, not with unrolling. I think unrolling would be relevant for derived variables with cyclic dependencies, where we currently always overapproximate (see issue453).
|
msg11665 (view) |
Author: salome |
Date: 2024-07-22.16:05:22 |
|
The default behaviour can still cause a combinatorial explosion, but
1) only when using a heuristic that needs negated axioms
2) these heuristics now have an option to avoid it (at the cost of heuristic accuracy).
I thus changed the priority to feature (and removed the translator keyword, since the computation has been moved to the search component). I assume we would still like to provide an alternative way of exactly computing negated axioms that avoids the combinatorial explosion (I think unrolling would be the key here?), but I don't know if we want to just change this issue to be about this instead, or rather open a new issue and close this one instead.
|
msg11657 (view) |
Author: malte |
Date: 2024-07-19.14:13:31 |
|
What's the status of this now that issue454 is merged?
|
msg11601 (view) |
Author: salome |
Date: 2024-06-27.12:28:04 |
|
Christian Muise reported some new tasks which also run into the exponential blowup. The tasks can be found here:
https://github.com/haz/minor-planning/ (for example revision ee618c0)
The repo contains two domain and two problem files, where the domain files are just variations, and the problem files work with both domains. prob_triangle_in_square.pddl is solvable, prob_C6_planar.pddl is not.
Side note: Once issue454 is merged, dom_edge_queue.pddl + prob_triangle_in_square.pddl should be solved in reasonable time according to Christian's test on the 454 branch.
|
msg9125 (view) |
Author: francos3 |
Date: 2019-12-19.16:44:34 |
|
Original message to the mail list below. The domain and problem files are
very simplified, so the "bug" is very easy to reproduce/alter.
Also thanks for all the work in maintaining and improving FD over the years,
it probably does not get said frequently enough ;-)
____________________
Dear all,
I am working on a domain where agents move in a 3D grid. I attach 2 very
simple domain and problem files with only one action and one trivial goal to
showcase my problem. The "NoBlowup" version works as I would expect. The
"Blowup" version Exists statement memory usage (when processing the axioms) is
growing by a ratio of 6 per extra agent. The time cost increases similarly.
This means that I cannot use more than 8 agents on my 32GB memory machine for
a 13x13x13 grid when using the "Blowup" version.
The Exist statement which blows-up (memory and time-wise) if using more than 8
agents below:
(not (exists (?r - agent)
(and
(at_agentX ?r ?x1)
(at_agentY ?r ?y1)
(at_agentZ ?r ?z1)
)
)
)
The Exist statement that does not blow-up (it can deal with 16 agents
instantaneously, translate memory and time efforts are negligible):
(not (exists (?r - agent)
(and
(at_agent ?r ?x1 ?y1 ?z1)
)
)
)
The only difference between both versions is whether the "at_agent" predicate
is split up or not. I do not understand why the difference in performance, as
a function of the number of agents, is so large (for grounding). Am I missing
something or is there a problem with the way translate handles the first
Exist?
Thanks a lot for your help,
|
msg8749 (view) |
Author: malte |
Date: 2019-03-26.11:30:48 |
|
We treat some performance problems as bugs, and I think this one is severe
enough to qualify. So I'm reclassifying this as "bug".
|
msg8748 (view) |
Author: malte |
Date: 2019-03-26.11:29:42 |
|
Lu Xu: I have added you to the "nosy list" of this issue, so that you will
receive email updates when we make progress on this issue. If you prefer not to
receive these updates, please let me know, and I can remove you from the nosy
list again. (You can also remove yourself.)
|
msg8746 (view) |
Author: malte |
Date: 2019-03-26.11:26:53 |
|
And now the problem file.
|
msg8745 (view) |
Author: malte |
Date: 2019-03-26.11:26:31 |
|
I am attaching another example that highlights this performance issue, or at
least I think it has the same cause. It is a modified version of the citycar
domain that includes some compiled-in control knowledge.
This comes from issue912; I have received the PDDL file from Xu Lu email and
received permission to add it here. First, the domain file.
|
msg3283 (view) |
Author: malte |
Date: 2014-08-08.11:55:08 |
|
Spawned from issue335. I'm attaching Patrik's example from that issue. With the
current translator version, we quickly run out of memory on this example unless
we comment out all but two objects. This is probably caused by
axiom_rules.compute_negative_axioms, which does a CNF-to-DNF-style conversion.
There are two separate aspects here. Firstly, we could avoid the exponential
blowup by introducing auxiliary axioms.
Secondly, it's not clear why we need to compute these negated axioms at all. I
think they were originally added for "extended DTGs", and I'm not sure if they
are really used except perhaps by a few optional parts of the planner (CG
heuristic, possibly cea heuristic, possibly some landmark generation methods).
If this is an optional computation, it doesn't belong in the translator.
(However, I did a quick test that simply removed this line of code, and this
didn't work well, claiming Patrik's example is unsolvable. It may be that the
simplification later on in the translator then decides that the variable is
unnecessary or something like that.)
|
|
Date |
User |
Action |
Args |
2024-07-30 13:48:36 | malte | set | messages:
+ msg11683 |
2024-07-22 16:18:33 | salome | set | messages:
+ msg11666 |
2024-07-22 16:05:22 | salome | set | priority: bug -> feature messages:
+ msg11665 keyword:
- translator title: negated axiom rules cause combinatorial explosion -> computation of negated axiom rules cause combinatorial explosion |
2024-07-19 14:13:31 | malte | set | messages:
+ msg11657 |
2024-06-27 12:28:04 | salome | set | nosy:
+ salome messages:
+ msg11601 |
2019-12-19 16:44:34 | francos3 | set | files:
+ ExistBlowupFiles.zip nosy:
+ francos3 messages:
+ msg9125 |
2019-06-14 14:29:27 | malte | set | summary: See meta-issue: issue924. |
2019-03-26 11:30:48 | malte | set | priority: feature -> bug messages:
+ msg8749 |
2019-03-26 11:29:42 | malte | set | nosy:
+ alachun messages:
+ msg8748 |
2019-03-26 11:26:53 | malte | set | files:
+ citycar-p3-2-2-0-1.pddl messages:
+ msg8746 |
2019-03-26 11:26:31 | malte | set | files:
+ citycar-domain.pddl messages:
+ msg8745 |
2015-11-19 23:43:02 | haz | set | nosy:
+ haz |
2014-10-04 19:35:11 | malte | set | keyword:
+ translator |
2014-08-08 11:55:19 | malte | set | files:
+ mst2.pddl |
2014-08-08 11:55:08 | malte | create | |
|