public:t-622-arti-15-1:lab_3_-_csps
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
public:t-622-arti-15-1:lab_3_-_csps [2015/02/09 13:58] – created stephan | public:t-622-arti-15-1:lab_3_-_csps [2024/04/29 13:33] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== Lab 3 - Constraint Satisfaction Problems ====== | ====== Lab 3 - Constraint Satisfaction Problems ====== | ||
+ | |||
+ | **Note:** For this lab, you can work together in teams of up to 4 students. However, this is not a necessity. The assignment is small enough to do it alone in which case you may get more experience. You can use [[https:// | ||
+ | |||
+ | You will need a Java Development Kit (JDK) and a Java IDE (any text editor should do as well). | ||
+ | |||
+ | ===== Problem Description ===== | ||
The following logic puzzle is known as Zebra Puzzle or Einstein Puzzle (source: [[http:// | The following logic puzzle is known as Zebra Puzzle or Einstein Puzzle (source: [[http:// | ||
Line 23: | Line 29: | ||
Now, who drinks water? Who owns the zebra? | Now, who drinks water? Who owns the zebra? | ||
- | |||
===== Tasks ===== | ===== Tasks ===== | ||
- | | + | |
+ | | ||
+ | - How big is the state space? Shortly, explain your answer. | ||
- Download the material below, implement your model (implement all things marked with TODO). | - Download the material below, implement your model (implement all things marked with TODO). | ||
- Run the program and compare the results. What does that tell you about the usefulness of different propagation algorithms and heuristics for this problem? | - Run the program and compare the results. What does that tell you about the usefulness of different propagation algorithms and heuristics for this problem? | ||
===== Material ===== | ===== Material ===== | ||
- | * {{: | + | |
+ | The Java project for the lab can be found on Skel. See, instructions below on how to get it. | ||
The project contains a Main class which sets up and solves the CSP, as well as some additional classes implementing the constraints. You need to implement a few parts in Main.java and a method in DifferByOneConstraint.java (if you need that constraint). To run the code simply run the Main class or use "ant run" on the terminal. | The project contains a Main class which sets up and solves the CSP, as well as some additional classes implementing the constraints. You need to implement a few parts in Main.java and a method in DifferByOneConstraint.java (if you need that constraint). To run the code simply run the Main class or use "ant run" on the terminal. | ||
===== Handing In ===== | ===== Handing In ===== | ||
- | You can work in groups of up to 4 students, although more than 2 is probably not necessary. | ||
- | Hand in a zip file containing: | + | Connect to skel.ru.is using your favorite ssh client and unpack the assignment into your home directory by running the following commands: |
- | * the answers | + | < |
- | * your source | + | [student14@skel ~]$ tar xvf / |
- | To create | + | [student14@skel ~]$ cd arti15/ |
+ | [student14@skel hw1]$ ls | ||
+ | answers | ||
+ | </code> | ||
+ | |||
+ | You can copy the code to your own machine for development by using any SCP or SFTP client | ||
+ | |||
+ | To answer | ||
+ | Single answers will be put into files called '' | ||
+ | |||
+ | Finally, to hand in your answers run '' | ||
+ | This should produce a file ''/ | ||
/var/www/cadia.ru.is/wiki/data/attic/public/t-622-arti-15-1/lab_3_-_csps.1423490317.txt.gz · Last modified: 2024/04/29 13:32 (external edit)