| Size: 7649 Comment: add dotnet and rust links |  ← Revision 61 as of 2025-09-17 12:46:51  ⇥ Size: 1752 Comment: add docker images pointer | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 5: | Line 5: | 
| All simulation programming projects must meet these requirements on a standard student account of a CTB60 ("alamode") machine. | All simulation programming projects must be gradable on the course [[DockerImage|docker image]], '''without any additional tools or libraries added to it''', ''save those added by the `/usr/local/install-scripts/` language setup scripts''. | 
| Line 7: | Line 8: | 
| Your submission must build '''without''' extra installs of additional packages or libraries to the grader's account.  The only exceptions to this requirement are: <<Include(Assignments/Requirements/Exceptions)>> | <<Include(SubmissionRequirements)>> | 
| Line 10: | Line 10: | 
| = Requirements = 1. Submitted as a `.zip` or `.tar.(Z|gz|bz2|xz)` compressed archive. '''Do not use RAR archives.''' {{{#!wiki warning If you are generating an archive with symbolic links from another `*nix` box, just use `tar` --- the invocation of `zip` seems to be tricky (or there are inconsistent `zip` versions in Linux land). }}} 1. The unrolled archive will be scanned for a '''top-most''' key file: '''only one of these may exist''': a. A `Makefile` compatible with [[http://www.gnu.org/software/make/|GNU make]] (this is the standard `make` on a Linux box) a. A `Build.sh` Bourne (`sh`) or `bash` script {{{#!wiki important Case in names are important! It is `Makefile` with a capital `M`, not `makefile`; likewise for `Build.sh`. This is a 400 level course in a CS program, I think it is reasonable to expect students to be able to either 1. develop in a Unix environment 1. transport a system independent code base<<FootNote(Sims should be pretty OS agnostic)>> from Windows or MacOS X to a Unix environment. | = Examples = <<Anchor(SubmissionTemplates)>> <<Include(SubmissionTemplates)>> | 
| Line 24: | Line 14: | 
| If you need help doing this '''please let me know,''' I'm happy to assist. }}} In either case, after running<<FootNote(The name of your directory containing `Makefile` or `Build.sh` does not have to be named `top`, the example is simply showing that `make` and `bash` will be run from ''within'' your top directory.)>> {{{ top $ make }}} or {{{ top $ bash Build.sh }}} there should be an application<<FootNote(This means the [[http://en.wikipedia.org/wiki/Filesystem_permissions#Permissions|Unix executable bit]] is set.)>> named `SIM` that is your simulator for the assignment.<<FootNote(This does not preclude `SIM` existing before `make` or `Build.sh` are run, and [[attachment:DoNothingBuild.sh|a build script]] might be a mere placeholder. Such a setup is applicable for certain languages.)>> That's all capitals, `SIM`. 1. `SIM` will be invoked with the appropriate command line arguments for the assignment, results required by the assignment should be printed on `stdout`. Any output line with an assignment required result '''must''' have `OUTPUT` as the first word (token). a. <<Anchor(OUTPUT)>>Any `stdout` output line with a required result must have `OUTPUT` as the first word (token). a. All numerical values required by an assignment must have whitespace (which includes end of line) around them. a. <<Anchor(textoutput)>>Required textual output should be surrounded by single colons (`:`). a. The '''order''' for results is assignment specific and '''important''', they must emanate from the application in the order dictated by the assignment. 1. Your submitted archive should '''not''' contain unnecessary files (`.o`, `.pyc`, `*.h~`, `Cargo.lock` ) or executable machine or vm code (`*.class` files, a `__pycache__` directory, `bin`, `target` or `obj` directory). 1. Files and directories that begin with an '''underscore''' are reserved for use by your instructor, TA, or grader. a. Your submitted archive file should not have any entries that begin with an underscore. a. Your `SIM` should not use or create files or directories that begin with an underscore. 1. <<Anchor(doc)>> Written answers or graphs should always be provided in a `doc` subdirectory, the `doc` directory should be alongside your `Makefile` or `Build.sh`. a. Prose should be provided in either a text file, an HTML file, or a PDF file. a. Graphs may be embedded in your written answers (if you provide HTML or PDF). If your answers are written in a simple text file, provide your graphs in a common raster image file format (PNG, JPEG, ...), SVG, or (preferably) PDF. Refer to the graphs by name in your answer write-up. a. Graphs provided for assignments without a required written component should be in appropriately named files (still, of course in `doc`) and should be self-explanatory on viewing.<<FootNote(Heaven forbid, don't forget a graph title.)>> a. Students may always feel free to submit a `README` file for any assignment, but it needs to be in `doc` and follow these conventions. 1. Your `SIM` should not prompt the user for any input, nor pause the display of console messages for the human eye. == Examples == === Submission Templates === <<Anchor(SubmissionTemplates)>>Here are example trees for submissions, one each for the most common languages used by students. If you are using another language, look at one of the templates for a similar language. {{{#!wiki tip Templates with a `Makefile`: edit `Project.mak` instead --- much easier. }}} * <<DjHR(submit-c++.tar.bz2,C++ language)>> * <<DjHR(submit-java.tar.bz2,Java language)>> * <<DjHR(submit-python3.tar.bz2,Python3 language)>> * <<DjHR(submit-ruby.tar.bz2,Ruby language)>> * <<DjHR(submit-rust-build.tar.bz2,Rust language using build script)>> * <<DjHR(submit-rust-makefile.tar.bz2,Rust language using make file)>> * <<DjHR(submit-dotnet.tar.bz2,.NET language)>> Here is a <<DjHR(pure-gmake-cxx.tar.bz2,source tarball)>> that is a "more pure" example of a non-trivial `Makefile` for building C++. This example doesn't use my `Project.mak` build configuration file. If you like to use IDEs such as Eclipse or M$``Vs: 1. do your work in the IDE with a simple source layout 1. copy your code into the appropriate extracted template on a CSM Linux box 1. '''test''' to make sure it builds and runs correctly 1. clean it out (there is a `clean` target in the provided Makefiles, otherwise remove residual files by hand) 1. `tar` or `zip` it up and submit. If your IDE purports to generate Makefiles, then give it a try (YMMV). Be sure to '''test on a Mines machine!''' {{{#!wiki warning Beware that M$ based IDEs frequently generate `NMAKE` files, which are a far cry from conventional Unix `make` compatible build files, and are uniformly mocked by `gmake`. }}} === Output Formatting === | == Output Formatting == | 
All simulation programming projects must be gradable on the course docker image, without any additional tools or libraries added to it, save those added by the /usr/local/install-scripts/ language setup scripts.
Requirements
- Submitted as a .zip or .tar.(Z|gz|bz2|xz) compressed archive. Do not use RAR archives. - If you are generating an archive with symbolic links from another *nix box, just use tar --- the invocation of zip seems to be tricky (or there are inconsistent zip versions in Linux land). 
- The unrolled archive will be scanned for two top-most key file - An Install file, this specifies which docker image install scripts should be run so tools for the language(s) your project is coded in are available. - Install is not a script file! It simply contains the key names for the languages required. These "key names" - are the names of the scripts without install- or .sh parts. Some examples: 
- If your project needs gcc for C and (or) C++, Install should have one line in it: - gcc - Why? Because the docker image install script is named /usr/local/install-scripts/install-gcc.sh If you prefer the LLVM toolchain, specify clang`. 
- If your project needs both Java and Kotlin, your Install should be: - java kotlin 
 
- Sanitation of the Install script contents is draconian: only letters, digits and newline (\n) are considered data. - Technically, an Install file is optional, If you decide to write your project in sh(1)... well, have fun with that. 
 
 
- Only one of a Makefile or Build.sh script must exist: - A Makefile compatible with GNU make (this is the standard make on a Linux box) 
- A Build.sh Bourne (sh) or bash script - Case in names are important! It is Makefile with a capital M, not makefile; likewise for Build.sh. This is a 400 level course in a CS program, I think it is reasonable to expect students to be able to either - develop in a Unix environment
- transport a system independent code base1 from Windows or MacOS X to a Unix environment. 
 - If you need help doing this please let me know, I'm happy to assist. 
 - In either case, after running2 - top $ make or- top $ bash Build.sh - there should be an application3 named SIM. 4 Note that SIM is always in all capital letters. 
 
- Your submission must build without extra installs of additional packages or libraries to the course docker image. 
- SIM will be invoked with the appropriate command line arguments for the assignment, results required by the assignment should be printed on stdout. - Any stdout output line with a required result must have OUTPUT as the first word (token). 
- All numerical values required by an assignment must have whitespace (which includes end of line) around them.
- Required textual output should be surrounded by single colons (:). 
- The order for results is assignment specific and important, they must emanate from the application in the order dictated by the assignment. 
- Depending on the assignment, SIM may be required to write a specifically formatted result file, in which case the OUTPUT rules above won't apply to the contents of the file. 
 
- Your submitted archive should not contain unnecessary files (.o, .pyc, *.h~, Cargo.lock ) or executable machine or vm code (*.class files, a __pycache__ directory, bin, target or obj directory). 
- Files and directories that begin with an underscore are reserved for use by your instructor, TA, or grader. - Your submitted archive file should not have any entries that begin with an underscore.
- Your SIM should not use or create files or directories that begin with an underscore. 
 
- Written answers or graphs should always be provided in a doc subdirectory, the doc directory should be alongside your Makefile or Build.sh. - Prose should be provided in either a text file, an HTML file, or a PDF file.
- Graphs may be embedded in your written answers (if you provide HTML or PDF). If your answers are written in a simple text file, provide your graphs in a common raster image file format (PNG, JPEG, ...), SVG, or (preferably) PDF. Refer to the graphs by name in your answer write-up.
- Graphs provided for assignments without a required written component should be in appropriately named files (still, of course in doc) and should be self-explanatory on viewing.5 
- Students may always feel free to submit a README file for any assignment, but it needs to be in doc and follow these conventions. 
 
- Your SIM should not prompt the user for any input, nor pause the display of console messages for the human eye. 
- You must submit the actual regular files of your program source and build config. Don't arrange downloads of your code from online repositories like github, gitlab, or even your own privately hosted repo. - Why? primarily if an instructor or grader can download your project submission in full without some form of authentication, you are effectively sharing your solution with the world and more specifically with all the current and future students of the course. That's pretty much a no-no with respect to academic integrity. 
 Other reasons also include: your submitted code should be a snapshot that cannot be easily forged or manipulated. There are technical ways to gaurantee this could not be done with your online repo but they are overly complex when the simplist solution is to simply put your regular source files into an archive and submit them on the course grading server.
 
Examples
Submission Templates
Here are example trees for submissions, one each for the most common languages used by students. If you are using another language, look at one of the templates for a similar language.
Templates with a Makefile and a Project.mak: edit Project.mak which is the intended way to configure the build.
- Rust language using build script - contact instructor if you have issues. 
- .NET language using build script - contact instructor if you have issues 
Here is a source tarball that is a "more pure" example of a non-trivial Makefile for building C++. This example doesn't use my Project.mak build configuration file.
If you like to use IDEs such as Eclipse or M$Vs:
- do your work in the IDE with a simple source layout
- copy your code into the appropriate extracted template on a CSM Linux box
- test to make sure it builds and runs correctly 
- clean it out (there is a clean target in the provided Makefiles, otherwise remove residual files by hand) 
- tar or zip it up and submit. 
If your IDE purports to generate Makefiles, then give it a try (YMMV). Be sure to test on a Mines machine!
Beware that M$ based IDEs frequently generate NMAKE files, which are a far cry from conventional Unix make compatible build files, and are uniformly mocked by gmake.
Output Formatting
Suppose a simulation assignment dictates:
- Your SIM should accept two arguments. The first argument is the seed for your pRNG, the second argument is the number of experimental runs. 
- Your SIM should display 3 numerical results: the average theta, the minimum theta, and the median alpha across all the experimental runs. 
Then all of the following outputs would be acceptable:
- $ ./SIM 38478 1000 OUTPUT 7.43 -2.1113 7483 $ - $ ./SIM 38478 1000 OUTPUT 7.43 OUTPUT -2.1113 OUTPUT 7483 $ - $ ./SIM 38478 1000 OUTPUT Average theta 7.43 minimum theta -2.1113 middle alpha 7483 $ - $ ./SIM 38478 1000 1000 experimental runs beginning! ... half-way there ... woot! look at us go OUTPUT Average theta 7.43 minimum theta -2.1113 maximum theta 32.874 OUTPUT middle alpha 7483 whew. $ - $ ./SIM 38478 1000 OUTPUT Average theta 7.43 minimum theta -2.1113 maximum theta =32.874= middle alpha 7483 $ 
But this one is not acceptable for two different reasons:
- $ ./SIM 38478 1000 OUTPUT Median alpha=7483 Average theta=7.43 Minimum theta=-2.1113 $ 
- The applications in this course should be pretty OS agnostic (1) 
- The name of your directory containing Makefile or Build.sh does not have to be named top, the example is simply showing that make and bash will be run from within your top directory. (2) 
- This means the Unix executable bit is set. (3) 
- This does not preclude SIM existing before make or Build.sh are run, and a build script might be a mere placeholder. Such a setup is applicable for certain languages. (4) 
- Heaven forbid, don't forget a graph title. (5)