Skip to content

UCL/Blender_Randomiser

Repository files navigation

Blender_Randomiser

Blender Randomiser is a Blender add-on that allows different scene properties to be randomised between some minimum and maximum bounds. The bounds can be defined either by:

  • Manually setting the bounds in the UI Randomiser panel located in the Geometry Nodes space

  • Using an input .json file to set the bounds from the command line

    The add-on panel called "Randomiser" is located in the Geometry Nodes space within Blender: Addon_location

Purpose

The add-on was originally developed to render a highly diverse and (near) photo-realistic synthetic dataset of laparoscopic surgery camera views. To replicate the different camera positions used in surgery as well as the shape and appearance of the tissues involved with surgery, we focused on three main components to randomise:

In the add-on, these three components appear as separate UI panels.

Additionally, there is a user-defined properties panel where the user can specify the full Python path of a property to randomise. When adding a user-defined property, a subpanel will be created to define its min and max bounds. Certain examples will and won't work (see user-defined examples)

Other functionality includes:

  • Selection toggle for including/excluding individual properties of the panel in the randomisation
  • Possibility of setting a randomisation seed for reproducibility
  • Capability to randomise the desired properties at every frame of an animation
  • Save Parameter panel with outputs saved to .json file with a timestamp

Installation via command line

  1. First, clone the repository in your desired directory
git clone https://github.com/UCL/Blender_Randomiser.git
  1. Launch a terminal at the cloned directory
    • You should be at the Blender_Randomiser directory
  2. Run the following bash script:
    sh install_randomiser.sh
    
    • This will zip the randomiser subdirectory, open the sample.blend file with Blender, and use Blender's Python interpreter to execute the install_and_enable_addons.py script.
    • The install_and_enable_addons.py script installs and enables any add-ons that are passed as command line arguments (add-ons can be passed as a path to a single Python file, or as a zip file)

Note

source ~/.bash_profile is used in the bash script to create an alias for blender with the following line in the bash_profile: alias blender=/Applications/Blender.app/Contents/MacOS/Blender

Advanced Usage

In step 3, run the randomisation_seed.sh bash script instead which has optional inputs:

  • --seed 32 which is an input to Blender
  • --input ./input_bounds.json (input to install_and_enable_addons.py)
  • --output ./output_randomisations_per_frame1697116725.310647.json (input to install_and_enable_addons.py)

Alternatively, install manually via Blender settings

License and copyright

BSD 3-Clause License

Testing

  1. Launch a terminal at the cloned directory
    • You should be at the Blender_Randomiser directory
  2. Run pytest or python -m pytest --blender-executable /Applications/Blender.app/Contents/MacOS/Blender
    • This will run our testing script which currently tests the camera transforms, materials and geometry panels.

Note

The tests make use of the pytest-blender plugin, which has pytest and other packages as dependencies (e.g. pytest-cov). These need to be installed in the site-packages directory of Blender's Python. The pytest-blender repo provides some guidance for this here. It is important to make sure you use Blender's Python interpreter and Blender's pip when installing pytest and its dependencies. Below are some tips on how to do this in Linux and MacOS.

Installing Pytest in Python

The following steps were needed to install these dependencies (tested in MacOS only):

# create and activate conda environment:
conda create -n blender-dev python=3.10 -y
conda activate blender-dev

# install pytest-blender:
pip install pytest-blender
pip install pytest-cov

# Get path to the Python interpreter that ships with Blender - this may take a long time:
blender_python="$(pytest-blender)"

# from the `Blender_Randomiser` directory, install the randomiser package with dev dependencies by running:
$blender_python -m pip install ".[dev]"

#Run pytest:
python -m pytest tests

## ~/.local/bin may need to be added to path

Installing Pytest in Blender's Python

An easy way to install these dependencies (tested in Linux only) is to run the following code in Blender's Python scripting window:

import pip
pip.main(["install", "pytest", "--user"])
pip.main(["install", "pytest-cov", "--user"])
pip.main(["install", "pytest-blender", "--user"])

Then outside of Blender, run the following command:

<path_to_blender_python> -m pytest --blender-executable <path-to-blender-executable>

Contributions

Please see Dev Notes if you wish to contribute. Feel free to submit suggestions via issues and/or PRs.

It can be helpful to use different .blend files for prototyping as it can preload certain features you're testing.

There are a few outstanding issues for enhancements:

  • Not able to currently export materials colour default value for save params button
  • Materials colour min-max can only be set to the same values in the 4D matrix using the input file
  • No functionality for reading in min-max input boundaries for user defined panel
  • Not able to currently handle an empty UIlist in the user defined panel which causes issues for other funtionality in the add-on (which are resolved by adding at least one UD prop to UIlist)
  • Can randomise all panels and save the output parameters, however the functionality to toggle on/off selection of individual parameters is only available for camera transforms and user defined properties currently, but not geometry and materials panels where all these properties will be randomised and exported when this functionality is used.
  • General refactoring for repeated code for example for the geometry and materials issue mentioned above

Authors

Tom Dowrick

Ruaridh Gollifer

Sofía Miñano

Harvey Mannering