Fit first-order dynamic models to experimental step response data and extract K (gain) and tau (time constant) parameters.
Installation
Details
Usage
After installing, this skill will be available to your AI coding assistant.
Verify installation:
npx agent-skills-cli listSkill Instructions
name: first-order-model-fitting description: Fit first-order dynamic models to experimental step response data and extract K (gain) and tau (time constant) parameters.
First-Order System Model Fitting
Overview
Many physical systems (thermal, electrical, mechanical) exhibit first-order dynamics. This skill explains the mathematical model and how to extract parameters from experimental data.
The First-Order Model
The dynamics are described by:
tau * dy/dt + y = y_ambient + K * u
Where:
y= output variable (e.g., temperature, voltage, position)u= input variable (e.g., power, current, force)K= process gain (output change per unit input at steady state)tau= time constant (seconds) - characterizes response speedy_ambient= baseline/ambient value
Step Response Formula
When you apply a step input from 0 to u, the output follows:
y(t) = y_ambient + K * u * (1 - exp(-t/tau))
This is the key equation for fitting.
Extracting Parameters
Process Gain (K)
At steady state (t -> infinity), the exponential term goes to zero:
y_steady = y_ambient + K * u
Therefore:
K = (y_steady - y_ambient) / u
Time Constant (tau)
The time constant can be found from the 63.2% rise point:
At t = tau:
y(tau) = y_ambient + K*u*(1 - exp(-1))
= y_ambient + 0.632 * (y_steady - y_ambient)
So tau is the time to reach 63.2% of the final output change.
Model Function for Curve Fitting
def step_response(t, K, tau, y_ambient, u):
"""First-order step response model."""
return y_ambient + K * u * (1 - np.exp(-t / tau))
When fitting, you typically fix y_ambient (from initial reading) and u (known input), leaving only K and tau as unknowns:
def model(t, K, tau):
return y_ambient + K * u * (1 - np.exp(-t / tau))
Practical Tips
- Use rising portion data: The step response formula applies during the transient phase
- Exclude initial flat region: Start your fit from when the input changes
- Handle noisy data: Fitting naturally averages out measurement noise
- Check units: Ensure K has correct units (output units / input units)
Quality Metrics
After fitting, calculate:
- R-squared (R^2): How well the model explains variance (want > 0.9)
- Fitting error: RMS difference between model and data
residuals = y_measured - y_model
ss_res = np.sum(residuals**2)
ss_tot = np.sum((y_measured - np.mean(y_measured))**2)
r_squared = 1 - (ss_res / ss_tot)
fitting_error = np.sqrt(np.mean(residuals**2))
More by benchflow-ai
View allSkill library for embodied household task planning in VirtualHome environments. Provides reusable high-level skills composed of primitive actions to generate executable programs from task descriptions and initial states.
Master the uv package manager for fast Python dependency management, virtual environments, and modern Python project workflows. Use when setting up Python projects, managing dependencies, or optimizing Python development workflows with uv.
Cheminformatics toolkit for fine-grained molecular control. SMILES/SDF parsing, descriptors (MW, LogP, TPSA), fingerprints, substructure search, 2D/3D generation, similarity, reactions. For standard workflows with simpler interface, use datamol (wrapper around RDKit). Use rdkit for advanced control, custom sanitization, specialized algorithms.
Build deterministic, verifiable data visualizations with D3.js (v6). Generate standalone HTML/SVG (and optional PNG) from local data files without external network dependencies. Use when tasks require charts, plots, axes/scales, legends, tooltips, or data-driven SVG output.
