Seml

Latest version: v0.5.4

Safety actively analyzes 682416 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 4 of 5

0.3.1

Not secure
Features
- You can now more conveniently change the `SETTINGS` in `settings.py` via a file in `$HOME/.config/seml/settings.py`.

Bug fixes
- correctly specify the pyyaml version (40)
- fix `seml jupyter` for pip installations (41)

0.3.0

Not secure
Highlights
- **Collaborating local workers**: Workers now dynamically load experiments from the MongoDB, and even collaborate with Slurm
- Interactive **debugging** on Slurm (`--debug`) and remotely via debugpy (`--debug-server`; supported by VS Code)
- Advanced **config checking**: SEML now prevents duplicates, missing fixed/random/grid blocks, and invalid values in the `seml` and `slurm` blocks
- **Nested parameters** in dictionaries via dot-notation
- **`seml jupyter`** command to easily start a Jupyter notebook in Slurm
- Mattermost observer
- Slurm templates

Breaking changes
- `seml queue` is now `seml add`, and sets the experiment state to `STAGED`, in analogy to `git`. SEML still correctly handles old experiments in the `QUEUED` state.
- SEML now strictly disallows all forms of duplicate parameters and blocks in the config. The exception are only sub-configs, in which you can overwrite more general parameters.
- SEML now disallows configs and sub-configs that have no fixed/random/grid blocks and unrecognized values in the `seml` and `slurm` blocks
- parameter collections are deprecated in favor of dot-notation
- removed `--unobserved` option
- renamed `--dry-run` to `--print-command`
- renamed `--no-config-check` to `--no-sanity-check`
- `--output-to-console` now _also_ prints to console (disable file output via `--no-file-output`)
- removed backwards compatibility to specifying `db_collection_name` in config

Features
- Workers now dynamically load experiments from the MongoDB. `seml start --local` starts one worker. You can then spin up more workers with `seml launch-worker`. Workers can even take over pending experiments from Slurm with the `--steal-slurm` option (without race conditions). Moreover, we added GPU and CPU resource options to conveniently manage multiple workers on the same system.
- Interactive debugging in Slurm via `--debug`
- **`--debug-server`**: Attach your IDE to your experiment as a debug client via debugpy (supported by VS Code, PyCharm doesn't support anything comparable)
- **`seml jupyter`** command to easily start a Jupyter notebook in Slurm
- detect and prevent duplicates in config files. Warn about redefinitions in sub-configs.
- **Nested parameters** in dictionaries via dot-notation
- New advanced example with nested parameters, dictionaries and Sacred prefixes
- **Mattermost observer**: Send messages on experiment start, completion, failure, interruption, and/or periodically (e.g. every hour/day), including any experiment info (e.g. current accuracy, epoch)
- **Slurm templates**: Define custom templates for the sbatch options of differents kinds of jobs/experiments (Jupyter, GPU, CPU, long, high-priority, ...) in `settings.py` and easily use them in your SEML configs
- `filter_dict` and `mongodb_config` parameters in `get_results`
- `--no-code-checkpoint` option to prevent code storage. Useful e.g. for debugging.
- `--no-file-output` option to stop printing to an output file
- some first tests (with GitHub actions thanks to sigeisler)

Bug fixes
- fix distribution in zip files and Python eggs
- print full Slurm node list (thanks to jayargo)
- fix missing directory in seml configure
- switch to stdlib `random` for True/False samples (thanks to cqql)
- configuration files without Slurm block (thanks to johannesjung)
- correctly detect killed jobs in disjoint, long, and singleton job array ranges
- use `None` as defaults to avoid changing the Python-internal default values
- empty `logs` folder in example to avoid errors
- correctly handle numbers as collection names
- fix TF1 GPU memory stat (thanks to mnchsmn)
- catch invalid sub-configs that do not contain a fixed/random/grid block

0.2.4

Not secure
Features
- Consistently interpret all relative file paths from the `project_root_dir`, including the `executable` and `output_dir`. I.e. `project_root_dir` is now always the current working directory (cwd).
- Save total runtime in stats as `real_time`

Bug fixes
- Correctly include `slurm_template.sh` in PyPI package (19)
- Detect all valid Slurm states (20)
- Preserve logging setup when importing executable
- Correctly parse objects known by BSON, but unknown by JSON in `get_results`

Breaking changes
- We now interpret all relative file paths from the `project_root_dir`, including the `executable` and `output_dir`. The current version is still backward compatible with interpreting it from the config file (in which case the directory containing the config file is the cwd), but this will probably change in the future.

0.2.3

Not secure
- Fix prepare_experiment collection name parsing
- Fix filtering experiments by user in some shells
- Fix cancel_experiments backwards compatibility
- Check if output_dir exists during local jobs

**Breaking changes**:
- Moved `name` parameter to `SEML` block

0.2.2

Not secure
Commands now specify the collection name instead of the config file name, e.g.
- `seml collection queue config.yaml`
- `seml collection start`
- `seml collection status`

**Breaking changes:**
- Specifying a config file in the command now raises a deprecation warning.
- Removed `db_collection` from the config file.

0.2.1

Not secure
Fix checking for Sacred special args

Page 4 of 5

© 2024 Safety CLI Cybersecurity Inc. All Rights Reserved.