4 releases (breaking)

0.4.0 Dec 23, 2024
0.3.0 Aug 11, 2024
0.2.0 Aug 11, 2024
0.1.0 Jul 22, 2024

#310 in Game dev

Download history 12/week @ 2024-09-18 12/week @ 2024-09-25 5/week @ 2024-10-02 2/week @ 2024-10-09 9/week @ 2024-10-30 7/week @ 2024-11-06 6/week @ 2024-12-04 6/week @ 2024-12-11 102/week @ 2024-12-18 40/week @ 2024-12-25 31/week @ 2025-01-01

184 downloads per month
Used in bevy_dogoap

MIT license

34KB
803 lines

dogoap - Data-Oriented, Goal-Oriented Action Planning

License Crates.io Downloads Docs ci

GOAP implemented in data-oriented way to facilitate dynamically setting up states/actions/goals rather than statically

This is a standalone Rust library for doing GOAP declaratively.

Pseudo-example

Given a current state like this:

is_hungry = true

And with the following available actions:

eat_action = Mutator::set("is_hungry", false)

And with a goal like this:

is_hungry = false

The magical planner can figure out the best path of actions to reach that goal. In this case, the best plan is just one eat_action which results in the is_hungry state variable to be set to false, a very simplistic example.

That's the basics. Of course, things get more interesting once we start to include preconditions, multiple actions and multiple state variables, and the planner needs to figure out the right way of reaching there.

Code / API example

This is the actual API of the library:

use dogoap::prelude::*;

let start = LocalState::new().with_datum("is_hungry", Datum::Bool(true));

let goal = Goal::new().with_req("is_hungry", Compare::Equals(Datum::Bool(false)));

let eat_action = Action {
    key: "eat".to_string(),
    preconditions: vec![],
    effects: vec![Effect {
        action: "eat".to_string(),
        mutators: vec![Mutator::Set("is_hungry".to_string(), Datum::Bool(false))],
        state: LocalState::new(),
        cost: 1,
    }],
};

let actions: Vec<Action> = vec![eat_action];

let plan = make_plan(&start, &actions[..], &goal);

print_plan(plan.unwrap());

Dependencies

~7MB
~126K SLoC