Skip to content

RBF Nodes

Ingo Clemens edited this page Jun 8, 2023 · 4 revisions

Description

RBF Nodes is a node-based RBF solver for Blender. It allows to drive multiple properties with multiple driver values.

RBF stands for Radial Basis Function and is used to approximate or interpolate a given set of values at any defined sample point. RBFs have a wide range of applications and can be very helpful when regular ways of driving values fail in 3D animation. It basically allows the user to interpolate multiple values based on a set of sample values, or poses which are defined by the artist in advance. For standard drivers, such multi-value interpolation is not easily, or even impossible to achieve. Like, a driver in Blender can have multiple input values but only one output target. RBFs can solve multiple output values based on multiple input values.

RBF Nodes has its own node tree to make it independent from any modes and panels. Even though RBFs are commonly used for rigging to drive certain deformation effects it would be a waste to limit it to armatures only. Therefore, you can use it with objects, armatures, shaders and geometry nodes, which makes it very versatile.

Usage

For getting a quick first impression see: https://vimeo.com/727526812

For a more thorough introduction see: https://vimeo.com/727526953

Limitations

  1. In order to play back or render a scene containing RBF nodes it's mandatory that the add-on is installed. Since Blender doesn't offer any outside access to the dependency graph in it's current state, the evaluation of the RBF nodes needs to get triggered through the add-on. If the add-on is not available the nodes don't know when to evaluate.

  2. Even though the virtual number of input and output values is unlimited there is an internal limit due to technical limitations of Blender. Currently a pose can store 1024 values which are shared amongst driver and driven values. If this value is not sufficient it can be easily expanded on demand by your local coding mate.

Version 1.0.0 Important Changes

Breaking Changes

Existing RBF setups created with previous versions are not directly compatible with the new release. However, when opening files containing obsolete setups a message is displayed informing about the incompatibility. Also, no controls are accessible in the side panel of the RBF Nodes editor.

Still, older setups can be converted and updated to work with the current version of RBF Nodes. This is done by deactivating the RBF setup and activating it again.

Use the following steps to convert an existing RBF setup to match the new version:

  1. Press Reset RBF in the RBF editor's side panel.
  2. Press Activate RBF in the same panel.

Important Changes

Locked Nodes

When activating the RBF setup all input and output nodes are now locked to prevent editing. This is meant as a guide since setting up properties should always be done in advance and before defining poses.

Shape Keys

When poses already exist it's usually not possible to add input or output properties because all properties need to exist in all poses and have to be different. Also, there needs to be a rest pose. If a new property is added and a pose is set there is no way to tell what the rest pose values of this property is. The only exception are shape keys, and this has been added to the current version. When a new shape key property is added after poses already exist it can be assumed when creating a new pose that the current shape key value should only be used for this pose and be at zero for all other poses.

Other Changes

  • Updated node names to differentiate between inputs and outputs.

  • Improved interpolation for quaternion-based rotation.

  • Improved error messages.

Fixes

  • RBF calculation is offset by one frame.

  • Quaternion output depends on the Euler axis selection.

  • Shape key drivers remain when resetting the RBF.

  • Shape key data block names other than the default are not respected.