public:t-622-arti-09-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-09-1:lab_2_materials [2009/01/26 13:55] – hannes | public:t-622-arti-09-1:lab_2_materials [2024/04/29 13:33] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | === Lab 2 materials === | + | === Lab 2 materials: Comparing Agent Programs |
- | In lab 2 we will finish [[public: | + | In lab 2 we will finish [[public: |
- Start by getting the file [[http:// | - Start by getting the file [[http:// | ||
- First finish the steps in lab 1, including | - First finish the steps in lab 1, including | ||
- | | + | |
- | * writing a performance evaluation function that at the end gives 20 points for each clean square and deducts one point for each move made. You can get the information about made moves from the environment like this: <code lisp> | + | * writing a performance evaluation function that at the end gives 20 points for each clean square and deducts one point for each move made. You can get the information about made moves from the environment like this: <code lisp> |
- | (env-moves-so-far env)</ | + | |
- After you have finished lab 1, fill in the function RANDOM-WALK-WITH-STATE, | - After you have finished lab 1, fill in the function RANDOM-WALK-WITH-STATE, | ||
- | | + | |
(agent-state agent) | (agent-state agent) | ||
(setf (agent-state agent) <new value> | (setf (agent-state agent) <new value> | ||
</ | </ | ||
- | | + | |
- | * The agent' | + | * The agent' |
- | * If the agent is sure everything is clean, it should return the action :idle | + | * If the agent is sure everything is clean, it should return the action :idle |
- | Be careful not to be to strict, e.g. if you make it absolutely impossible for the agent to travel through clean squares - can it get in trouble so that it is unable to meet its objective? If so, find a solution. | + | |
- | Use the functions at the bottom of agents2.lisp to run experiments and evaluate your agent. To try your agent on all possible 3x3 environments with two dirty squares, enter this in the REPL: \\ <code lisp> | + | |
(run-experiment (generate-environments 3 3 2) | (run-experiment (generate-environments 3 3 2) | ||
(lambda () (make-agent :program #' | (lambda () (make-agent :program #' | ||
#' | #' | ||
1000) | 1000) | ||
- | </ | + | </ |
- | This will return the number of experiments performed, and the average performance value. | + | - Try different agents |
- | - Try different agents and different performance measures. Does the stateful agent behave better than the others with any particular performance measure? You can add print commands to the experiment functions to get more information about the agents behaviour if you like. | + | |
- **BONUS** If you finish the stateful agent and running the experiments, | - **BONUS** If you finish the stateful agent and running the experiments, | ||
/var/www/cadia.ru.is/wiki/data/attic/public/t-622-arti-09-1/lab_2_materials.1232978131.txt.gz · Last modified: 2024/04/29 13:32 (external edit)