Get the FREE Ultimate OpenClaw Setup Guide →

numerical-integration

npx machina-cli add skill HeshamFS/materials-simulation-skills/numerical-integration --openclaw
Files (1)
SKILL.md
6.1 KB

Numerical Integration

Goal

Provide a reliable workflow to select integrators, set tolerances, and manage adaptive time stepping for time-dependent simulations.

Requirements

  • Python 3.8+
  • NumPy (for some scripts)
  • No heavy dependencies for core functionality

Inputs to Gather

InputDescriptionExample
Problem typeODE/PDE, stiff/non-stiffstiff PDE
Jacobian availableCan compute ∂f/∂u?yes
Target accuracyDesired error level1e-6
ConstraintsMemory, implicit allowed?implicit OK
Time scaleCharacteristic time1e-3 s

Decision Guidance

Choosing an Integrator

Is the problem stiff?
├── YES → Is Jacobian available?
│   ├── YES → Use Rosenbrock or BDF
│   └── NO → Use BDF with numerical Jacobian
└── NO → Is high accuracy needed?
    ├── YES → Use RK45 or DOP853
    └── NO → Use RK4 or Adams-Bashforth

Stiff vs Non-Stiff Detection

SymptomLikely StiffAction
dt shrinks to tiny valuesYesSwitch to implicit
Eigenvalues span many decadesYesUse BDF/Radau
Smooth solution, reasonable dtNoStay explicit

Script Outputs (JSON Fields)

ScriptKey Outputs
scripts/error_norm.pyerror_norm, scale_min, scale_max
scripts/adaptive_step_controller.pyaccept, dt_next, factor
scripts/integrator_selector.pyrecommended, alternatives, notes
scripts/imex_split_planner.pyimplicit_terms, explicit_terms, splitting_strategy
scripts/splitting_error_estimator.pyerror_estimate, substeps

Workflow

  1. Classify stiffness - Check eigenvalue spread or use stiffness_detector
  2. Choose tolerances - See references/tolerance_guidelines.md
  3. Select integrator - Run scripts/integrator_selector.py
  4. Compute error norms - Use scripts/error_norm.py for step acceptance
  5. Adapt step size - Use scripts/adaptive_step_controller.py
  6. Plan IMEX/splitting - If mixed stiff/nonstiff, use scripts/imex_split_planner.py
  7. Validate convergence - Repeat with tighter tolerances

Conversational Workflow Example

User: I'm solving the Allen-Cahn equation with a stiff double-well potential. What integrator should I use?

Agent workflow:

  1. Check integrator options:
    python3 scripts/integrator_selector.py --stiff --jacobian-available --accuracy high --json
    
  2. Plan the IMEX splitting (diffusion implicit, reaction explicit):
    python3 scripts/imex_split_planner.py --stiff-terms diffusion --nonstiff-terms reaction --coupling weak --json
    
  3. Recommend: Use IMEX-BDF2 with diffusion term implicit, double-well reaction explicit.

Pre-Integration Checklist

  • Identify stiffness and dominant time scales
  • Set rtol/atol consistent with physics and units
  • Confirm integrator compatibility with stiffness
  • Use error norm to accept/reject steps
  • Verify convergence with tighter tolerance run

CLI Examples

# Select integrator for stiff problem with Jacobian
python3 scripts/integrator_selector.py --stiff --jacobian-available --accuracy high --json

# Compute scaled error norm
python3 scripts/error_norm.py --error 0.01,0.02 --solution 1.0,2.0 --rtol 1e-3 --atol 1e-6 --json

# Adaptive step control with PI controller
python3 scripts/adaptive_step_controller.py --dt 1e-2 --error-norm 0.8 --order 4 --controller pi --json

# Plan IMEX splitting
python3 scripts/imex_split_planner.py --stiff-terms diffusion,elastic --nonstiff-terms reaction --coupling strong --json

# Estimate splitting error
python3 scripts/splitting_error_estimator.py --dt 1e-4 --scheme strang --commutator-norm 50 --target-error 1e-6 --json

Error Handling

ErrorCauseResolution
rtol and atol must be positiveInvalid tolerancesUse positive values
error-norm must be positiveNegative error normCheck error computation
Unknown controllerInvalid controller typeUse i, pi, or pid
Splitting requires at least one termEmpty term listSpecify stiff or nonstiff terms

Interpretation Guidance

Error Norm Values

