123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509 |
- #include "test.h"
- #include "pid.c"
- #include "util.c"
- #include "fixpt.c"
- static void check_common(void)
- {
- /* Check get/set setpoint */
- {
- struct pid pid;
- struct pid_k_set k;
- k.kp = float_to_fixpt(1.0);
- k.ki = float_to_fixpt(0.0);
- k.kd = float_to_fixpt(0.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- CHECK(pid_get_setpoint(&pid) == float_to_fixpt(10.0));
- }
- }
- static void check_P(void)
- {
- /* Check P-term with KP=1 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(1.0);
- k.ki = float_to_fixpt(0.0);
- k.kd = float_to_fixpt(0.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(1.0)); // r
- CHECK(ret == float_to_fixpt(9.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(2.0)); // r
- CHECK(ret == float_to_fixpt(8.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(5.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(5.0));
- }
- /* Check P-term with KP=3 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(3.0);
- k.ki = float_to_fixpt(0.0);
- k.kd = float_to_fixpt(0.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(1.0)); // r
- CHECK(ret == float_to_fixpt(15.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.5), // dt
- float_to_fixpt(2.0)); // r
- CHECK(ret == float_to_fixpt(15.0));
- ret = pid_run(&pid,
- float_to_fixpt(2.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(15.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(9.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.5)); // r
- CHECK(ret == float_to_fixpt(7.5));
- }
- /* Check P-term with KP=2.5 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(2.5);
- k.ki = float_to_fixpt(0.0);
- k.kd = float_to_fixpt(0.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(1.0)); // r
- CHECK(ret == float_to_fixpt(15.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(2.0)); // r
- CHECK(ret == float_to_fixpt(15.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(12.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(7.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.5)); // r
- CHECK(ret == float_to_fixpt(6.25));
- }
- /* Check P-term with KP=-2.5 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(-2.5);
- k.ki = float_to_fixpt(0.0);
- k.kd = float_to_fixpt(0.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(1.0)); // r
- CHECK(ret == float_to_fixpt(-15.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(2.0)); // r
- CHECK(ret == float_to_fixpt(-15.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(-12.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(-7.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.5)); // r
- CHECK(ret == float_to_fixpt(-6.25));
- }
- }
- static void check_I(void)
- {
- /* Check I-term with KI=1 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(0.0);
- k.ki = float_to_fixpt(1.0);
- k.kd = float_to_fixpt(0.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(1.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(2.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(3.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(10.0)); // r
- CHECK(ret == float_to_fixpt(3.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(2.0));
- ret = pid_run(&pid,
- float_to_fixpt(3.0), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(-1.0));
- ret = pid_run(&pid,
- float_to_fixpt(0.5), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(-1.5));
- ret = pid_run(&pid,
- float_to_fixpt(0.5), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(-2.0));
- }
- /* Check I-term with KI=-1 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(0.0);
- k.ki = float_to_fixpt(-1.0);
- k.kd = float_to_fixpt(0.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(-1.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(-2.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(-3.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(10.0)); // r
- CHECK(ret == float_to_fixpt(-3.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(-2.0));
- ret = pid_run(&pid,
- float_to_fixpt(3.0), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(1.0));
- ret = pid_run(&pid,
- float_to_fixpt(0.5), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(1.5));
- ret = pid_run(&pid,
- float_to_fixpt(0.5), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(2.0));
- }
- /* Check I-term with KI=1.5 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(0.0);
- k.ki = float_to_fixpt(1.5);
- k.kd = float_to_fixpt(0.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(1.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(3.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(4.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(10.0)); // r
- CHECK(ret == float_to_fixpt(4.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(3.0));
- ret = pid_run(&pid,
- float_to_fixpt(3.0), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(-1.5));
- ret = pid_run(&pid,
- float_to_fixpt(0.5), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(-2.25));
- ret = pid_run(&pid,
- float_to_fixpt(0.5), // dt
- float_to_fixpt(11.0)); // r
- CHECK(ret == float_to_fixpt(-3.0));
- }
- }
- static void check_D(void)
- {
- /* Check D-term with KD=1 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(0.0);
- k.ki = float_to_fixpt(0.0);
- k.kd = float_to_fixpt(1.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(1.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(8.0)); // r
- CHECK(ret == float_to_fixpt(1.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(1.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(2.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(0.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(-2.0));
- }
- /* Check D-term with KD=-1 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(0.0);
- k.ki = float_to_fixpt(0.0);
- k.kd = float_to_fixpt(-1.0);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(-1.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(8.0)); // r
- CHECK(ret == float_to_fixpt(-1.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(-1.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(-2.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(0.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(2.0));
- }
- /* Check D-term with KD=1.5 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(0.0);
- k.ki = float_to_fixpt(0.0);
- k.kd = float_to_fixpt(1.5);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(1.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(8.0)); // r
- CHECK(ret == float_to_fixpt(1.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(1.5));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(3.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(5.0)); // r
- CHECK(ret == float_to_fixpt(0.0));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(7.0)); // r
- CHECK(ret == float_to_fixpt(-3.0));
- }
- }
- static void check_PID(void)
- {
- /* Check PID with KP=1.5, KI=1.5, KD=1.5 */
- {
- struct pid pid;
- struct pid_k_set k;
- fixpt_t ret;
- k.kp = float_to_fixpt(1.5);
- k.ki = float_to_fixpt(1.5);
- k.kd = float_to_fixpt(1.5);
- k.d_decay_div = float_to_fixpt(1.0);
- pid_init(&pid, &k,
- float_to_fixpt(-15.0), // I -lim
- float_to_fixpt(15.0), // I +lim
- float_to_fixpt(-15.0), // -lim
- float_to_fixpt(15.0)); // +lim
- pid_set_setpoint(&pid, int_to_fixpt(10));
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(4.5)); // (integr=1.5)
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(8.0)); // r
- CHECK(ret == float_to_fixpt(9.0)); // (integr=4.5)
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(8.0)); // r
- CHECK(ret == float_to_fixpt(10.5)); // (integr=7.5)
- ret = pid_run(&pid,
- float_to_fixpt(1.0), // dt
- float_to_fixpt(9.0)); // r
- CHECK(ret == float_to_fixpt(9.0)); // (integr=9.0)
- }
- }
- int main(void)
- {
- check_common();
- check_P();
- check_I();
- check_D();
- check_PID();
- return 0;
- }
|