diff --git a/content/project/controllib/featured.png b/content/project/controllib/featured.png new file mode 100644 index 0000000..66cb3db Binary files /dev/null and b/content/project/controllib/featured.png differ diff --git a/content/project/controllib/index.md b/content/project/controllib/index.md new file mode 100644 index 0000000..f6fe8eb --- /dev/null +++ b/content/project/controllib/index.md @@ -0,0 +1,91 @@ +--- +# Documentation: https://wowchemy.com/docs/managing-content/ + +title: "Control Library" +summary: "A library for quick and easy implementation of regulation and control loops. (PID)" +authors: [] +tags: [] +categories: [] +date: 2021-07-21T20:49:38+02:00 + +# Optional external URL for project (replaces project detail page). +external_link: "" + +# Featured image +# To use, add an image named `featured.jpg/png` to your page's folder. +# Focal points: Smart, Center, TopLeft, Top, TopRight, Left, Right, BottomLeft, Bottom, BottomRight. +image: + caption: "Control loop" + focal_point: "" + preview_only: false + +# Custom links (optional). +# Uncomment and edit lines below to show custom links. +# links: +# - name: Follow +# url: https://twitter.com +# icon_pack: fab +# icon: twitter + +url_code: "" +url_pdf: "" +url_slides: "" +url_video: "" + +# Slides (optional). +# Associate this project with Markdown slides. +# Simply enter your slide deck's filename without extension. +# E.g. `slides = "example-slides"` references `content/slides/example-slides.md`. +# Otherwise, set `slides = ""`. +slides: "" +--- +{{% callout note %}} +Concept phase. No implementation yet. +{{% /callout %}} + +# Concept +Implement commonly used algorithms used in control loops. This typically covers PID control loops and their supporting elements. (Filters, scaling, glitch detection etc). + +# Why +Control loops typically interact with the real world. The real world is complex enough without an added layer of code complexity. The goal of the project is to keep the implementation clear and easy to understand. +Code that is easy to undersstand is easy to modify and adapt. + +# How +Implement in C++ taking advantage of object orientated features to present a clean API for the user. Should not rely on integer math and optimization. Floats and integers both have their pros and cons. Floating Point are avaible on most micro controllers and the user should not worry about premature optimization. Slow routines may be updated at a later time if the need arises. +The library should remain cross-platform to ensure the code may be used for embedded development and on the desktop. (All the way from Arduino to Windows). +Reflect Control loop diagrams as closely as possible. + +# TDD +Unit test individual components to ensure their reliability before integration. +Compare with other implementations for correcteness taking into account floating point (in)accuracy. + +# Features +- PID controller + - P/PI/PID + - Various clamping/anti-windup strategies. +- Filters + - Exponentional Moving Average + - Rolling average + - Kalman Filter + - FIR/IIR +- Detection + - Inside/Outside range, inhibit time, hysteresis, glitch protection + - Deadbands +- Ramp / Fade + - Expontential, Linear +- Generators + - Sine, Square, Triangle, Sawtooth +- Utils + - Linear scaling (Y=ax+b) + - Polyominal + - Map +- Limit + + + +# Example +```mermaid +graph LR; + Input-->Map-->Filter-->Error-->PID-->Limit-->Output; + +```