| Size: 11830 Comment:  |  ← Revision 27 as of 2014-04-01 10:15:54  ⇥ Size: 4697 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 1: | Line 1: | 
| #acl EditorsGroup:read,write,revert,delete,admin All:read | ##acl EditorsGroup:read,write,revert,delete,admin All:read | 
| Line 7: | Line 7: | 
| == Application == | == Application Procedure == | 
| Line 9: | Line 9: | 
| Teams willing to participate in the competition can register via Easychair.  The registration procedure is as follows: * go to http://www.easychair.org/conferences/?conf=aspcomp2013 * click '''New Submission''' * add all names, email addresses, and affiliations of the team members in the '''Author i''' entries * put the name of their team in the '''Title''' entry; * add a small description of your system to the '''Abstract''' entry; * choose the category: tick '''Model & Solve Track Participant Package''' or '''System Track Participant Package''' if you want to participate in the Model & Solve or in the System track, resp.; * add a few keywords that describe the features of your system; and * tick '''Abstract Only'''. | Participants willing to apply for the competition can send an email (starting from March 1st, 2014) to this [[mailto:aspcomp2014@mat.unical.it|address]] specifying: * the name of their team; * names and affiliation of the team members (institution, research group); * name and number of the systems the team will submit; * please indicate whether a system is an updated version of a solution submitted to the 2013 edition; * specific software requirements: e.g. linux packages/libraries needed to run your system. * language support: e.g. my submission supports normal logic programs and aggregates, it does not support weak constraints and function symbols... and so on. | 
| Line 20: | Line 17: | 
| Then click on the '''Submit''' button.  We will then get in contact with you for the further procedure. == Instructions for testing and submitting systems and benchmarks == | Applicants will get a private e-mail with the instructions for submitting systems and login credentials for accessing our Competition server through ssh. | 
| Line 24: | Line 19: | 
| Participants are expected to submit their packages as a single {{{ZIP}}} file or {{{7z}}}-compressed file in {{{ZIP}}} format. | ## The competition will run on a Debian Linux server (64bit kernel) running on Intel Xeon X5365 Processors with 4096KB of cache and 16GB of RAM. ## (please note that 16GB is the total amount of memory available in the hardware but it is not the memory limit used for the competition) | 
| Line 26: | Line 22: | 
| All files in your submission package will be installed as if they were located in {{{/usr/local}}}.  This means, the zip file containing your submission will be uncompressed to {{{/usr/local}}} without modification to the directory layout. E.g., if your submission package contains {{{bin/mysolver}}}, {{{bin/xsb}}}, {{{lib/libxsb.so.2}}}, ..., we will uncompress it to {{{/usr/local/bin/mysolver}}}, {{{/usr/local/bin/xsb}}}, {{{/usr/local/lib/libxsb.so.2}}}, etc. Note that all solvers will be jailed in a dedicated {{{chroot}}} environment without access to the production file system. You can simulate the environment and test linked binaries etc. on a [[http://releases.ubuntu.com/precise/|Ubuntu 12.04.1 LTS AMD64 server (Precise Pangolin)]] installation with the following sequence of commands: {{{ $ sudo mkdir /path/to/my/sandbox $ sudo debootstrap --arch=amd64 precise /path/to/my/sandbox http://at.archive.ubuntu.com/ubuntu/ $ [install/copy all your tools to /path/to/my/sandbox/usr/local/{bin,lib,...}] $ sudo chroot /path/to/my/sandbox $ [perform some tests with your solver on some instances and check that the installation works] $ exit }}} Your solver will be run as an underprivileged user different from {{{root}}}. After each run, the {{{chroot}}} environment will be cleaned up and temporary files created during the run will be wiped. Please note that we have disk/file size limitations: don't forget to pipe the grounding immediately to your solver, and avoid creating temporary files. Interprocess communication should always be done using pipes (or alternatively named pipes---cf. {{{mkfifo}}}---if some tool can only read/write from/to files). Input instances must be read from {{{stdin}}} and solutions written to {{{stdout}}} according to the output specification. In case additional packages are needed, please include them in your submission packages, and assuming the above unpacking policy. Your {{{run}}} (see below) scripts should take care of setting {{{PATH}}} and other sister environment variables accordingly. The content of the package depends on whether your team is participating to the system or model competition. | Detailed submission instructions, competition rules, hardware and software settings will be published soon. Pease check this page frequently. | 
| Line 63: | Line 25: | 
| <<Anchor(MSComp)>> == Model & Solve Competition == | <<Anchor(System)>> == Directions for Submitting == | 
| Line 66: | Line 28: | 
| If your team is participating in the model competition, your {{{ZIP}}} package will contain a subdirectory for each benchmark that you solve: let us call one of such directories {{{benchmark_example}}}. | Available SOON. | 
| Line 68: | Line 30: | 
| {{{#!wiki caution In the '''Model & Solve''' Competition, you're allowed to specify a different software solution per each benchmark problem, provided it is based at its core on a declarative programming system coupled with a declarative problem specification of your choice. }}} | ## Your package should at least contain a folder named {{{bin}}}. Your package is expected ## to be run with the same configuration for all the benchmark domains, i.e., ## the package must comprise all files required for running your system on any problem encoding and any problem instance. | 
| Line 73: | Line 34: | 
| The directory layout of your {{{ZIP}}} file may look like this: {{{ . ├── benchmark_example1 │ ├── bin │ │ ├── run │ │ ├── mysolver │ │ └── my_helper_tool │ ├── lib │ │ ├── libmysolver.so │ │ ├── libmysolver.so.4 │ │ ├── libmysolver.so.4.0.1 . . . . . . . ├── benchmark_example2 │ └── bin │ ├── run │ └── the_bm2_solver ├── benchmark_example3 │ ├── bin │ │ ├── run . . . . . . . }}} | ## {{{##!wiki caution ## You must specify a single fixed software bundle capable ## of accepting problem encodings written in the ASP-Core-2 format. ## }}} | 
| Line 100: | Line 39: | 
| In particular, {{{benchmark_example}}} must contain a directory {{{bin}}} that contains an '''executable''' file named {{{run}}}, which will be invoked during the competition run. This file can be a script invoking a binary executable, possibly using other scripts for pre- or post-processing included in your package. Don't forget to make your scripts and binaries executable using {{{chmod 755}}}. <<newicon>> A {{{zip}} file containing the folder structure needed to participate to the M&S track is available [[https://www.mat.unical.it/aspcomp2013/files/links/benchmarks/instances/packages/MSFolderStructure.zip|here]] ==== Input ==== A problem instance in the prescribed [[https://www.mat.unical.it/aspcomp2013/files/aspinput.txt|format]] is fed to {{{run}}}'s standard input. ==== Command Line ==== {{{run}}} takes '''three''' arguments: * The first argument ({{{$1}}}, {{{argv[1]}}}, ...) is the maximum integer which is sufficient for solving the input instance ({{{0}}} if not meaningful for the problem/instance at hand). This information can be used (or not) depending on whether your underlying solver needs to know a priori this bound. * The second argument ({{{$2}}}, {{{argv[2]}}}, ...) is the maximum nesting level of Skolem terms which is sufficient for solving the input instance ({{{0}}} if not meaningful for the problem/instance at hand). This information can be used (or not) depending on whether your underlying solver needs to know a priori this bound, e.g. for guaranteeing termination. * The third argument ({{{$3}}}, {{{argv[3]}}}, ...) is a comma-separated list of output predicates {{{p1/n1,p2/n2,...}}} with predicate names {{{pi}}} and arities {{{ni}}}. This list will differ on a per problem basis (not per instance), and coincides with the list of output predicates which should be included in the output of the run script. Of course, the three arguments can be taken into account or not by the submitted scripts at participant's will and necessity (for instance, output predicate names can be hardwired in the {{{run}}} script or elsewhere). ==== Output ==== The output of {{{run}}} must be printed to standard output, and a proper exit code must be issued, according to the format specified [[https://www.mat.unical.it/aspcomp2013/files/aspoutput.txt|here]]. An example of {{{run}}} script can be found [[RunModelSolve|here]] (forthcoming). <<Anchor(System)>> == System Competition == If your team is participating to the System competition, your package should at least contain a folder named {{{bin}}}. Your package is expected to be run with the same configuration for all the benchmark domains, i.e., the package must comprise all files required for running your system on any problem encoding and any problem instance. {{{#!wiki caution In the '''System''' Competition, you must specify a single fixed software bundle capable of accepting problem encodings written in the ASP-Core-2 format. }}} The directory {{{bin}}} must contain an '''executable''' file called {{{run}}}, which will be invoked during the Competition run. {{{ . ├── bin │ ├── run │ ├── mysolver │ └── my_helper_tool ├── lib │ ├── libmysolver.so │ ├── libmysolver.so.4 │ ├── libmysolver.so.4.0.1 . . . . . }}} | ## The directory {{{bin}}} must contain an '''executable''' file called {{{run}}}, which will be invoked during the Competition run. ## {{{ ## ## . ## ## ├── bin ## ## │ ├── run ## ## │ ├── mysolver ## ## │ └── my_helper_tool ## ## ├── lib ## ## │ ├── libmysolver.so ## ## │ ├── libmysolver.so.4 ## ## │ ├── libmysolver.so.4.0.1 ## ## . . ## ## . . ## ## . ## }}} | 
| Line 156: | Line 56: | 
| This file can be a script invoking a binary executable, possibly using other scripts for pre- or post-processing provided in your package. Don't forget to make your scripts and binaries executable using {{{chmod 755}}}. | ## This file can be a script invoking a binary executable, possibly using other scripts for pre- or post-processing provided in your package. ## Don't forget to make your scripts and binaries executable using {{{chmod 755}}}. | 
| Line 159: | Line 59: | 
| ==== Input ==== | ## === Input === | 
| Line 161: | Line 61: | 
| A problem instance, '''together with an ASP-Core-2''' program, is fed to {{{run}}}'s standard input. The problem instance concatenated with the ASP-Core-2 encoding complies with the ASP-Core-2 2.01c [[https://www.mat.unical.it/aspcomp2013/files/ASP-CORE-2.01c.pdf|grammar]]. | ## A problem instance, '''together with an ASP-Core-2''' program, is fed to {{{run}}}'s standard input. The problem instance concatenated ## with the ASP-Core-2 encoding complies with the ASP-Core-2 2.01c [[https://www.mat.unical.it/aspcomp2013/files/ASP-CORE-2.01c.pdf|grammar]]. | 
| Line 164: | Line 64: | 
| ==== Command Line ==== | ## === Command Line === | 
| Line 166: | Line 66: | 
| {{{run}}} takes '''three''' arguments: | ## {{{run}}} takes '''three''' arguments: | 
| Line 168: | Line 68: | 
| * The first argument ({{{$1}}}, {{{argv[1]}}}, ...) is the maximum integer which is sufficient for solving the input instance ({{{0}}} if not meaningful for the problem/instance at hand). * The second argument ({{{$2}}}, {{{argv[2]}}}, ...) is the maximum nesting level of function symbols which is sufficient for solving the input instance ({{{0}}} if not meaningful for the problem/instance at hand). * The third argument ({{{$3}}}, {{{argv[3]}}}, ...) is a comma-separated list of output predicates {{{p1/n1,p2/n2,...}}} with predicate names {{{pi}}} and arities {{{ni}}}. This list specifies which output predicates should be included in the output of the run script. Note that, for avoiding syntactic problem recognition techniques, predicate names might be masked/renamed and might not coincide with output predicate names listed in public problem specifications. | ## ## * The first argument ({{{$1}}}, {{{argv[1]}}}, ...) is the maximum integer which is sufficient for solving the input instance ({{{0}}} if not meaningful for the problem/instance at hand). ## ## * The second argument ({{{$2}}}, {{{argv[2]}}}, ...) is the maximum nesting level of function symbols which is sufficient for solving the input instance ({{{0}}} if not meaningful for the problem/instance at hand). ## ## * The third argument ({{{$3}}}, {{{argv[3]}}}, ...) is a comma-separated list of output predicates {{{p1/n1,p2/n2,...}}} with predicate names {{{pi}}} and arities {{{ni}}}. This list specifies which output predicates should be included in the output of the run script. Note that, for avoiding syntactic problem recognition techniques, predicate names might be masked/renamed and might not coincide with output predicate names listed in public problem specifications. | 
| Line 172: | Line 72: | 
| Of course, the first two arguments can be taken into account or not by submitted scripts at participant's will and necessity (for instance, a system not having particular constraints on termination when function symbols are into play, can ignore the second argument). The third argument must be explicitly used for filtering and preparing output data such that the checker can verify your solution. | ## Of course, the first two arguments can be taken into account or not by submitted scripts at participant's will and necessity (for instance, a system not having particular constraints on termination when function symbols ## are into play, can ignore the second argument). ## The third argument must be explicitly used for filtering and preparing output data such that the checker can verify your solution. | 
| Line 176: | Line 76: | 
| ==== Output ==== | ## === Output === | 
| Line 178: | Line 78: | 
| The output of {{{run}}} must be printed to standard output, and a proper exit code must be issued, according to the format specified [[https://www.mat.unical.it/aspcomp2013/files/aspoutput.txt|here]]. | ## The output of {{{run}}} must be printed to standard output, and a proper ## exit code must be issued, according to the format specified [[https://www.mat.unical.it/aspcomp2013/files/aspoutput.txt|here]]. | 
| Line 181: | Line 81: | 
| An example of {{{run}}} script can be found [[RunSystem|here]] (forthcoming). == How to compress files using the 7z format == We strongly advise to use the {{{7z}}} tool for creating a {{{ZIP}}} file with LZMA compression level 9 like this: {{{ $ cd /path/to/my/sandbox/usr/local $ 7z a -tzip -mx=9 -mm=lzma -mfb=64 -md=64m /tmp/mysolver.zip . 7-Zip [64] 9.20 Copyright (c) 1999-2010 Igor Pavlov 2010-11-18 p7zip Version 9.20 (locale=en_US.UTF-8,Utf16=on,HugeFiles=on,24 CPUs) Scanning Creating archive /tmp/mysolver.zip Compressing bin/run Compressing bin/mysolver Compressing lib/libmysolver.so Compressing lib/libmysolver.so.2 Compressing lib/libmysolver.so.2.0.1 Everything is Ok }}} {{{7z}}} is available in Ubuntu 12.04 with the {{{p7zip-full}}} package. You may also use standard {{{zip}}} if your package does not exceed easychair's filesize limit: {{{ $ cd /path/to/my/sandbox/usr/local $ zip -r /tmp/mysolver.zip . adding: lib/ (stored 0%) adding: lib/libmysolver.so.2.0.1 (deflated 63%) adding: lib/libmysolver.so.2 (deflated 63%) adding: lib/libmysolver.so (deflated 63%) adding: bin/ (stored 0%) adding: bin/mysolver (deflated 20%) adding: bin/run (deflated 76%) }}} == Uploading the submission package == Use Easychair for uploading your submission package: * go to http://www.easychair.org/conferences/?conf=aspcomp2013 * click on your submission '''Paper XXX''' * click on '''Submit a new version''' * click on '''Browse...''' in the '''Submission''' entry * select your {{{ZIP}}} file in the file selection window * click on '''Submit a New Version''' You can submit multiple times by the final deadline. | ## An example of {{{run}}} script can be found [[https://www.mat.unical.it/aspcomp2013/files/links/aspexec/run|here]] | 
Participant submission procedure
Application Procedure
Participants willing to apply for the competition can send an email (starting from March 1st, 2014) to this address specifying:
- the name of their team;
- names and affiliation of the team members (institution, research group);
- name and number of the systems the team will submit;
- please indicate whether a system is an updated version of a solution submitted to the 2013 edition;
- specific software requirements: e.g. linux packages/libraries needed to run your system.
- language support: e.g. my submission supports normal logic programs and aggregates, it does not support weak constraints and function symbols... and so on.
Applicants will get a private e-mail with the instructions for submitting systems and login credentials for accessing our Competition server through ssh.
Detailed submission instructions, competition rules, hardware and software settings will be published soon. Pease check this page frequently.
Directions for Submitting
Available SOON.



