install.sh
: Ensures that you have a valid Python runtime environment and installs all requirements if necessary.update.sh
: Updates OneTrainer to the latest version and upgrades any outdated requirements in your Python runtime environment.start-ui.sh
: Launches the main OneTrainer interface.run-cmd.sh
: Executes a custom script (such as "train"), and supports providing command-line arguments. See the "running custom script commands" guide section for more details.
-
OT_CONDA_CMD
: Sets a custom Conda command or an absolute path to the binary (useful when it isn't in the user'sPATH
). If nothing is provided, we detect and useCONDA_EXE
if available, which is a variable that's set by Conda itself and always points at the user's installed Conda binary. -
OT_CONDA_ENV
: Sets the directory name (or an absolute/relative path) of the Conda environment. If a name or relative path is used, it will be relative to the OneTrainer directory. Defaults toconda_env
. -
OT_PYTHON_CMD
: Sets the Host's Python executable. It's used for creating the Python Venvs. This can be used to force the usage of a specific Python version's binary (such aspython3.10
) whenever the host has multiple versions installed. However, it's always recommended to use Conda or Pyenv instead, rather than relying on the host's unreliable system-wide Python binaries (which might change or be removed with system updates), so we don't recommend changing this option unless you really know what you're doing. Defaults topython
. -
OT_PYTHON_VENV
: Sets the directory name (or an absolute/relative path) of the Python Venv. If a name or relative path is used, it will be relative to the OneTrainer directory. Defaults tovenv
. -
OT_PREFER_VENV
: If set totrue
, Conda will be ignored even if it exists on the system, and Python Venv will be used instead. This ensures that people who usepyenv
(to choose which Python version to run on the host) can easily set up their desired Python Venv environments. Defaults tofalse
. -
OT_LAZY_UPDATES
: If set totrue
, OneTrainer's self-update process will only update the Python environment's dependencies if the OneTrainer source code has been modified since the previous dependency update. This speeds up executions ofupdate.sh
, and is generally safe, but may miss some updates and important bugfixes for external third-party dependencies. If you use this option, you must set it permanently for every script (not justupdate.sh
). Defaults tofalse
. -
OT_CUDA_LOWMEM_MODE
: If set totrue
, it enables aggressive garbage collection in PyTorch to help with low-memory GPUs. Defaults tofalse
. -
OT_PLATFORM_REQUIREMENTS
: Allows you to override which platform-specific "requirements" file you want to install. Defaults todetect
, which automatically detects whether you have an AMD or NVIDIA GPU. But people with multi-GPU systems can use this setting to force a specific GPU acceleration framework's requirements. Valid values arerequirements-rocm.txt
for AMD,requirements-cuda.txt
for NVIDIA, andrequirements-default.txt
for non-AMD/NVIDIA systems. -
OT_SCRIPT_DEBUG
: If set totrue
, it enables additional debug logging in the scripts. Defaults tofalse
.
- You can provide custom environment variables directly on the command line, as follows:
env OT_PREFER_VENV="true" OT_CUDA_LOWMEM_MODE="true" OT_PLATFORM_REQUIREMENTS="requirements-cuda.txt" ./start-ui.sh
. - You can add them to your user's persistent environment variables, so that they are always active. The process varies depending on your operating system. On Linux, you can place them in
~/.config/environment.d/onetrainer.conf
(on all Systemd-based distros), which is a plaintext file with one variable per line, such asOT_CUDA_LOWMEM_MODE="true"
. Beware that changes toenvironment.d
requires a complete system restart to take effect (there is no command for reloading them live). To verify that your environment has been set persistently, you can then open a terminal window and runprintenv <variable name>
(such asprintenv OT_CUDA_LOWMEM_MODE
) to see if your custom values have taken effect. - If you're launching OneTrainer from your own, custom scripts, then you can instead
export
the new values (which tells the shell to pass those environment variables onto child processes). For example, by having a line such asexport OT_CUDA_LOWMEM_MODE="true"
before your script calls./OneTrainer/start-ui.sh
. - If you're running OneTrainer inside a Docker/Podman container, you can instead use the ENV instruction in your
Dockerfile
/Containerfile
to set the variables, such asENV OT_CUDA_LOWMEM_MODE="true"
.
- If you've received a warning that your system's Python version is incorrect, then your system most likely doesn't have Conda installed, and has instead tried to create a Python Venv with your host's default Python version. If that version is incompatible with OneTrainer, then you'll have to resolve the problem by manually installing a compatible version. Alternatively, you are using an outdated Conda environment.
- Begin by deleting the
venv
sub-directory inside the OneTrainer directory, to erase the invalid Python Venv (which was created with the wrong Python version). If you were using Conda, then you must instead delete the outdatedconda_env
sub-directory. - Now you'll have to choose which solution you prefer.
- The most beginner-friendly solution is to install Miniconda on your system. OneTrainer will then automatically install and manage the correct Python version for you via Conda. You can stop reading here if you're choosing this solution. Everything will work automatically after that.
- Alternatively, if you prefer a more lightweight and advanced solution, then you can use pyenv, which allows you to set the exact Python version to use for OneTrainer's directory. If you're on Linux, then read their "automatic installer" section and follow the instructions. If you're on a Mac instead, then read their "Homebrew" section (which is an open-source package manager for Macs).
- After installing pyenv, you will also need to install the Python build dependencies on your system, since pyenv installs each Python version by compiling them directly from the official source code.
- Restart your shell, and then try the
pyenv doctor
command, which ensures that pyenv is loaded and verifies that your system contains all required dependencies for installing Python. - Run
pyenv install <python version>
to install whichever Python version is currently required by OneTrainer. You can look at theOT_CONDA_USE_PYTHON_VERSION
variable at the top of thelib.include.sh
file in OneTrainer's project directory, to see which Python version is recommended by OneTrainer at the moment. - Lastly, you must navigate to the OneTrainer directory, and then run
pyenv local <python version>
to force OneTrainer to use that version of Python. Your choice will be stored persistently in the hidden.python-version
file, and can be changed again in the future by running the command again. - You can now run
python --version
to verify that thepython
command in OneTrainer is being mapped to the correct Python version by pyenv. - Everything is now ready for running OneTrainer!
- Always use
run-cmd.sh
when you want to execute any of OneTrainer's CLI tasks. It automatically validates the chosen target script's name, configures the runtime environment correctly, and then runs the target script with your given command-line arguments. - For example, to run the training CLI script, you would use
./run-cmd.sh train --config-path <path to your config>
. - The names of all valid scripts can be seen in OneTrainer's
scripts/
sub-directory. - To learn more about the available command-line arguments for each script, you can execute them with the
-h
(help) argument:./run-cmd.sh <script name> -h
. For example, if you want to learn more about the "train" script, you would run./run-cmd.sh train -h
.
- If you want to automate various OneTrainer CLI tasks, then you should call
run-cmd.sh
from your own scripts (see previous guide section), since it's capable of running any OneTrainer command with your own command-line arguments. - To run multiple tasks in the same scripts, you should perform separate calls to
run-cmd.sh
. Run it as many times as required for all the custom scripts and command-line arguments that you want to perform in your own script. - It's highly recommended that you use
set -e
at the top of your own scripts (seeinstall.sh
for an example of that), since it tells Bash to exit your script if any of the OneTrainer commands fail. Otherwise your script will continue running even if a previous step has failed, which is usually not what you want!