SGI Fellows: 
Stephanie Atherton, Marina Levay, Ualibyek Nurgulan, Shree Singhi, Erendiro Pedro
In the Topology Control project mentored by Professor Paul Kry and project assistants Daria Nogina and Yuanyuan Tao, we sought to explore preserving topological invariants of meshes within the framework of DeepSDFs. Deep Signed Distance Functions are a neural implicit representation used for shapes in geometry processing, but they don’t come with the promise of respecting topology. After finishing our ML pipeline, we explored various topology-preserving techniques through our simple, initial case of deforming a “donut” (torus) into a mug.
DeepSDFs

Signed Distance Functions (SDFs) return the shortest distance from any point in 3D space to the surface of an object. Their sign indicates spatial relation: negative if the point lies inside, positive if outside. The surface itself is defined implicitly as the zero-level set: the locus where \(\text{SDF}(x) = 0 \).
In 2019, Park et al. introduced DeepSDF, the first method to learn a continuous SDF directly using a deep neural network (Park et al., 2019). Given a shape-specific latent code \( z \in \mathbb{R}^d \) and a 3D point \( x \in \mathbb{R}^3 \), the network learns a continuous mapping:
$$
f_\theta(z_i, x) \approx \text{SDF}^i(x),
$$
where \( f_\theta \) takes a latent code \( z_i \) and a 3D query point \( x \) and returns an approximate signed distance.
The training set is defined as:
$$
X := {(x, s) : \text{SDF}(x) = s}.
$$
Training minimizes the clamped L1 loss between predicted and true distances:
$$
\mathcal{L}\bigl(f_\theta(x), s\bigr)
= \bigl|\text{clamp}\bigl(f_\theta(x), \delta\bigr) – \text{clamp}(s, \delta)\bigr|
$$
with the clamping function:
$$
\text{clamp}(x, \delta) = \min\bigl(\delta, \max(-\delta, x)\bigr).
$$
Clamping focuses the loss near the surface, where accuracy matters most. The parameter \( \delta \) sets the active range.
This is trained on a dataset of 3D point samples and corresponding signed distances. Each shape in the training set is assigned a unique latent vector \( z_i \), allowing the model to generalize across multiple shapes.
Once trained, the network defines an implicit surface through its decision boundary, precisely where \( f_\theta(z, x) = 0 \). This continuous representation allows smooth shape interpolation, high-resolution reconstruction, and editing directly in latent space.
Training Field Notes
We sampled training data from two meshes, torus.obj and mug.obj using a mix of blue-noise points near the surface and uniform samples within a unit cube. All shapes were volume-normalized to ensure consistent interpolation.
DeepSDF is designed to intentionally overfit. Validation is typically skipped. Effective training depends on a few factors: point sample density, network size, shape complexity, and sufficient epochs.
After training, the implicit surface can be extracted using Marching Cubes or Marching Tetrahedra to obtain a polygonal mesh from the zero-level set.
| Training Parameters | |
|---|---|
| SDF Delta | 1.0 | 
| Latent Mean | 0.0 | 
| Latent SD | 0.01 | 
| Loss Function | Clamped L1 | 
| Optimizer | Adam | 
| Network Learning Rate | 0.001 | 
| Latent Learning Rate | 0.01 | 
| Batch Size | 2 | 
| Epochs | 5000 | 
| Max Points per Shape | 3000 | 
| Network Architecture | |
| Latent Dimension | 16 | 
| Hidden Layer Size | 124 | 
| Number of Layers | 8 | 
| Input Coordinate Dim | 3 | 
| Dropout | 0.0 | 
| Point Cloud Sampling | |
| Radius | 0.02 | 
| Sigma | 0.02 | 
| Mu | 0.0 | 
| Number of Gaussians | 10 | 
| Uniform Samples | 5000 | 
For higher shape complexity, increasing the latent dimension or training duration improves reconstruction fidelity.
Latent Space Interpolation
One compelling application is interpolation in latent space. By linearly blending between two shape codes \( z_a \) and \( z_b \), we generate new shapes along the path
$$
z(t) = (1 – t) \cdot z_a + t \cdot z_b,\quad t \in [0,1].
$$

While DeepSDF enables smooth morphing between shapes, it exposes a core limitation: a lack of topological consistency. Even when the source and target shapes share the same number of genus, interpolated shapes can exhibit unintended holes, handles, or disconnected components. These are not artifacts, they reveal that the model has no built-in notion of topology.
However, this limitation also opens the door for deeper exploration. If neural fields like DeepSDF lack an inherent understanding of topology, how can we guide them toward preserving it? In the next post, we explore a fundamental topological property—genus—and how maintaining it during shape transitions could lead us toward more structurally meaningful interpolations.
References