Skip to main content

An advanced PID controller

Project description

moat-lib-pid

An advanced PID controller in Python. The derivative term can also be used in practice thanks to built-in first-order filter. Detailed information can be found here.

Usage is very simple:

from moat.lib.pid import PID

# Create PID controller
pid = PID(Kp=2.0, Ki=0.1, Kd=1.0, Tf=0.05)

# Control loop
while True:
    # Get current measurement from system
    timestamp, measurement = system.get_measurement()

    # Calculate control signal by using PID controller
    reference = 1.0
    control = pid(timestamp, reference - measurement)

    # Feed control signal to system
    system.set_input(control)

This module was vendorized from the advanced-pid module by Erkan Adali erkanadali91@gmail.com.

Complete API documentation can be found here.

Usage

Biggest advantage of advanced-pid, the derivative term has a built-in first-order filter. advanced-pid package includes a toy mass-spring-damper system model for testing:

from moat.lib.pid import PID
from examples.mass_spring_damper import MassSpringDamper
from matplotlib import pyplot as plt
from numpy import diff

# Create a mass-spring-damper system model
system = MassSpringDamper(mass=1.0, spring_const=1.0, damping_const=0.2)
system.set_initial_value(initial_position=1.0, initial_velocity=0.0)

# Create PID controller
pid = PID(Kp=1.0, Ki=0.0, Kd=2.0, Tf=0.5)

# Control loop
time, meas, cont = [], [], []
for i in range(800):
    # Get current measurement from system
    timestamp, measurement = system.get_measurement()

    # Calculate control signal by using PID controller
    control = pid(timestamp, -measurement)

    # Feed control signal to system
    system.set_input(control)

    # Record for plotting
    time.append(timestamp)
    meas.append(measurement)
    cont.append(control)

# Plot result
fig, (ax1, ax2, ax3) = plt.subplots(3, 1)
fig.suptitle('Mass-Spring-Damper system')
ax1.set_ylabel('Measured Position [m]')
ax1.plot(time, meas, 'b')
ax1.grid()
ax2.set_ylabel('Force [N]')
ax2.plot(time, cont, 'g')
ax2.grid()
ax3.set_xlabel('Time [s]')
ax3.set_ylabel('Derivative Term')
ax3.plot(time[1:], diff(meas)/diff(time), 'r')
ax3.grid()
plt.show()

As It can be seen in the figure, derivative term cannot be use without a filter: alt text

Installation

To install, run:

pip3 install moat-lib-pid

Tests

To run tests, run:

pytest tests

License

Licensed under the MIT License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

moat_lib_pid-0.6.4.tar.gz (9.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

moat_lib_pid-0.6.4-py3-none-any.whl (6.6 kB view details)

Uploaded Python 3

File details

Details for the file moat_lib_pid-0.6.4.tar.gz.

File metadata

  • Download URL: moat_lib_pid-0.6.4.tar.gz
  • Upload date:
  • Size: 9.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for moat_lib_pid-0.6.4.tar.gz
Algorithm Hash digest
SHA256 735a952bb51a935b0fc7d7028857b1c34eaf589844d7bbc3d7751b7d08f4b153
MD5 c5447743f48bee4e147e54a19a5b8883
BLAKE2b-256 49a7f7b0562cafec500c85e7bcc2f31a43696ea4c4f5916aa27a872678782337

See more details on using hashes here.

File details

Details for the file moat_lib_pid-0.6.4-py3-none-any.whl.

File metadata

  • Download URL: moat_lib_pid-0.6.4-py3-none-any.whl
  • Upload date:
  • Size: 6.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for moat_lib_pid-0.6.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b51e7b2eeb75126d8f7e9b4c406e6df0ea5d71458001802b05c22396e12caa88
MD5 445149742a4f51c15904178e9c2360c5
BLAKE2b-256 d9cf44b60926cd6c6e9a3ac6fe53f36e120f7eb45ddd8453ab7e135f04ebf514

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page