Agent Skill
2/7/2026burn-app-dev
This skill should be used when the user asks about "Burn tensors", "tensor operations", "Module derive", "burn config", "autodiff", "backward pass", "gradient", "record serialization", "model weights", or core Burn application development patterns.
J
johnzfitch
1GitHub Stars
1Views
npx skills add johnzfitch/burn-plugin
SKILL.md
| Name | burn-app-dev |
| Description | This skill should be used when the user asks about "Burn tensors", "tensor operations", "Module derive", "burn config", "autodiff", "backward pass", "gradient", "record serialization", "model weights", or core Burn application development patterns. |
name: burn-app-dev description: This skill should be used when the user asks about "Burn tensors", "tensor operations", "Module derive", "burn config", "autodiff", "backward pass", "gradient", "record serialization", "model weights", or core Burn application development patterns. version: 0.1.0
Burn Application Development
Core knowledge for building applications with the Burn deep learning framework.
Tensors
Burn tensors are the fundamental data structure. Three element types:
Tensor<B, D, Float>— Floating point operationsTensor<B, D, Int>— Integer operationsTensor<B, D, Bool>— Boolean masks
Key patterns:
// Creation
let tensor = Tensor::<B, 2>::zeros([batch, features], &device);
let tensor = Tensor::from_data([[1.0, 2.0], [3.0, 4.0]], &device);
// Operations (return new tensors, original unchanged)
let result = tensor.matmul(other);
let result = tensor.relu();
// Clone for multiple uses (cheap, reference counted)
let a = tensor.clone();
let b = tensor.clone();
Modules
Neural network layers use the Module derive macro:
#[derive(Module, Debug)]
pub struct Model<B: Backend> {
conv: Conv2d<B>,
pool: AdaptiveAvgPool2d,
linear: Linear<B>,
activation: Relu,
}
impl<B: Backend> Model<B> {
pub fn forward(&self, x: Tensor<B, 4>) -> Tensor<B, 2> {
let x = self.conv.forward(x);
let x = self.activation.forward(x);
let x = self.pool.forward(x);
let x = x.flatten(1, 3);
self.linear.forward(x)
}
}
Config
Type-safe configuration with the Config derive:
#[derive(Config)]
pub struct ModelConfig {
#[config(default = 64)]
hidden_size: usize,
#[config(default = 0.1)]
dropout: f64,
}
// Usage
let config = ModelConfig::new();
let model = config.init::<B>(&device);
Autodiff
Automatic differentiation for training:
// AutodiffBackend wraps any backend
type MyBackend = Autodiff<Wgpu>;
// Forward pass tracks gradients
let output = model.forward(input);
let loss = output.cross_entropy(targets);
// Backward pass
let grads = loss.backward();
let grad_tensor = tensor.grad(&grads).unwrap();
Key difference from PyTorch: gradients are returned as a separate Gradients struct, not stored on tensors.
Records
Serialization for model weights:
// Save
let recorder = CompactRecorder::new();
model.save_file("model.bin", &recorder)?;
// Load
let model = config.init::<B>(&device);
let model = model.load_file("model.bin", &recorder, &device)?;
Additional Resources
Consult references/topic-map-app.md for:
- Detailed tensor operation reference
- Built-in module catalog (Conv, Pool, RNN, Transformer, Loss)
- Advanced autodiff patterns
- Record format options
Skills Info
Original Name:burn-app-devAuthor:johnzfitch
Download