CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

10 motors
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
nasbyc



Joined: 27 Apr 2009
Posts: 50

View user's profile Send private message AIM Address

10 motors
PostPosted: Mon Nov 07, 2011 1:21 pm     Reply with quote

Hi, I want to control the position of ten dc motors with potentiometers as feedback. I want to use pid algo to calculate the pwm. I already managed to position one of the dc motor to the desired angle.

I intend to use PIC16F1527 as it has 10 Capture/Compare/PWM (CCP) modules. I want the motor to move simultaneously. The problem is that how can I do that. The time base for each motor should be the same, the diff is speed(pwm). Is it possible for me to use one pid algorithm calc the pwm for all motor. what I mean is that, I executes the pid algo to motor in sequence which mean that motor2 not going to be executes until motor 1 achieved it desired angle.

Another alternative is to create one motor with one pid. so I will have ten pid func.fyi I used interrupt to read the potentiometer.thus that mean i need ten interrupt. executes according to priority. Any helps/ideas/advice will be helpful
SherpaDoug



Joined: 07 Sep 2003
Posts: 1640
Location: Cape Cod Mass USA

View user's profile Send private message

PostPosted: Mon Nov 07, 2011 2:03 pm     Reply with quote

How about using 10 really small PICs? The PIC12F5XX types cost less than US$1 each in a 8 pin DIP package. One clock could drive them all, and you should be able to do your PID totally in software if that is all the PIC has to do.
_________________
The search for better is endless. Instead simply find very good and get the job done.
nasbyc



Joined: 27 Apr 2009
Posts: 50

View user's profile Send private message AIM Address

PostPosted: Tue Nov 08, 2011 6:17 am     Reply with quote

is it easier to do that by having each pic for each motor + pot. fyi my system also will have imu (accelerometer and gyro), compass and maybe servo. so do you suggest that I have one pic (act as master) for main program and 10 other small pic (slave) for motors.

I don't have any idea how master slave works.how they comm each other. do you have any material that can i read about about it
temtronic



Joined: 01 Jul 2010
Posts: 9244
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue Nov 08, 2011 7:06 am     Reply with quote

SherpaDoug is right, just think of RC servo systems. Each servo receives info from the 'master', then acts accordingly. Simple, easy to implement.
You can easily do the same with either RS232,RS485,I2C, or your own communications protocol.Just start with one servo, add another, test, add another, test,....until all ten are installed.
One of the MAJOR benefits of this approach is if one servo'subsystem' fails the master PIC won't be destroyed ! Also, spare servo 'subsystems' are cheap and all would be interchangable.
The 'master' PIC can be anything even an 16F84 depending on how fancy the system is.
nasbyc



Joined: 27 Apr 2009
Posts: 50

View user's profile Send private message AIM Address

PostPosted: Tue Nov 08, 2011 9:03 am     Reply with quote

oo ok. What about the hw configuration? For example I want to use pic16f877a one for master and another as a slave. Does it mean that the slave have the same conf as master which has its own crystal frequency, pull up resistor?

I already have one interrupt (timer 0) for pid calc. if i put this programme in slave. for ex if i use i2c, I notice that it need to call the interrupt #int_ssp to comm with the master. if i plan to use i2c, does it effect the interrupt for my pid (the interrupt in pid is use to read potentiometer and while doing the calculation, i disable the timer0 interrupt)
temtronic



Joined: 01 Jul 2010
Posts: 9244
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue Nov 08, 2011 4:12 pm     Reply with quote

First, you need to decide on some overall details.
Overall system performance. Speed that the PID control loops need to operate at. Is this going to be a CNC machine or 'robot'.
Servos ? PWM, linear, ?? Since you say 'pots', can we assume a limited(270* or less) rotation of the servos?
Physical size of the system. How far away will the servos be from the controller. That will decide communication strategy.
Power requirement of the servos. Is this a battery device or tethered to the AC wall socket.
nasbyc



