LandmarkFactory
A landmark factory specification is either a newly created instance or a landmark factory that has been defined previously. This page describes how one can specify a new landmark factory instance. For re-using landmark factories, see OptionSyntax#Landmark_Predefinitions.
This feature type can be bound to variables using let(variable_name, variable_definition, expression)
where expression
can use variable_name
. Predefinitions using --evaluator
, --heuristic
, and --landmarks
are automatically transformed into let
-expressions but are deprecated.
Exhaustive Landmarks#
Exhaustively checks for each fact if it is a landmark.This check is done using relaxed planning.
lm_exhaust(only_causal_landmarks=false, verbosity=normal)
- only_causal_landmarks (bool): keep only causal landmarks
- verbosity ({silent, normal, verbose, debug}): Option to specify the verbosity level.
silent
: only the most basic outputnormal
: relevant information to monitor progressverbose
: full outputdebug
: like verbose with additional debug output
Supported language features:
- conditional_effects: ignored, i.e. not supported
h^m Landmarks#
The landmark generation method introduced by Keyder, Richter & Helmert (ECAI 2010).
lm_hm(m=2, conjunctive_landmarks=true, use_orders=true, verbosity=normal)
- m (int): subset size (if unsure, use the default of 2)
- conjunctive_landmarks (bool): keep conjunctive landmarks
- use_orders (bool): use orders between landmarks
- verbosity ({silent, normal, verbose, debug}): Option to specify the verbosity level.
silent
: only the most basic outputnormal
: relevant information to monitor progressverbose
: full outputdebug
: like verbose with additional debug output
Supported language features:
- conditional_effects: ignored, i.e. not supported
Merged Landmarks#
Merges the landmarks and orderings from the parameter landmarks
lm_merged(lm_factories, verbosity=normal)
- lm_factories (list of LandmarkFactory):
- verbosity ({silent, normal, verbose, debug}): Option to specify the verbosity level.
silent
: only the most basic outputnormal
: relevant information to monitor progressverbose
: full outputdebug
: like verbose with additional debug output
Precedence: Fact landmarks take precedence over disjunctive landmarks, orderings take precedence in the usual manner (gn > nat > reas > o_reas).
Note: Does not currently support conjunctive landmarks
Supported language features:
- conditional_effects: supported if all components support them
HPS Orders#
Adds reasonable orders described in the following paper
-
Jörg Hoffmann, Julie Porteous and Laura Sebastia.
Ordered Landmarks in Planning.
Journal of Artificial Intelligence Research 22:215-278. 2004.lm_reasonable_orders_hps(lm_factory, verbosity=normal)
-
lm_factory (LandmarkFactory):
- verbosity ({silent, normal, verbose, debug}): Option to specify the verbosity level.
silent
: only the most basic outputnormal
: relevant information to monitor progressverbose
: full outputdebug
: like verbose with additional debug output
Obedient-reasonable orders: Hoffmann et al. (2004) suggest obedient-reasonable orders in addition to reasonable orders. Obedient-reasonable orders were later also used by the LAMA planner (Richter and Westphal, 2010). They are "reasonable orders" under the assumption that all (non-obedient) reasonable orders are actually "natural", i.e., every plan obeys the reasonable orders. We observed experimentally that obedient-reasonable orders have minimal effect on the performance of LAMA (Büchner et al., 2023) and decided to remove them in issue1089.
Supported language features:
- conditional_effects: supported if subcomponent supports them
RHW Landmarks#
The landmark generation method introduced by Richter, Helmert and Westphal (AAAI 2008).
lm_rhw(disjunctive_landmarks=true, use_orders=true, only_causal_landmarks=false, verbosity=normal)
- disjunctive_landmarks (bool): keep disjunctive landmarks
- use_orders (bool): use orders between landmarks
- only_causal_landmarks (bool): keep only causal landmarks
- verbosity ({silent, normal, verbose, debug}): Option to specify the verbosity level.
silent
: only the most basic outputnormal
: relevant information to monitor progressverbose
: full outputdebug
: like verbose with additional debug output
Supported language features:
- conditional_effects: supported
Zhu/Givan Landmarks#
The landmark generation method introduced by Zhu & Givan (ICAPS 2003 Doctoral Consortium).
lm_zg(use_orders=true, verbosity=normal)
- use_orders (bool): use orders between landmarks
- verbosity ({silent, normal, verbose, debug}): Option to specify the verbosity level.
silent
: only the most basic outputnormal
: relevant information to monitor progressverbose
: full outputdebug
: like verbose with additional debug output
Supported language features:
- conditional_effects: We think they are supported, but this is not 100% sure.