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.3.tar.gz (69.6 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.3-py3-none-any.whl (6.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: moat_lib_pid-0.6.3.tar.gz
  • Upload date:
  • Size: 69.6 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.3.tar.gz
Algorithm Hash digest
SHA256 935ebc1d35d48c741d24c49e857fde592524f13eba02fde2e23cfdaf026dc519
MD5 1466e9257793f723e7e53750a29762f6
BLAKE2b-256 3393a637215081fc9b5628677f6121404863bb02ae0efa51bd347a7003cfbe4a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: moat_lib_pid-0.6.3-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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 8a73ae2d7385839836ad834bdb041ea8f4b1f8b7c259e59228fd14009a772e4e
MD5 c034aa657a930891790f69d117e468ad
BLAKE2b-256 9129b5af96dec1a1b2e8a408cc88cfcd4b9c2f9addcb29f5abccfd543b014e53

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