Joined: 27 Apr 2009
Posts: 50

View user's profile Send private message AIM Address

PostPosted: Wed Nov 09, 2011 3:57 am     Reply with quote

thanks for the replies. let me answer ur questions

temtronic wrote:
First, you need to decide on some overall details.
Overall system performance. Speed that the PID control loops need to operate at..


I need the motor to move to the desired angle in 1/8 seconds. Currently the interrupt in my pid which reading the pot is execute every 3.3 ms.

temtronic wrote:
Is this going to be a CNC machine or 'robot'.
Servos ? PWM, linear, ?? Since you say 'pots', can we assume a limited(270* or less) rotation of the servos?


this is a robot. the motors will be place in series (ex a tail/snake). I use the pid to calculate the pwm to varies the speed of each motor but excutes in the same time period. yes, the rotation of the gear motors are plus minus 20 degrees.

temtronic wrote:
Physical size of the system. How far away will the servos be from the controller. That will decide communication strategy. Power requirement of the servos. Is this a battery device or tethered to the AC wall socket.


it is a robot and the motors are in series so the end of the tail (last motor) will be approx 40cm from the controller.about the power req, i use 12v battery for the motor
temtronic



Joined: 01 Jul 2010
Posts: 9244
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed Nov 09, 2011 6:17 am     Reply with quote

Ah, much better 'picture' of the overall project. It's similar to a 'snake' I designed about 10 years ago based on an IEEE article.I hacked common RCservos to get the pot position voltage and fed to a 16F877.It was the cheapest way to get the snake working.
Today, I'd use the servos but have an 8 pin PIC control each servo.It would 'listen' for the master command signal, send the servo pot info, then adjust the 'servo control pulse(1.0-2.0ms)' as dictated by the master.
You could easily use RS485 as the communications bus.It has the speed,noise immunity and simple code to implement.Each 'segment' would consist of the servo,PIC and MAX488 plus a few caps and Rs for filtering.The 'fun' is in the master code to program the 'snake' or 'tail'. Depending on how many segments you have, getting the 'end of the tail' to a predefined point is a lot of math(several DOF) but simple 'S' movements are fairly easy.
Ttelmah



Joined: 11 Mar 2010
Posts: 19544

View user's profile Send private message

PostPosted: Wed Nov 09, 2011 6:45 am     Reply with quote

Have to agree wholeheartedly with using RS485. Also, since the basic needs are really simple, you can be 'sneaky', with a protocol that is easy to implement. Something (say), like using values under 127, for 'motor number', and values over this for 'position'. Each unit then just looks for it's 'motor number' value, and when this is seen, reads the next byte, subtracts 128, and moves to the position this defines. At (say) 100Kbps (a nice round figure, that is easily achieved by most standard clocks), it then takes just 1/5000th second to send a position, and 1/500th second to update them all. Smile

Best Wishes
SherpaDoug



Joined: 07 Sep 2003
Posts: 1640
Location: Cape Cod Mass USA

View user's profile Send private message

PostPosted: Wed Nov 09, 2011 10:53 am     Reply with quote

This sounds like a cool project! If this is for hobby or school you might be able to use a open collector parallel serial bus instead of real RS485 for this short distance.