Error NormMeaningAction
< 1.0Step acceptableAccept, maybe increase dt
≈ 1.0At tolerance boundaryAccept with current dt
> 1.0Step rejectedReject, reduce dt

Controller Selection

ControllerPropertiesBest For
I (integral)Simple, some overshootNon-stiff, moderate accuracy
PI (proportional-integral)Smooth, robustGeneral use
PIDAggressive adaptationRapidly varying dynamics

IMEX Strategy

CouplingStrategy
WeakSimple operator splitting
ModerateStrang splitting
StrongFully coupled IMEX-RK

Limitations

  • No automatic stiffness detection: Use stiffness_detector from numerical-stability
  • Splitting assumes separability: Terms must be cleanly separable
  • Jacobian requirement: Some methods need analytical or numerical Jacobian

References

  • references/method_catalog.md - Integrator options and properties
  • references/tolerance_guidelines.md - Choosing rtol/atol
  • references/error_control.md - Error norm and adaptation formulas
  • references/imex_guidelines.md - Stiff/non-stiff splitting
  • references/splitting_catalog.md - Operator splitting patterns
  • references/multiphase_field_patterns.md - Phase-field specific splits

Version History

  • v1.1.0 (2024-12-24): Enhanced documentation, decision guidance, examples
  • v1.0.0: Initial release with 5 integration scripts

Source

git clone https://github.com/HeshamFS/materials-simulation-skills/blob/main/skills/core-numerical/numerical-integration/SKILL.mdView on GitHub

Overview

Provides a practical workflow to pick integrators, set tolerances, and manage adaptive time stepping for time-dependent simulations. It covers stiffness assessment, IMEX splitting planning, and choosing explicit versus implicit schemes (e.g., Rosenbrock, BDF, RK45, DOP853) to meet accuracy and performance goals.

How This Skill Works

Classify stiffness and dominant time scales, then choose an appropriate integrator (RK4, RK45, DOP853, BDF, Rosenbrock) or IMEX split. Set rtol/atol, run error norm and adaptive step tests, and adjust dt_next with a controller. Use dedicated scripts (integrator_selector, error_norm, adaptive_step_controller, imex_split_planner) to guide the workflow.

When to Use It

  • You have a stiff PDE/ODE system and want implicit integration (with potential Jacobian availability).
  • You need high accuracy and can use explicit methods like RK45 or DOP853 for non-stiff problems.
  • You want adaptive time stepping to balance error control and performance.
  • You are planning IMEX splitting for mixed stiff/nonstiff terms (e.g., diffusion implicit, reaction explicit).
  • You are diagnosing convergence or selecting an integrator with stiffness detection evidence (eigenvalue spread, dt behavior).

Quick Start

  1. Step 1: Classify stiffness and set initial tolerances, then select an integrator with the integrator_selector script (e.g., python3 scripts/integrator_selector.py --stiff --jacobian-available --accuracy high --json).
  2. Step 2: If mixed stiffness exists, plan IMEX splitting with imex_split_planner (e.g., python3 scripts/imex_split_planner.py --stiff-terms diffusion --nonstiff-terms reaction --coupling weak --json).
  3. Step 3: Run with the recommended method and verify via error norms and adaptive stepping (e.g., use error_norm.py and adaptive_step_controller.py; adjust rtol/atol as needed).

Best Practices

  • Identify stiffness early by checking eigenvalue spread or using a stiffness detector.
  • Set rtol/atol consistently with physics units and desired accuracy.
  • If a Jacobian is available and the problem is stiff, prefer Rosenbrock or BDF; if not available, use BDF with a numerical Jacobian.
  • For non-stiff problems requiring accuracy, prefer RK45 or DOP853; for cheaper schemes, RK4 or Adams-Bashforth can suffice.
  • Validate convergence by repeating runs with tighter tolerances and verifying consistent results.

Example Use Cases

  • Allen-Cahn equation with a stiff double-well potential analyzed via IMEX-BDF2 with diffusion implicit and reaction explicit.
  • Stiff PDE with diffusion-reaction coupling where IMEX splitting is planned to balance stiffness and speed.
  • Non-stiff ODE system where RK45 or DOP853 achieves high accuracy efficiently.
  • Problem with available Jacobian demonstrating Rosenbrock or BDF choice for stiff dynamics.
  • Mixed stiff/nonstiff system requiring explicit terms for non-stiff components and implicit terms for stiff components.

Frequently Asked Questions

Add this skill to your agents
Sponsor this space

Reach thousands of developers