home / skills / benchflow-ai / skillsbench / imc-tuning-rules

This skill calculates IMC tuning gains for PI controllers on first-order systems, giving Kp, Ki, and lambda to achieve stable, fast responses.

npx playbooks add skill benchflow-ai/skillsbench --skill imc-tuning-rules

Review the files below or copy the command above to add this skill to your agents.

Files (1)
SKILL.md
3.5 KB
---
name: imc-tuning-rules
description: Calculate PI/PID controller gains using Internal Model Control (IMC) tuning rules for first-order systems.
---

# IMC Tuning Rules for PI/PID Controllers

## Overview

Internal Model Control (IMC) is a systematic method for tuning PI/PID controllers based on a process model. Once you've identified system parameters (K and tau), IMC provides controller gains.

## Why IMC?

- **Model-based**: Uses identified process parameters directly
- **Single tuning parameter**: Just choose the closed-loop speed (lambda)
- **Guaranteed stability**: For first-order systems, always stable if model is accurate
- **Predictable response**: Closed-loop time constant equals lambda

## IMC Tuning for First-Order Systems

For a first-order process with gain K and time constant tau:

```
Process: G(s) = K / (tau*s + 1)
```

The IMC-tuned PI controller gains are:

```
Kp = tau / (K * lambda)
Ki = Kp / tau = 1 / (K * lambda)
Kd = 0  (derivative not needed for first-order systems)
```

Where:
- `Kp` = Proportional gain
- `Ki` = Integral gain (units: 1/time)
- `Kd` = Derivative gain (zero for first-order)
- `lambda` = Desired closed-loop time constant (tuning parameter)

## Choosing Lambda (λ)

Lambda controls the trade-off between speed and robustness:

| Lambda | Behavior |
|--------|----------|
| `lambda = 0.1 * tau` | Very aggressive, fast but sensitive to model error |
| `lambda = 0.5 * tau` | Aggressive, good for accurate models |
| `lambda = 1.0 * tau` | Moderate, balanced speed and robustness |
| `lambda = 2.0 * tau` | Conservative, robust to model uncertainty |

**Default recommendation**: Start with `lambda = tau`

For noisy systems or uncertain models, use larger lambda.
For precise models and fast response needs, use smaller lambda.

## Implementation

```python
def calculate_imc_gains(K, tau, lambda_factor=1.0):
    """
    Calculate IMC-tuned PI gains for a first-order system.

    Args:
        K: Process gain
        tau: Time constant
        lambda_factor: Multiplier for lambda (default 1.0 = lambda equals tau)

    Returns:
        dict with Kp, Ki, Kd, lambda
    """
    lambda_cl = lambda_factor * tau

    Kp = tau / (K * lambda_cl)
    Ki = Kp / tau
    Kd = 0.0

    return {
        "Kp": Kp,
        "Ki": Ki,
        "Kd": Kd,
        "lambda": lambda_cl
    }
```

## PI Controller Implementation

```python
class PIController:
    def __init__(self, Kp, Ki, setpoint):
        self.Kp = Kp
        self.Ki = Ki
        self.setpoint = setpoint
        self.integral = 0.0

    def compute(self, measurement, dt):
        """Compute control output."""
        error = self.setpoint - measurement

        # Integral term
        self.integral += error * dt

        # PI control law
        output = self.Kp * error + self.Ki * self.integral

        # Clamp to valid range
        output = max(output_min, min(output_max, output))

        return output
```

## Expected Closed-Loop Behavior

With IMC tuning, the closed-loop response is approximately:

```
y(t) = y_setpoint * (1 - exp(-t / lambda))
```

Key properties:
- **Rise time**: ~2.2 * lambda to reach 90% of setpoint
- **Settling time**: ~4 * lambda to reach 98% of setpoint
- **Overshoot**: Minimal for first-order systems
- **Steady-state error**: Zero (integral action eliminates offset)

## Tips

1. **Start conservative**: Use `lambda = tau` initially
2. **Decrease lambda carefully**: Smaller lambda = larger Kp = faster but riskier
3. **Watch for oscillation**: If output oscillates, increase lambda
4. **Anti-windup**: Prevent integral wind-up when output saturates

Overview

This skill calculates PI/PID controller gains using Internal Model Control (IMC) tuning rules for first-order processes. It converts identified process parameters (process gain K and time constant tau) and a chosen closed-loop time constant (lambda) into Kp, Ki, and Kd. The goal is predictable closed-loop speed with a single tuning knob (lambda).

How this skill works

The skill uses the first-order model G(s) = K / (tau*s + 1) and the IMC formulas to compute controller gains. For PI control the formulas are Kp = tau / (K * lambda) and Ki = 1 / (K * lambda); Kd is set to zero for true first-order dynamics. It also returns the effective lambda used so you can evaluate expected rise and settling times.

When to use it

  • You have an identified first-order process model (K and tau).
  • You need a quick, model-based baseline PI controller.
  • You want a single tuning parameter to trade speed vs robustness.
  • You require predictable closed-loop time constant and minimal overshoot.
  • You need a starting point before refining with advanced tuning or tests.

Best practices

  • Start with lambda = tau for a conservative, robust response.
  • Increase lambda for noisy or uncertain models to improve robustness.
  • Decrease lambda cautiously to speed response but watch for oscillation.
  • Implement anti-windup when actuator saturation can occur.
  • Verify tuning on the real system and adjust lambda based on observed behavior.

Example use cases

  • Tuning temperature control loops modeled well by a first-order response.
  • Designing PI controllers for flow or level loops with identified K and tau.
  • Generating baseline gains for simulation before performing online tuning.
  • Rapidly prototyping control for lab experiments where model parameters are known.
  • Converting process identification results into deployable controller parameters.

FAQ

Can I use this for higher-order or time-delay processes?

IMC rules here assume a first-order model. For higher-order dynamics or significant dead time, use extended IMC formulations or model reduction and include time-delay handling.

How do I pick lambda for a noisy system?

Choose a larger lambda (>= tau) to reduce sensitivity to noise and model errors. Start with lambda = tau and increase until noise and oscillation are acceptable.