Skip to content
All posts

From Graph Neural Diffusion to Neural Radiance Volume Fields (NeRV)

Graph Neural Diffusion

Neural Radiance Volume Fields (NeRV)

Evolving Neural Topologies

Activation Functions

Overfitting and Regularisation

Epochs, Batches, and Iterations

 

Graph Neural Diffusion

Graph Neural Diffusion is a novel method that combines graph neural networks (GNNs) with diffusion processes to better model the spread of information, behaviours, or signals across networks. It leverages the mathematical properties of diffusion to capture complex, time-dependent interactions in graph-structured data.

Traditional GNNs focus on aggregating and updating node and edge information across fixed graph structures. However, they struggle with dynamic systems where relationships or signals evolve over time. Graph Neural Diffusion introduces continuous-time diffusion mechanisms into GNNs, allowing for the modelling of temporal processes like information propagation, influence spread, or disease transmission.

The diffusion process involves simulating the flow of signals (e.g., information, influence, or energy) across edges in the graph, governed by physical or probabilistic laws. This allows the model to capture both short-term interactions (e.g., immediate neighbours) and long-range dependencies (e.g., multi-hop relationships) dynamically. Applications include social network analysis, financial contagion modelling, and real-time recommendation systems.

In epidemiology, Graph Neural Diffusion has been used to simulate the spread of infectious diseases like COVID-19 by modelling human interactions across transportation and social networks. The approach can predict how an outbreak might propagate under different scenarios, such as lockdowns or vaccination campaigns.

Neural Radiance Volume Fields (NeRV)

Neural Radiance Volume Fields (NeRV) extend the concept of Neural Radiance Fields (NeRF) by incorporating volumetric data to represent 3D objects and scenes more comprehensively. This approach is particularly valuable for applications requiring high fidelity and dynamic interactions, such as virtual reality or digital twins.

Traditional NeRF models focus on representing 3D scenes as a continuous field of radiance, reconstructing views from sparse 2D images. NeRV builds on this by explicitly modelling volumetric data, enabling the representation of internal structures and dynamic changes over time. By learning both the surface geometry and volumetric properties, NeRV can handle applications like fluid dynamics or transparent materials (e.g., glass, water).

Training NeRV involves optimising a neural network to approximate the 3D radiance and density fields from a set of images or sensor data. This provides a more complete understanding of the scene, including both external appearances and internal properties. The integration of volumetric data also enables dynamic scene reconstruction, where objects in the scene can move or deform realistically.

In digital twins for smart cities, NeRV can create highly detailed 3D representations of urban environments, including buildings, traffic, and weather conditions. Unlike traditional methods, NeRV can simulate dynamic changes like traffic flow or weather patterns, enabling more accurate planning and real-time monitoring.

Evolving Neural Topologies

Evolving Neural Topologies refers to the dynamic modification of a neural network’s architecture during training. Instead of relying on fixed architectures, this approach allows networks to grow, shrink, or restructure themselves adaptively to optimise performance and computational efficiency.

This concept builds on the idea that a neural network’s structure should evolve to match the complexity of the problem it is solving. During training, certain neurons or connections may be added (growth) or removed (pruning) based on their contribution to the model’s accuracy and efficiency. Techniques like genetic algorithms, neuroevolution, or reinforcement learning are often used to guide this process.

Evolving Neural Topologies offers several benefits:

  • Efficiency: Reduces unnecessary complexity by pruning redundant parameters, making models faster and more resource-efficient.
  • Adaptability: Allows networks to adjust their capacity to match the problem’s difficulty dynamically.
  • Improved Generalisation: By simplifying the network, the risk of overfitting decreases, leading to better performance on unseen data.

In autonomous vehicles, evolving neural topologies have been applied to optimise neural networks used for perception and decision-making. As the system encounters new driving environments, the network restructures itself to handle unique challenges, such as processing additional sensor data in high-traffic areas or reducing computational load in simpler scenarios.

Activation Functions

Activation functions are mathematical functions used in neural networks to introduce non-linearity, allowing the network to learn and model complex patterns in the data. Without them, neural networks would behave like simple linear models, unable to capture intricate relationships.

In a neural network, each neuron computes a weighted sum of its inputs and passes this sum through an activation function. This function decides whether the neuron should "activate" or contribute to the final output. By introducing non-linear transformations, activation functions enable the network to approximate non-linear relationships in the data, which are essential for tasks like image recognition or natural language processing.

There are several commonly used activation functions, each with unique properties:

  • ReLU (Rectified Linear Unit): Outputs the input directly if it’s positive and zero otherwise. It’s computationally efficient and helps avoid the "vanishing gradient problem."
  • Sigmoid: Maps inputs to a range between 0 and 1, making it useful for probabilities but prone to saturation issues.
  • Tanh (Hyperbolic Tangent): Similar to Sigmoid but maps inputs to a range between -1 and 1, offering better gradients for inputs near zero.
  • Softmax: Often used in the output layer of classification tasks, Softmax converts raw scores into probabilities that sum to 1 across classes.

The choice of activation function affects the network’s performance and the speed of training, making it a critical component of neural network design.

