# coding:utf-8
import math
import numpy as np
from sympy import *
from matplotlib import pyplot as plt
from numpy.random import *
"""
Mn = Mn1 + Kp*(en-en1) + Ki*en + Kd*((en-en1) - (en1-en2))
比例制御:
Mn1 + Kp*(en-en1)
積分制御:
Ki*en
微分制御
Kd*((en-en1)-(en1-en2))
Mn : 操作量
en : 偏差
Kp : 比例制御(P)の比例定数
Ki : 積分制御(I)の比例定数
Kd : 微分制御(D)の比例定数
M : 与える操作量
M1 : 一つ前に与えた操作量
goal : 目的値
e : 偏差(目的値と現在値の差)
e1 : 前回の偏差
e2 : 前々回の偏差
Kp : 比例制御(P制御)の比例定数
Ki : 積分制御(I制御)の比例定数
Kd : 微分制御(D制御)の比例定数
pi = math.pi
x = np.linspace(0, 2*pi, 100)
y = np.sin(x)
pyplot.plot(x, y)
pyplot.show()
"""
def main():
M = 1.00
M1 = 0.00
e = 0.00
e1 = 0.00
e2 = 0.00
Kp = Ki = Kd = 0.1
t = 100
goal = 50.00
x_list = []
y_list = []
x_list.append(0)
y_list.append(0.00)
for i in range(1,t):
M1 = M
e2 = e1
e1 = e
e = goal - y_list[i-1]
M = M1 + Kp * (e-e1) + Ki * e + Kd * ((e-e1) - (e1-e2))
y_list.append(M)
x_list.append(i)
plt.plot(x_list, y_list)
plt.ylim(0, goal*2)
plt.show()
if __name__ == "__main__":
main()