Neural Classification
Classify surface pixels into two classes using a simple two-layer feedforward neural network with sigmoid activations. Features are extracted via multi-scale Gaussian filtering. Equivalent in purpose to Gwyddion's neural.c classifier.
Inputs
| Name |
Type |
Required |
Description |
| field |
DATA_FIELD |
Yes |
Input surface to classify |
| training_mask |
IMAGE |
No |
Training labels: 0 = class A, 255 = class B. When omitted the network uses unsupervised self-labelling |
Outputs
| Name |
Type |
Description |
| mask |
IMAGE |
Binary classification mask (0 or 255) |
| probability |
DATA_FIELD |
Per-pixel probability of belonging to class B (values in 0-1) |
Controls
| Name |
Type |
Default |
Description |
| n_gaussians |
INT |
4 |
Number of Gaussian blur scales for feature extraction (1-10). Each scale uses sigma = 2^i |
| n_hidden |
INT |
16 |
Number of neurons in the hidden layer (4-128) |
| train_steps |
INT |
200 |
Number of gradient descent iterations (10-5000) |
| seed |
INT |
42 |
Random seed for weight initialisation (0-999999) |
Notes
- Feature extraction applies Gaussian blur at multiple scales (sigma = 1, 2, 4, 8, ...) to capture both fine and coarse surface structure. Each feature is normalised to zero mean and unit variance before training.
- The network architecture is input -> hidden (sigmoid) -> output (sigmoid), trained with binary cross-entropy loss and standard backpropagation.
- When a training mask is provided, the network learns in supervised mode using all pixels (0 pixels as class A targets, 255 pixels as class B targets).
- Without a training mask, the node uses an unsupervised approach: the random initial weights produce an initial classification which is then refined by self-training for a small number of steps.
- Increasing n_hidden or train_steps improves capacity but slows computation. For most surfaces, the defaults work well.
- The probability output can be fed into a Threshold Mask node for adjustable post-classification thresholding.