PIDRegulator.py
Go to the documentation of this file.
1 # Copyright (c) 2016 The UUV Simulator Authors.
2 # All rights reserved.
3 #
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
7 #
8 # http://www.apache.org/licenses/LICENSE-2.0
9 #
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
15 
16 import numpy
17 
18 
20  """A very basic 1D PID Regulator."""
21  def __init__(self, p, i, d, sat):
22  self.p = p
23  self.i = i
24  self.d = d
25  self.sat = sat
26 
27  self.integral = 0
28  self.prev_err = 0
29  self.prev_t = -1.0
30 
31  def __str__(self):
32  msg = 'PID controller:'
33  msg += '\n\tp=%f' % self.p
34  msg += '\n\ti=%f' % self.i
35  msg += '\n\td=%f' % self.d
36  msg += '\n\tsat=%f' % self.sat
37  return msg
38 
39  def regulate(self, err, t):
40  derr_dt = 0.0
41  dt = t - self.prev_t
42  if self.prev_t > 0.0 and dt > 0.0:
43  derr_dt = (err - self.prev_err)/dt
44  self.integral += 0.5*(err + self.prev_err)*dt
45 
46  u = self.p*err + self.d*derr_dt + self.i*self.integral
47 
48  self.prev_err = err
49  self.prev_t = t
50 
51  if (numpy.linalg.norm(u) > self.sat):
52  # controller is in saturation: limit outpt, reset integral
53  u = self.sat*u/numpy.linalg.norm(u)
54  self.integral = 0.0
55 
56  return u
def regulate(self, err, t)
Definition: PIDRegulator.py:39
def __init__(self, p, i, d, sat)
Definition: PIDRegulator.py:21


uuv_control_cascaded_pids
Author(s): Musa Morena Marcusso Manhaes , Sebastian Scherer , Luiz Ricardo Douat
autogenerated on Thu Jun 18 2020 03:28:22