Either connect all the transmit PIC pins in parallel with a common pull-up resistor and set the UARTS to open collector mode (I don't have my CCS reference with me now). Or have the PIC UART TX pins each drive an external transistor. It will be simpler than putting a real RS484 driver/reciever chip on each motor unit.

With the right software protocol you could have stackable self contained interchangable segments, each with its own motor and processor. You could make the snake longer by removing the tail segment, adding any number of new segments and replacing the tail. On initialization the head segment measures how many segments there are till it finds the tail and adjusts the motion scheme to suit. Very Happy
_________________
The search for better is endless. Instead simply find very good and get the job done.
nasbyc



Joined: 27 Apr 2009
Posts: 50

View user's profile Send private message AIM Address

PostPosted: Wed Nov 09, 2011 11:11 am     Reply with quote

Thanks. This robot is for my research. Currently I try to understand the difference between rs485 and rs232. I try to see how can I interface multi pic + max488. With rs485, it needs the termination resistor.
Ttelmah



Joined: 11 Mar 2010
Posts: 19544

View user's profile Send private message

PostPosted: Wed Nov 09, 2011 4:06 pm     Reply with quote

RS232 - Single source, single destination. Quite good noise immunity because of voltages used, and receive levels selected. Limited maximum speed.

RS488 - Possibly you mean IEEE-488?

RS423 - lower voltage, but similar to RS232 - supports higher data rates, and requires a terminating resistance once data rates rise - supports multiple destination devices (10).

RS485/RS422 - Similar low voltage differential busses. Again requires termination (over 250Kbps, and depending on bus length), supporting higher data rates up to 10Mb.


General comments:

Differential busses, with twisted pair wiring, are _much_ more likely to be reliable with motors around. Even over the short distances involved, you _will_ have problems with single ended busses like RS232/RS423, and motors nearby.....

Once data rates go up, you need to match the bus impedance with a terminating resistor. It's all down to slew rates, and ringing at the ends of the wire. RS232/423, or even RS485, _will_operate happily without termination, but only up to perhaps 250kbps, and with limited slew rates. Go faster, and termination becomes essential. Seriously though, it only involves choosing a cable with a known impedance, and a couple of resistors. Not exactly hard.....

Best Wishes
SherpaDoug



Joined: 07 Sep 2003
Posts: 1640
Location: Cape Cod Mass USA

View user's profile Send private message

PostPosted: Wed Nov 09, 2011 6:14 pm     Reply with quote

Ttelmah wrote:

Once data rates go up, you need to match the bus impedance with a terminating resistor. It's all down to slew rates, and ringing at the ends of the wire. RS232/423, or even RS485, _will_operate happily without termination, but only up to perhaps 250kbps, and with limited slew rates. Go faster, and termination becomes essential. Seriously though, it only involves choosing a cable with a known impedance, and a couple of resistors. Not exactly hard.....


Unless this robotic snake is going to be outrunning a real live snake I doubt the data speeds will have to exceed 9600 baud. RS485 on a twisted pair with terminating resistors in the head and tail sections will certainly work.

RS485 allows one node at a time to transmit to all nodes on the twisted pair line, including itself. You have to establish the protocol so only one node speaks at a time. Usually one node is Master and the others are Slaves who only speak when spoken to.
_________________
The search for better is endless. Instead simply find very good and get the job done.
nasbyc



Joined: 27 Apr 2009
Posts: 50

View user's profile Send private message AIM Address

PostPosted: Thu Nov 10, 2011 6:24 am     Reply with quote

SherpaDoug wrote:
How about using 10 really small PICs? The PIC12F5XX types cost less than US$1 each in a 8 pin DIP package. One clock could drive them all, and you should be able to do your PID totally in software if that is all the PIC has to do.


i looked at pic12f5xx, and try to find that has pwm and able to do rs485 but couldn't find one. as i need 10 of it, better to have small pic. the closest i get are 18 pin (PIC16F87/8828) and 28 pin (PIC16F882/883/886). earlier i run my pid using pic16f877a with 20MHz
SherpaDoug



Joined: 07 Sep 2003
Posts: 1640
Location: Cape Cod Mass USA

View user's profile Send private message

PostPosted: Thu Nov 10, 2011 10:19 am     Reply with quote

Are these motors the hobby servo type that take a 1 to 2ms pulse width to set position? If they are you don't really need PWM hardware. A PIC12F1840 has a UART, 7k of flash 256 RAM, and clocks at 32MHz, all in a 8 pin DIP for $1.50 at Digi-Key.

At 32MHz your PID should really fly, with plenty of CPU cycles left to use one of the timers to drive your servo.
_________________
The search for better is endless. Instead simply find very good and get the job done.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group