Go Back   EcoModder Forum > EcoModding > Fossil Fuel Free > Open ReVolt: open source DC motor controller
Register Now
 Register Now
 

Reply  Post New Thread
 
Submit Tools LinkBack Thread Tools
Old 04-19-2015, 02:50 AM   #7041 (permalink)
EcoModding Lurker
 
Join Date: Apr 2015
Location: USA
Posts: 12
Thanks: 5
Thanked 4 Times in 3 Posts
Yep power section is built. I used the entire board just for the little DC motor. RTD explorer said 7 amps max on the current feedback.

  Reply With Quote
Alt Today
Popular topics

Other popular topics in this forum...

   
Old 04-19-2015, 03:02 AM   #7042 (permalink)
PLUGnGO
 
jedsmd's Avatar
 
Join Date: Sep 2012
Location: Olympia Wa
Posts: 137
Thanks: 75
Thanked 82 Times in 54 Posts
Quote:
Originally Posted by Articus View Post
Yep power section is built. I used the entire board just for the little DC motor. RTD explorer said 7 amps max on the current feedback.
Congrats! Photos?

(Sorry I've no help on your current limiting question)
  Reply With Quote
Old 04-19-2015, 03:14 AM   #7043 (permalink)
EcoModding Lurker
 
Join Date: Apr 2015
Location: USA
Posts: 12
Thanks: 5
Thanked 4 Times in 3 Posts
Quote:
Originally Posted by jedsmd View Post
Congrats! Photos?

(Sorry I've no help on your current limiting question)
Thanks and of course . I made 2 of them, here is the first:


I'm waiting on an order from Mouser for the VR1 trim pot on the second one because I lost the ones I originally ordered
  Reply With Quote
Old 04-19-2015, 03:20 AM   #7044 (permalink)
PLUGnGO
 
jedsmd's Avatar
 
Join Date: Sep 2012
Location: Olympia Wa
Posts: 137
Thanks: 75
Thanked 82 Times in 54 Posts
Nice, what are you putting these into?
  Reply With Quote
Old 04-19-2015, 10:21 PM   #7045 (permalink)
PaulH
 
MPaulHolmes's Avatar
 
Join Date: Feb 2008
Location: Maricopa, AZ (sort of. Actually outside of town)
Posts: 3,832

Michael's Electric Beetle - '71 Volkswagen Superbeetle 500000
Thanks: 1,362
Thanked 1,202 Times in 765 Posts
Depending on the motor, it may not be using 7 amps. Also, there would be very little resolution, since it's a LEM Hass 300-s. There are 128 ticks of the A/D for each 300 amps. So, around 2 amps per tick of the A/D. Figure +/-1 tick of resolution, and it can only resolve +/- 2 amps. My guess is that the motor is using less than 7 motor amps, and so the PWM just ramps to 100% trying to see 7 motor amps.
__________________
kits and boards
  Reply With Quote
Old 04-22-2015, 03:31 AM   #7046 (permalink)
Dreamer
 
Join Date: Nov 2013
Location: Australia
Posts: 350
Thanks: 95
Thanked 214 Times in 151 Posts
Quote:
Originally Posted by MPaulHolmes View Post
Depending on the motor, it may not be using 7 amps. Also, there would be very little resolution, since it's a LEM Hass 300-s. There are 128 ticks of the A/D for each 300 amps. So, around 2 amps per tick of the A/D. Figure +/-1 tick of resolution, and it can only resolve +/- 2 amps. My guess is that the motor is using less than 7 motor amps, and so the PWM just ramps to 100% trying to see 7 motor amps.
Since it is low current and just for testing with a small motor. How about taking the LEM 300 off of the copper bar and running a wire from the copper bar, looping through the LEM several times (not sure how many) and then to the motor? Thereby increasing the magnetic field measured by the LEM. Effectively reducing the LEM to say a LEM 20 rather than an LEM 300.
  Reply With Quote
The Following User Says Thank You to Astro For This Useful Post:
MPaulHolmes (04-22-2015)
Old 04-22-2015, 08:55 AM   #7047 (permalink)
PaulH
 
MPaulHolmes's Avatar
 
Join Date: Feb 2008
Location: Maricopa, AZ (sort of. Actually outside of town)
Posts: 3,832

Michael's Electric Beetle - '71 Volkswagen Superbeetle 500000
Thanks: 1,362
Thanked 1,202 Times in 765 Posts
That works very well to do that. Good idea!
__________________
kits and boards
  Reply With Quote
Old 05-07-2015, 12:18 PM   #7048 (permalink)
EcoModding Lurker
 
Join Date: Nov 2012
Location: West
Posts: 7
Thanks: 1
Thanked 3 Times in 3 Posts
I'm totally confused by the "PI" loop in the Cougar11B code. Can someone please help me see where I've made a mistake:

In config you have:
Kp ( from the example in the code, this is 1 or 2)
Ki ( from the example in the code somewhere between 20 and 160)


In config_pi:

v1 =Kp<<10
pi.K1=v1 (so ~2000)
pi.k2=Ki-pi.K1 (so ~ -1800)


In the main loop:

pi.error_new = current_ref - current_fb;
pi.pwm += (pi.K1 * pi.error_new) + (pi.K2 * pi.error_old);

drop the pi. and substitute for K2 (watch the i's and 1's):

pwm += (K1 * error_new) + ((Ki-K1) * error_old);
pwm += (K1 * error_new) + (Ki * error_old) - (K1 * error_old);
pwm += (K1 * (error_new - error_old)) + (Ki * error_old);

finally :

pi.error_old = pi.error_new;

I can't see an integral term in there. Normally you'd have something like

pi.total_error += pi.error_new;

but the code is just setting new to old, not accumulating.

The first term appears to be a differential term. If so, what's running is a PD controller, but the proportional term (Ki) is acting on the last error, not the current error.

Substituting some imaginary values:

pi.pwm += (2000*10) -1800*50;
pi.pwm += 20000 - 90000 = -70000;

the final signal is pi.pwm >> 16 so the output would change by 254, not unreasonable.

Empirically, the loop is stable, so I feel I must be missing something - PD is not unstable.
  Reply With Quote
The Following User Says Thank You to artc For This Useful Post:
MPaulHolmes (05-07-2015)
Old 05-07-2015, 01:06 PM   #7049 (permalink)
PaulH
 
MPaulHolmes's Avatar
 
Join Date: Feb 2008
Location: Maricopa, AZ (sort of. Actually outside of town)
Posts: 3,832

Michael's Electric Beetle - '71 Volkswagen Superbeetle 500000
Thanks: 1,362
Thanked 1,202 Times in 765 Posts
I didn't do the PI loop the traditional way. I did it like this:

Let P and I be the constants. error(t) is the error between the desired current, and the actual current. pwm(t) is the duty at time t.

pwm(t) = P*error(t) + I*INTEGRAL(error(TAU)), where the integral goes from 0 to t, hence the dummy variable TAU (remember that in calculus? hehe. They always use TAU! What's up with that?).


Differentiate both sides:

(2) d (pwm)/dt = P*d(error)/dt + I*error(t), by the Fundamental Theorem of Calculus. (The one where differentiating the integral leaves the function)


Now, I approximated d(error)/dt and d(pwm)/dt by finding the slope of two points for a small time interval, like 0.001, which was my throttle sampling rate back in the day, and substitute it into equation (2).



So, d(error)/dt IS REPLACED WITH (errorNew - errorOld)/deltaT. (remember the difference quotient. We just aren't letting h --> 0. Just using small h)



Also, d(pwm)/dt IS REPLACED WITH deltaPWM/deltaT.



Also, replace error(t) with errorOld. (You could use either errorOld or errorNew if you wanted I think).



So, after substituting, Equation (2) becomes:
(2b) deltaPWM/deltaT = P*(errorNew - errorOld)/deltaT + I*errorOld

Now, multiply both sides by deltaT:

(3) deltaPWM = P*(errorNew - errorOld) + I*deltaT*errorOld

Now, distribute P, and get all the errorOld stuff together:



(4) deltaPWM = P*errorNew - P*errorOld + I*deltaT*errorOld

(5) deltaPWM = P*errorNew + (I*deltaT - P)*errorOld


So, kp = P, and ki = I*deltaT - P. kp and ki are constants, because I, P, and deltaT are constant.
__________________
kits and boards
  Reply With Quote
The Following User Says Thank You to MPaulHolmes For This Useful Post:
artc (05-07-2015)
Old 05-07-2015, 03:52 PM   #7050 (permalink)
EcoModding Lurker
 
Join Date: Nov 2012
Location: West
Posts: 7
Thanks: 1
Thanked 3 Times in 3 Posts
Quote:
Originally Posted by MPaulHolmes View Post
I didn't do the PI loop the traditional way.
No argument from me there

You're right in that you're calculating deltaPWM rather than PWM so there's an additional differentiation that comes into play.

Quote:
Originally Posted by MPaulHolmes View Post
(5) deltaPWM = P*errorNew + (I*deltaT - P)*errorOld
(As a PI equation that seem intuitively horribly wrong, but I can' see a problem in the mathematics).

What bothers me about (5) is that somewhere I'm missing an inversion (possibly U5C?). With a "direct" drive I think that lower pwm, lower OCR1A would lead to an increased current which would imply a negative proportional term. However, I think that output of that loop increases with increasing error.

  Reply With Quote
Reply  Post New Thread




Similar Threads
Thread Thread Starter Forum Replies Last Post
Paul and Sabrina's Cheap 3 Phase Inverter (AC Controller) with Field Oriented Control MPaulHolmes Fossil Fuel Free 3431 05-04-2022 06:43 PM
Paul & Sabrina's Cheap EV Conversion MPaulHolmes Fossil Fuel Free 542 11-12-2016 10:09 PM
Three Dirt Cheap DIY Electric Cars - Part 5 SVOboy EcoModder Blog Discussion 0 12-12-2008 05:10 PM



Powered by vBulletin® Version 3.8.11
Copyright ©2000 - 2025, vBulletin Solutions Inc.
Content Relevant URLs by vBSEO 3.5.2
All content copyright EcoModder.com