Skip to content

Commit

Permalink
feat(predicates): update axone-protocol/axoned predicates documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
bot-anik committed Nov 11, 2024
1 parent 11365f2 commit d98b730
Show file tree
Hide file tree
Showing 32 changed files with 481 additions and 28 deletions.
20 changes: 20 additions & 0 deletions predicates/abolish_1.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
---
sidebar_position: 1
---
[//]: # (This file is auto-generated. Please do not modify it yourself.)

# abolish/1

## Description

`abolish/1` is a predicate that abolishes a predicate from the database. Removes all clauses of the predicate designated by given predicate indicator Name/Arity.

## Signature

```text
abolish(+PredicateIndicator)
```

Where:

- PredicateIndicator is the indicator of the predicate to abolish.
178 changes: 178 additions & 0 deletions predicates/asserta_1.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,178 @@
---
sidebar_position: 2
---
[//]: # (This file is auto-generated. Please do not modify it yourself.)

# asserta/1

## Description

`asserta/1` is a predicate that asserts a clause into the database as the first clause of the predicate.

## Signature

```text
asserta(+Clause)
```

Where:

- Clause is the clause to assert into the database.

## Examples

### Assert a fact into the database

This scenario demonstrates the process of asserting a new fact into a Prolog database. In Prolog, asserting a fact means
adding a new piece of information or *knowledge* into the database, allowing it to be referenced in subsequent queries.
This is particularly useful when you want to dynamically extend the knowledge base with facts or rules based on conditions
or interactions during runtime.

Here are the steps of the scenario:

- **Given** the program:

``` prolog
assert_fact :- asserta(father(john, pete)).
```

- **Given** the query:

``` prolog
assert_fact, father(X, Y).
```

- **When** the query is run
- **Then** the answer we get is:

``` yaml
height: 42
gas_used: 3977
answer:
has_more: false
variables: ["X", "Y"]
results:
- substitutions:
- variable: X
expression: "john"
- variable: Y
expression: "pete"
```
### Only dynamic predicates can be asserted
This scenario demonstrates that only dynamic predicates can be asserted. In Prolog, dynamic predicates are those that can be
modified during runtime. This is in contrast to static predicates, which are fixed and cannot be modified.
Here are the steps of the scenario:
- **Given** the program:
``` prolog
parent(jane, alice).
```

- **Given** the query:

``` prolog
asserta(parent(john, alice)).
```

- **When** the query is run
- **Then** the answer we get is:

``` yaml
height: 42
gas_used: 3975
answer:
has_more: false
results:
- error: "error(permission_error(modify,static_procedure,parent/2),asserta/1)"
```
### Show that the fact is asserted at the beginning of the database
This scenario demonstrates that the asserta/1 predicate adds the fact to the beginning of the database. This means that
the fact is the first fact to be matched when a query is run.
This is in contrast to the assertz/1 predicate, which adds the fact to the end of the database.
Here are the steps of the scenario:
- **Given** the program:
``` prolog
:- dynamic(parent/2).

parent(jane, alice).

assert_fact :- asserta(parent(john, alice)).
```

- **Given** the query:

``` prolog
assert_fact, parent(X, alice).
```

- **When** the query is run (limited to 2 solutions)
- **Then** the answer we get is:

``` yaml
height: 42
gas_used: 3977
answer:
has_more: false
variables: ["X"]
results:
- substitutions:
- variable: X
expression: "john"
- substitutions:
- variable: X
expression: "jane"
```
### Shows a simple counter example
This scenario demonstrates a simple counter example using the `asserta/1` and `retract/1` predicates.
In this example, we represent the value of the counter as a dynamic predicate `counter/1` that is asserted and retracted
to each time the value of the counter is incremented or decremented.

Here are the steps of the scenario:

- **Given** the program:

``` prolog
:- dynamic(counter/1).
counter(0).
increment_counter :- retract(counter(X)), Y is X + 1, asserta(counter(Y)).
decrement_counter :- retract(counter(X)), Y is X - 1, asserta(counter(Y)).
```

- **Given** the query:

``` prolog
counter(InitialValue), increment_counter, increment_counter, counter(IncrementedValue), decrement_counter, counter(DecrementedValue).
```

- **When** the query is run
- **Then** the answer we get is:

``` yaml
height: 42
gas_used: 3989
answer:
has_more: false
variables: ["InitialValue", "IncrementedValue", "DecrementedValue"]
results:
- substitutions:
- variable: InitialValue
expression: 0
- variable: IncrementedValue
expression: 2
- variable: DecrementedValue
expression: 1
```
175 changes: 175 additions & 0 deletions predicates/assertz_1.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,175 @@
---
sidebar_position: 3
---
[//]: # (This file is auto-generated. Please do not modify it yourself.)

# assertz/1

## Description

`assertz/1` is a predicate that asserts a clause into the database as the last clause of the predicate.

## Signature

```text
assertz(+Clause)
```

Where:

- Clause is the clause to assert into the database.

## Examples

### Assert a fact into the database

This scenario demonstrates the process of asserting a new fact into a Prolog database. In Prolog, asserting a fact means
adding a new piece of information or *knowledge* into the database, allowing it to be referenced in subsequent queries.
This is particularly useful when you want to dynamically extend the knowledge base with facts or rules based on conditions
or interactions during runtime.

Here are the steps of the scenario:

- **Given** the program:

``` prolog
assert_fact :- assertz(father(john, pete)).
```

- **Given** the query:

``` prolog
assert_fact, father(X, Y).
```

- **When** the query is run
- **Then** the answer we get is:

``` yaml
height: 42
gas_used: 3977
answer:
has_more: false
variables: ["X", "Y"]
results:
- substitutions:
- variable: X
expression: "john"
- variable: Y
expression: "pete"
```
### Only dynamic predicates can be asserted
This scenario demonstrates that only dynamic predicates can be asserted. In Prolog, dynamic predicates are those that can be
modified during runtime. This is in contrast to static predicates, which are fixed and cannot be modified.
Here are the steps of the scenario:
- **Given** the program:
``` prolog
parent(jane, alice).
```

- **Given** the query:

``` prolog
assertz(parent(john, alice)).
```

- **When** the query is run
- **Then** the answer we get is:

``` yaml
height: 42
gas_used: 3975
answer:
has_more: false
results:
- error: "error(permission_error(modify,static_procedure,parent/2),assertz/1)"
```
### Show that the fact is asserted at the end of the database
This scenario demonstrates that the assertz/1 predicate adds the fact to the end of the database. This means that
the fact is the last fact to be matched when a query is run.
This is in contrast to the asserta/1 predicate, which adds the fact to the beginning of the database.
Here are the steps of the scenario:
- **Given** the program:
``` prolog
:- dynamic(parent/2).

parent(jane, alice).

assert_fact :- assertz(parent(john, alice)).
```

- **Given** the query:

``` prolog
assert_fact, parent(X, alice).
```

- **When** the query is run (limited to 2 solutions)
- **Then** the answer we get is:

``` yaml
height: 42
gas_used: 3977
answer:
has_more: false
variables: ["X"]
results:
- substitutions:
- variable: X
expression: "jane"
- substitutions:
- variable: X
expression: "john"
```
### Add and remove items in an inventory
This scenario demonstrates how to maintain a dynamic list of items (like in an inventory system) by representing each item
as a fact in the Prolog knowledge base. By using dynamic predicates, we can add items to the inventory and remove them on demand.
Here are the steps of the scenario:
- **Given** the program:
``` prolog
:- dynamic(inventory/1).

add_item(Item) :- assertz(inventory(Item)).
remove_item(Item) :- retract(inventory(Item)).
```

- **And** the query:

``` prolog
add_item('apple'),
add_item('banana'),
add_item('orange'),
remove_item('banana'),
findall(I, inventory(I), CurrentInventory).
```

- **When** the query is run
- **Then** the answer we get is:

``` yaml
height: 42
gas_used: 3984
answer:
has_more: false
variables: ["I","CurrentInventory"]
results:
- substitutions:
- variable: CurrentInventory
expression: "[apple,orange]"
```
2 changes: 1 addition & 1 deletion predicates/atomic_list_concat_2.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
sidebar_position: 1
sidebar_position: 4
---
[//]: # (This file is auto-generated. Please do not modify it yourself.)

Expand Down
2 changes: 1 addition & 1 deletion predicates/atomic_list_concat_3.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
sidebar_position: 2
sidebar_position: 5
---
[//]: # (This file is auto-generated. Please do not modify it yourself.)

Expand Down
2 changes: 1 addition & 1 deletion predicates/bank_balances_2.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
sidebar_position: 3
sidebar_position: 6
---
[//]: # (This file is auto-generated. Please do not modify it yourself.)

Expand Down
Loading

0 comments on commit d98b730

Please sign in to comment.