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 14:57] – 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 27: | Line 27: | ||
CL-USER> (first '(a b c)) | CL-USER> (first '(a b c)) | ||
A | A | ||
+ | </ | ||
;; HINT: adding an element to a list. | ;; HINT: adding an element to a list. | ||
;; cons takes an item and a list, and returns a new list consisting of | ;; cons takes an item and a list, and returns a new list consisting of | ||
Line 34: | Line 35: | ||
CL-USER> (setf my-list (cons 'item my-list)) | CL-USER> (setf my-list (cons 'item my-list)) | ||
(ITEM A B C) | (ITEM A B C) | ||
- | ;; HINT: checking for | + | </ |
- | consp is a predicate which is true if its argument is a list... | + | ;; HINT: checking for a list argument. |
+ | ;; consp is a predicate which is true if its argument is a list... | ||
CL-USER> (consp '(4 3 8)) | CL-USER> (consp '(4 3 8)) | ||
T | T | ||
;; ...but is not nil | ;; ...but is not nil | ||
- | (consp nil) | + | CL-USER> |
NIL | NIL | ||
</ | </ | ||
* **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:\\ {{: | ||
- | - Use the functions | + | - **Running Experiments**: |
+ | ;; HINT: remember to load the definitions in " | ||
(run-experiment (generate-environments 3 3 2) | (run-experiment (generate-environments 3 3 2) | ||
- | (lambda () (make-agent :program #'random-agent-with-state-program)) | + | (lambda () (make-agent :program #'example-agent-program)) |
- | #'perf-measure | + | #'example-measure |
1000) | 1000) | ||
- | </ | + | </ |
- | - Try different agents (e.g. stateless | + | - **Comparing Different Agents**: |
- | - **BONUS** 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.1295449034.txt.gz · Last modified: 2024/04/29 13:32 (external edit)