Skip to content

A fork of Fast Downward expanding on the alternation list and examining the impact of exploration in Type-GBFS and Type-WA*

License

Notifications You must be signed in to change notification settings

mbrotos/downward-dynamic-explore

 
 

Repository files navigation

Abstract

Several recent heuristic search algorithms have focused on methods which systematically disregard the heuristic function. While these popular search algorithms report increases in performance without a significant increase in computational cost, they all use rudimentary techniques to determine when to disregard heuristics. We create a framework on top of Type-GBFS in the Fast Downward Planning System, allowing us to dynamically update the probability of ignoring the heuristic. We test our proposed dynamic exploration control using cached values to evaluate the potential of our method. While we do not see significant benefits over traditional Type-GBFS within our experiments, our tests only focus on a limited scope. We note that dynamic exploration control has a high theoretical potential. We provide a framework for others to test with.


A fork of Fast Downward expanding on the alternation list and examining the impact of exploration in Type-GBFS and Type-WA*

New features:

  • Custom alternation list decision functions
  • New alternation list option to toggle between decision functions
  • Random and weighted-random alternations
  • New alternation list option to define a probability distribution across open lists
  • [WIP] Search progress-based alternation decision function examining uninformative heuristic regions (UHRs):
    • Rate of change of f-values
    • Distribution of heuristic value in open list
    • Number of nodes expanded and generated
    • Number of dead ends
    • etc.


Fast Downward

Fast Downward is a domain-independent classical planning system.

Copyright 2003-2023 Fast Downward contributors (see below).

For further information:

Scientific experiments

We recommend to use the latest release instead of the tip of the main branch. The Downward Lab Python package helps running Fast Downward experiments. Our separate benchmark repository contains a collection of planning tasks.

Supported software versions

The planner is mainly developed under Linux; and all of its features should work with no restrictions under this platform. The planner should compile and run correctly on macOS, but we cannot guarantee that it works as well as under Linux. The same comment applies for Windows, where additionally some diagnostic features (e.g., reporting peak memory usage when the planner is terminated by a signal) are not supported. Setting time and memory limits and running portfolios is not supported under Windows either.

This version of Fast Downward has been tested with the following software versions:

OS Python C++ compiler CMake
Ubuntu 22.04 3.10 GCC 11, GCC 12, Clang 14 3.22
Ubuntu 20.04 3.8 GCC 10, Clang 12 3.16
macOS 12 3.10 AppleClang 14 3.24
macOS 11 3.8 AppleClang 13 3.24
Windows 10 3.8 Visual Studio Enterprise 2019 (MSVC 19.29) and 2022 (MSVC 19.31) 3.22

We test LP support with CPLEX 22.1.1 and SoPlex 6.0.3+. On Ubuntu we test both CPLEX and SoPlex. On Windows we currently only test CPLEX, and on macOS we do not test LP solvers (yet).

Build instructions

See BUILD.md.

Contributors

The following list includes all people that actively contributed to Fast Downward, i.e., all people that appear in some commits in Fast Downward's history (see below for a history on how Fast Downward emerged) or people that influenced the development of such commits. Currently, this list is sorted by the last year the person has been active, and in case of ties, by the earliest year the person started contributing, and finally by last name.

  • 2003-2023 Malte Helmert
  • 2008-2016, 2018-2023 Gabriele Roeger
  • 2010-2023 Jendrik Seipp
  • 2010-2011, 2013-2023 Silvan Sievers
  • 2012-2023 Florian Pommerening
  • 2013, 2015-2023 Salomé Eriksson
  • 2015, 2021-2023 Thomas Keller
  • 2018-2023 Patrick Ferber
  • 2018-2020, 2023 Augusto B. Corrêa
  • 2021-2023 Clemens Büchner
  • 2022-2023 Remo Christen
  • 2023 Simon Dold
  • 2023 Claudia S. Grundke
  • 2023 Victor Paléologue
  • 2023 Emanuele Tirendi
  • 2021-2022 Dominik Drexler
  • 2016-2020 Cedric Geissmann
  • 2017-2020 Guillem Francès
  • 2020 Rik de Graaff
  • 2015-2019 Manuel Heusner
  • 2017 Daniel Killenberger
  • 2016 Yusra Alkhazraji
  • 2016 Martin Wehrle
  • 2014-2015 Patrick von Reth
  • 2009-2014 Erez Karpas
  • 2014 Robert P. Goldman
  • 2010-2012 Andrew Coles
  • 2010, 2012 Patrik Haslum
  • 2003-2011 Silvia Richter
  • 2009-2011 Emil Keyder
  • 2010-2011 Moritz Gronbach
  • 2010-2011 Manuela Ortlieb
  • 2011 Vidal Alcázar Saiz
  • 2011 Michael Katz
  • 2011 Raz Nissim
  • 2010 Moritz Goebelbecker
  • 2007-2009 Matthias Westphal
  • 2009 Christian Muise

History

The current version of Fast Downward is the merger of three different projects:

  • the original version of Fast Downward developed by Malte Helmert and Silvia Richter
  • LAMA, developed by Silvia Richter and Matthias Westphal based on the original Fast Downward
  • FD-Tech, a modified version of Fast Downward developed by Erez Karpas and Michael Katz based on the original code

In addition to these three main sources, the codebase incorporates code and features from numerous branches of the Fast Downward codebase developed for various research papers. The main contributors to these branches are Malte Helmert, Gabi Röger and Silvia Richter.

License

Fast Downward is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or (at
your option) any later version.

Fast Downward is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.

About

A fork of Fast Downward expanding on the alternation list and examining the impact of exploration in Type-GBFS and Type-WA*

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 70.9%
  • Python 18.6%
  • PDDL 8.3%
  • CMake 1.7%
  • Shell 0.3%
  • Smarty 0.2%