In image classification, suppose you're training a neural network to distinguish between cats and dogs. The network has multiple layers, each transforming the input image data to identify features such as edges, shapes, or textures. In the hidden layers, you might use the ReLU activation function because it helps the network learn efficiently by allowing only positive values to pass through, avoiding issues like vanishing gradients (which can occur with functions like Sigmoid).

At the output layer, the Softmax activation function converts the raw scores into probabilities. For instance, the output might be:

  • 0.8 for “cat”
  • 0.2 for “dog.”

This means the network predicts an 80% chance the image is a cat and a 20% chance it's a dog. By using activation functions like ReLU and Softmax together, the network efficiently learns features and provides interpretable, probabilistic predictions.

For more complex cases, such as detecting multiple objects in an image (e.g., a cat and a sofa), the Sigmoid activation function might be used in the output layer, as it can provide independent probabilities for each class without forcing them to sum to one.

Overfitting and Regularisation

Overfitting occurs when a machine learning model learns the training data too well, including its noise and irrelevant patterns, leading to poor generalisation on new, unseen data. Regularisation techniques are used to mitigate overfitting by introducing constraints that prevent the model from becoming too complex.

Overfitting typically happens when a model is too flexible or has too many parameters relative to the size of the training dataset. The model memorises the training data rather than learning generalisable patterns, resulting in high accuracy on the training set but poor performance on the test set.

To combat overfitting, several regularisation techniques are employed:

  • L1 and L2 Regularisation: Add penalty terms to the loss function to constrain the magnitude of the model’s weights. L1 regularisation encourages sparsity (many weights become zero), while L2 penalises large weights without enforcing sparsity.
  • Dropout: Temporarily “drops out” (deactivates) random neurons during training, forcing the network to rely on multiple pathways and improving robustness.
  • Early Stopping: Monitors validation performance during training and stops training when the validation loss stops improving.
  • Data Augmentation: Expands the training dataset by creating modified versions of existing data, such as flipping or rotating images, helping the model generalise better.

Regularisation ensures that the model remains simple enough to capture the underlying structure of the data without overfitting to specific training examples.

In speech recognition, consider a model trained on audio clips of spoken words to classify them into categories (e.g., numbers or commands like "play" and "stop"). Without regularisation, the model might memorise the specific characteristics of the training dataset, such as background noise or speaker accents, instead of learning the general patterns that define the spoken words. This leads to poor performance on new audio inputs.

To combat this:

  • Dropout might deactivate random neurons during training. For example, if the model uses features like "pitch" and "speed," Dropout ensures it doesn’t overly rely on one feature, forcing it to learn redundantly useful patterns from other features. This makes the model more robust to variations in test audio.
  • Data augmentation could introduce noise, pitch shifts, or speed variations into the training data to simulate a variety of real-world conditions. For example, a training clip of "play" might be modified to include background chatter or be sped up slightly, teaching the model to generalise better.
  • Early stopping can monitor validation accuracy during training. If the accuracy on a validation set stops improving while the training set accuracy continues to rise, the training is halted to prevent overfitting.

By combining these techniques, the model learns generalisable patterns that perform well across a range of audio environments and speakers, not just those present in the training data.

Epochs, Batches, and Iterations

Training a neural network involves breaking down the dataset into smaller parts to make learning more efficient. The concepts of epochs, batches, and iterations are fundamental to understanding how training progresses in steps rather than all at once.

  • Epoch: One full pass through the entire training dataset. During each epoch, the network sees all the data once, and its parameters (weights) are updated based on the calculated gradients. Typically, training involves multiple epochs to ensure the model learns thoroughly from the data.
  • Batch: Since feeding the entire dataset into the network at once can be computationally expensive, the data is divided into smaller chunks called batches. Each batch is used to update the model’s parameters during an iteration.
  • Iteration: A single step of training where the network processes one batch of data and updates its parameters. The number of iterations in an epoch is equal to the total number of training samples divided by the batch size.

Smaller batches result in more frequent updates and can help the model converge faster, but they may introduce noise in the gradient updates. Larger batches provide more stable updates but require more memory and may converge slower. The choice of batch size is often a trade-off between computational efficiency and training speed.

In time-series forecasting, suppose you’re building a model to predict daily stock prices based on historical data. You have 10,000 days of stock prices as your training dataset. Training this dataset all at once might overwhelm your computational resources, so you divide it into batches of 100 entries.

Each batch contains 100 consecutive days of prices, which the model uses to update its weights. For instance, one batch might include prices from January 1, 2000, to April 9, 2000, and the next might contain prices from April 10, 2000, to July 18, 2000.

If you train the model for 10 epochs, the model will see each of the 100 batches 10 times (one per epoch). This means:

  • Iterations per epoch: 10,000 entries ÷ 100 entries per batch = 100 iterations.
  • Total iterations: 100 iterations/epoch × 10 epochs = 1,000 updates to the model.

During the first few epochs, the model might struggle to identify patterns, predicting prices that are too noisy. By the 10th epoch, after seeing the data multiple times, it might capture trends like seasonal changes or long-term growth, improving its accuracy. If you notice that performance plateaus after five epochs, you could use early stopping to save computational time and avoid overfitting.

Additionally, using smaller batches (e.g., 50 entries) might speed up convergence because the model updates weights more frequently, although at the cost of noisier gradient updates.