public:t-622-arti-11-1:lab_2_materials
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
public:t-622-arti-11-1:lab_2_materials [2011/01/19 15:28] – angelo | public:t-622-arti-11-1:lab_2_materials [2024/04/29 13:33] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | === Lab 2: Comparing Agent Programs | + | === Lab 2: Comparing Agent Programs === |
In this lab session we will finish [[public: | In this lab session we will finish [[public: | ||
- | - **Getting Started**: | + | - **Getting Started**: |
- In order to run the experiments later, you can use both functions: **random-agent-program** and **random-agent-measure** from lab 1 (that means you can copy them in the new file **agents2.lisp** =)); | - In order to run the experiments later, you can use both functions: **random-agent-program** and **random-agent-measure** from lab 1 (that means you can copy them in the new file **agents2.lisp** =)); | ||
- You only have to change the **random-agent-program** declaration in order to accommodate a small change in the way the function is called during experiments.< | - You only have to change the **random-agent-program** declaration in order to accommodate a small change in the way the function is called during experiments.< | ||
Line 11: | Line 11: | ||
(defun random-agent-program (agent percept) | (defun random-agent-program (agent percept) | ||
</ | </ | ||
- | - **Creating | + | - **Creating |
* Uses the **STATE** field of the agent struct to remember what squares has already visited (and eventually cleaned). Remember you can use this field in this way: <code lisp> | * Uses the **STATE** field of the agent struct to remember what squares has already visited (and eventually cleaned). Remember you can use this field in this way: <code lisp> | ||
;; HINT: getting the value of the state field in the agent structure | ;; HINT: getting the value of the state field in the agent structure | ||
Line 46: | Line 46: | ||
* **NOTE 2**: in order to keep track of the squares already seen, you can use two helper functions (see **agents2.lisp** for more details): **SQUARE-ID** and **GET-NEIGHBOURS**. The following picture show an example of possible 3x3 environment (**w** x **h**, **width** and **height** = 3) and how unique id are assigned to each square:\\ {{: | * **NOTE 2**: in order to keep track of the squares already seen, you can use two helper functions (see **agents2.lisp** for more details): **SQUARE-ID** and **GET-NEIGHBOURS**. The following picture show an example of possible 3x3 environment (**w** x **h**, **width** and **height** = 3) and how unique id are assigned to each square:\\ {{: | ||
- **Running Experiments**: | - **Running Experiments**: | ||
- | ;; HINT: remember to load the agent2.lisp | + | ;; HINT: remember to load the definitions in "agent2.lisp" |
(run-experiment (generate-environments 3 3 2) | (run-experiment (generate-environments 3 3 2) | ||
(lambda () (make-agent :program #' | (lambda () (make-agent :program #' | ||
Line 52: | Line 52: | ||
1000) | 1000) | ||
</ | </ | ||
- | - **Comparing | + | - **Comparing |
- | - **Extra** If you finish the stateful agent and running the experiments, | + | - **Building an Orderly Agent (EXTRA)**:\\ Try to create |
/var/www/cadia.ru.is/wiki/data/attic/public/t-622-arti-11-1/lab_2_materials.1295450911.txt.gz · Last modified: 2024/04/29 13:32 (external edit)