Skip to content
/ qPID Public
forked from akharsa/qPID

Open PID Controller for embedded systems

Notifications You must be signed in to change notification settings

eventus17/qPID

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

qPID Digital PID controller library

Introduction

This library is a digital Proportional-Integrative-Derivative digital controller designed for embedded systems to interact with real systems.

Principle of work and definitions

Block Diagram

Block diagram

Detailed information

Full mathematical description and testing results of this libarary can be found (in spanish) in kharsansky-quadrotor-control-thesis.

Usage example

#include "qPIDs.h"

float setPoint = 0.0;
float sensor = 0.0;
float output = 0.0;


// Example usage for the qPID library for controlling the speed of a simle motor
// The idea is to control the speed of the motor by varing the voltage applied via PWM

float readSensor(void);			// A function that reads the motor speed from a sensor
float readSetPoint(void);		// A function that reads the desired speed from a potentiometer
setActuator(void);				// A function that sets the PWM output for controlling the motor

void example(void){

	// Declare de new object
	qPID controler;
	
	// Configure settings
	controller.AntiWindup = ENABLED;
	controller.Bumpless = ENABLED;
	
	// Set mode to auotmatic (otherwise it will be in manual mode)
	controller.Mode = AUTOMATIC;
	
	// Configure de output limits for clamping
	controller.OutputMax = 1.0;
	controller.OutputMin = -1.0;
	
	// Set the rate at the PID will run in seconds
	controller.Ts = 0.005; 
	
	// More settings
	controller.b = 1.0;
	controller.c = 1.0;
	
	// Init de controller
	qPID_Init(&controller);

	// Set the tunning constants	
	controller.K = 0.5;
	controller.Ti = 1/0.02;
	controller.Td = 0.0;
	controller.Nd = 4.0;
	
	while (1){
		sensor = readSensor();				// update the process variable
		setPoint = readSetPoint(); 			// update the user desired value
		
		// Update the PID and get the new output
		output = qPID_Procees(&controller, setPoint, sensor);
		
		setActuator(output);				// update the actuator input
	}
	
}

About

Open PID Controller for embedded systems

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 61.7%
  • C++ 38.3%