pid-controller
v0.1.0Use this skill when implementing PID control loops for adaptive cruise control, vehicle speed regulation, throttle/brake management, or any feedback control...
Security Scan
OpenClaw
Benign
high confidencePurpose & Capability
The name/description (PID controller for vehicle control and feedback systems) aligns with the provided content: a conceptual overview, discrete-time implementation in Python, anti-windup approaches, and tuning guidance. Nothing requested or described is extraneous to implementing a PID controller.
Instruction Scope
SKILL.md contains only explanatory text and a self-contained Python class; it does not instruct the agent to read files, call external services, or access environment variables. Note: the document is example code and lacks production-safety guidance (e.g., sensor filtering, unit conventions, real-time constraints, verification) which is important for safety-critical vehicle deployment.
Install Mechanism
This is an instruction-only skill with no install spec, no downloads, and no code files beyond SKILL.md — minimal disk/write risk.
Credentials
No environment variables, credentials, or config paths are requested. The skill does not require any unrelated secrets or external service access.
Persistence & Privilege
The skill does not request persistent/system-level privileges and always:false. It does not modify other skills or system settings.
Assessment
This skill is coherent and appears safe from a permissions/credential perspective — it is a documentation/example-only PID implementation. Before using it in any real vehicle or safety-critical system, review and adapt the code for your platform: add sampling-rate handling, unit consistency, sensor noise filtering (e.g., derivative filtering), robust anti-windup, saturation-safe integration, bounds and failsafes, thread/real-time considerations, testing (unit, HIL, SIL), and safety validation. The SKILL.md contains no hidden network calls or credential requests, but treat the code as a starting point, not a certified production controller.Like a lobster shell, security has layers — review code before you run it.
latest
PID Controller Implementation
Overview
A PID (Proportional-Integral-Derivative) controller is a feedback control mechanism used in industrial control systems. It continuously calculates an error value and applies a correction based on proportional, integral, and derivative terms.
Control Law
output = Kp * error + Ki * integral(error) + Kd * derivative(error)
Where:
error= setpoint - measured_valueKp= proportional gain (reacts to current error)Ki= integral gain (reacts to accumulated error)Kd= derivative gain (reacts to rate of change)
Discrete-Time Implementation
class PIDController:
def __init__(self, kp, ki, kd, output_min=None, output_max=None):
self.kp = kp
self.ki = ki
self.kd = kd
self.output_min = output_min
self.output_max = output_max
self.integral = 0.0
self.prev_error = 0.0
def reset(self):
"""Clear controller state."""
self.integral = 0.0
self.prev_error = 0.0
def compute(self, error, dt):
"""Compute control output given error and timestep."""
# Proportional term
p_term = self.kp * error
# Integral term
self.integral += error * dt
i_term = self.ki * self.integral
# Derivative term
derivative = (error - self.prev_error) / dt if dt > 0 else 0.0
d_term = self.kd * derivative
self.prev_error = error
# Total output
output = p_term + i_term + d_term
# Output clamping (optional)
if self.output_min is not None:
output = max(output, self.output_min)
if self.output_max is not None:
output = min(output, self.output_max)
return output
Anti-Windup
Integral windup occurs when output saturates but integral keeps accumulating. Solutions:
- Clamping: Limit integral term magnitude
- Conditional Integration: Only integrate when not saturated
- Back-calculation: Reduce integral when output is clamped
Tuning Guidelines
Manual Tuning:
- Set Ki = Kd = 0
- Increase Kp until acceptable response speed
- Add Ki to eliminate steady-state error
- Add Kd to reduce overshoot
Effect of Each Gain:
- Higher Kp -> faster response, more overshoot
- Higher Ki -> eliminates steady-state error, can cause oscillation
- Higher Kd -> reduces overshoot, sensitive to noise
Comments
Loading comments...
