Systems
This page describes current plans for the programming environment which will be available to each NWERC 2024 team. Please note that these plans are subject to change.
Each team will have access to one workstation, shared between team members.
Software
The software configuration will consist of the following:
- OS:
- Ubuntu 22.04 LTS Linux (64-bit)
- Desktop:
- Xfce
- Editors:
- vim
- gvim
- nano
- neovim
- emacs
- gedit
- geany
- kate
- IDEs:
- IntelliJ IDEA Community
- Version: 2022.3
- Workspace is already set up but needs to be opened from the welcome screen
- Plugins:
- IdeaVim
- CLion
- Version: 2022.3
- Workspace is already set up
- Plugins:
- IdeaVim
- PyCharm Community
- Version: 2022.3
- Workspace is already set up
- Plugins:
- IdeaVim
- Eclipse
- Version: 2022-12
- Plugins:
- PyDev
- Visual Studio Code
- Version: 1.82.2
- Plugins:
- C/C++ - Microsoft
- C# - Microsoft
- Code Runner - Jun Han
- Debugger for Java - Microsoft
- ESLint - Dirk Baeumer
- Language Support for Java - Red Hat
- Python - Microsoft
- TSLint - Microsoft
- Code::Blocks
- Version: 20.03
- IntelliJ IDEA Community
Languages
The following languages are allowed during the contest:
- C
- Compiler version: 11.3.0
- Standard: gnu17
- C++
- Compiler version: 11.3.0
- Standard: gnu++20
- Python
- Version: PyPy 7.3.9 (Python 3.8.13)
- Java
- Version: 17.0.6
- Kotlin
- Version: 1.7.21
Note that Python 2 is no longer supported.
Compilation of Submissions
During the contest, teams will submit proposed solutions to the contest problems to the Judges using the DOMjudge contest control system (version 8.1). This can be done through the web interface, or using the submit client. Source files submitted to the Judges will be compiled using the following command line arguments for the respective language:
- C:
gcc -std=gnu17 -x c -Wall -O2 -static -pipe -o $1 "$1.c" -lm
- Available as
mygcc
- C++:
g++ -std=gnu++20 -x c++ -Wall -O2 -static -pipe -o $1 "$1.cpp" -lm
- Available as
mygpp
- Python 3:
pypy3 $@
- Available as
mypython
- Java:
javac -encoding UTF-8 -sourcepath . -d . $@
- Available as
myjavac
- Kotlin:
kotlinc -d . $@
- Available as
mykotlinc
Execution of Submissions
- For each language, if the above compilation step is successful then the submission will be executed as follows:
- For C/C++: the executable file generated by the compiler will be executed to generate the output of the submission.
- For Python 3: the main source file will be executed by the PyPy3 Python3 interpreter to generate the output of the submission.
- For Java: the compiled main class will be executed using the following command:
java -Dfile.encoding=UTF-8 -XX:+UseSerialGC -Xss65536k -Xms1966080k -Xmx1966080k $@
- Available as
myjava
- For Kotlin: the compiled main class will be executed using the following command:
kotlin -Dfile.encoding=UTF-8 -J-XX:+UseSerialGC -J-Xss65536k -J-Xms1966080k -J-Xmx1966080k $@
- Available as
mykotlin
Compilation and execution as described above will take place in a “sandbox” on a dedicated judging machine. The judging machine will be identical to the machines used by teams (see Hardware).
The sandbox will allocate 2 GiB of memory; the entire program, including its runtime environment, must execute within this memory limit. For interpreted languages (Python, Java, and Kotlin) the runtime environment includes the interpreter (that is, the PyPy3 interpreter for Python and the JVM for Java/Kotlin). The sandbox memory allocation size will be the same for all languages and all contest problems. For Java and Kotlin, the above commands show the stack size and heap size settings that will be used when the program is run in the sandbox.
Documentation / Specification / Reference material
The following reference materials will be available on the teams’ workstations through the browser: