from machine import Pin, PWM, Timer from time import sleep from math import sin, pi, floor Out1 = Pin(18, Pin.OUT) Out2 = Pin(19, Pin.OUT) fwd = PWM(Pin(18)) rev = PWM(Pin(19)) fwd.freq(100) rev.freq(100) pin1 = Pin(26,Pin.IN) pin2 = Pin(27,Pin.IN,Pin.PULL_UP) N1 = N2 = N12 = 0 flag = 0 def ChanA(pin1): global pin2 global N1 if(pin1.value() ^ pin2.value()): N1 += 1 else: N1 -= 1 def ChanB(pin2): global pin1 global N1 if(pin1.value() ^ pin2.value()): N1 -= 1 else: N1 += 1 pin1.irq(trigger=Pin.IRQ_FALLING | Pin.IRQ_RISING, handler=ChanA) pin2.irq(trigger=Pin.IRQ_FALLING | Pin.IRQ_RISING, handler=ChanB) def tick(timer): global N1, N2, N12, flag X = N1 N12 = N1 - N2 N2 = X flag = 1 tim = Timer() tim.init(freq=20, mode=Timer.PERIODIC, callback=tick) t = V = 0 dt = 1/20 kv = 65535 / 13.4 # convert volts to pwm kq = 2*pi/1000 # convert counts to radians kw = 0.16*pi/4 fwd.duty_u16(0) rev.duty_u16(0) D = 0.1266 P = 5*D while(t < 10): while(flag == 0): pass flag = 0 if( (t>1) & (t<6)): Ref = 50 else: Ref = 0 Angle = N1*kq Speed = N12*kw V = P*(Ref - Angle) + D*(0 - Speed) if(V>0): fwd.duty_u16(int(V*kv)) rev.duty_u16(0) else: fwd.duty_u16(0) rev.duty_u16(int(-V*kv)) print('{: 7.2f}'.format(t), '{: 7.2f}'.format(Ref), '{: 7.4f}'.format(Angle), '{: 7.4f}'.format(Speed)) t += dt print('Stop') fwd.duty_u16(0) rev.duty_u16(0)