當前位置: 首頁>>代碼示例>>Python>>正文


Python Motor.set_value方法代碼示例

本文整理匯總了Python中motor.Motor.set_value方法的典型用法代碼示例。如果您正苦於以下問題:Python Motor.set_value方法的具體用法?Python Motor.set_value怎麽用?Python Motor.set_value使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在motor.Motor的用法示例。


在下文中一共展示了Motor.set_value方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: ControlThread

# 需要導入模塊: from motor import Motor [as 別名]
# 或者: from motor.Motor import set_value [as 別名]
class ControlThread(Thread):
    def __init__(self, config):
        Thread.__init__(self)
        self.angle = 0
        self.K = 0.98
        self.logDataSetBuffer = []

        self.Kp = config.config.as_float('Kp')
        self.Ki = config.config.as_float('Ki')
        self.Kd = config.config.as_float('Kd')
        self.set_point = config.config.as_float('set_point')
        self.disable_motors = config.config.as_bool('disable_motors')
        
        self.integral_error = 0
        self.last_error = 0
        self.motor_left = Motor("L", port_motor_left_pwm, port_motor_left_backward, port_motor_left_forward)
        self.motor_right = Motor("R", port_motor_right_pwm, port_motor_right_backward, port_motor_right_forward)
        
        self.accelerometer = MPU6050()

        self.last_time = time()

        self.logger = logging.getLogger(__name__)

        self.setDaemon(True)
        self.latest_sensor = 0
        
        self.logger.info('Initialized ControlThread with the following settings')
        self.logger.info('disable_motors={}'.format(self.disable_motors))
        self.logger.info('set_point={:1.2f}'.format(self.set_point))
        self.logger.info('Kp={:1.1f}'.format(self.Kp))
        self.logger.info('Ki={:1.1f}'.format(self.Ki))
        self.logger.info('Kd={:1.1f}'.format(self.Kd))


    def run(self):
        while True:
            self.perform_one_step()

    def perform_one_step(self):
        # create an object for logging the current sensors' data and current control data
        currentLogDataSet = LogDataSet()
        
        # read sensors
        try:
            # this gives IOError sometimes
            axes = self.accelerometer.getAxes(True)
        except (IOError):
            # error, do nothing, try again
            return

        self.latest_sensor = axes
        z = axes['z']
        x = axes['y']
        accelerometerAngle = atan2(x, -z)
        # read gyroscope
        gyroscopeRate = -axes['gx'] / 180 * math.pi
        
        # log the values from the sensors
        currentLogDataSet.setSensorsValues(axes, gyroscopeRate)
        
        # calculate dt based on the current time and the previous measurement time
        now = time()
        dt = now - self.last_time
        self.dt = dt
        self.last_time = now 
        
        # complementary filter
        self.angle = self.K * (self.angle + gyroscopeRate * dt) + (1 - self.K) * accelerometerAngle

        # PID
        error = self.angle - self.set_point
        self.integral_error += error * dt
        differential_error = (error - self.last_error) / dt
        self.last_error = error

        up = self.Kp * error
        ui = self.Ki * self.integral_error
        ud = self.Kd * differential_error
        u = up + ui + ud
        self.u = u
        
        # log the calculated control values
        currentLogDataSet.setControlValues(accelerometerAngle, self.angle, error, self.integral_error, differential_error, u, dt)
        # append the current logDataSet object to the logging-buffer
        self.logDataSetBuffer.append(currentLogDataSet)
        # limit the size of the buffer
        if len(self.logDataSetBuffer) > 500: 
            del self.logDataSetBuffer[0]
            
        self.logger.debug(
            'x={:5.2f} z={:5.2f} gy={:7.2f} accelAngle={:5.2f} gyrAngle={:6.3f} angle={:6.3f} e={:6.3f} ie={:6.3f} de={:5.2f} up={:5.2f} ui={:5.2f} ud={:5.2f} u={:5.2f} dt={:3.0f}'
                .format(
                    x, z, gyroscopeRate, accelerometerAngle, gyroscopeRate * dt, self.angle, error, self.integral_error, differential_error, up, ui, ud, u, dt * 1000))
        
        # control the motors
        if not self.disable_motors:
            self.motor_left.set_value(u, dt)
            self.motor_right.set_value(u, dt)

#.........這裏部分代碼省略.........
開發者ID:lewisling,項目名稱:yarapibabot,代碼行數:103,代碼來源:control.py


注:本文中的motor.Motor.set_value方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。