![]() |
Swerve vs. Mecanum Programming
I have seen many people talk about the advantages and disadvantages of Swerve vs. Mecanum. I have seen one argument that a swerve is harder to program than a mecanum but I think it is the other way around. I have built at least 2 VIs (I use LabView) for a swerve drive and my dad has built at least 5. I still have yet to figure out how to program a mecanum drive.
So my two questions 1. What is you opinion on Swerve vs. Mecanum Programing difficulty. 2 Am I missing an equation or formula that can be used in programing a mecanum drive that makes it easier? |
Re: Swerve vs. Mecanum Programming
Quote:
2 JOYSTICK TANK DRIVE MECANUM SEPARATION OF VARIABLES http://www.chiefdelphi.com/forums/sh...94&postcount=1 3-AXIS JOYSTICK MECANUM ALGORITHM http://www.chiefdelphi.com/forums/sh...383#post916383 The above algorithms are not optimum, but they work. ~ |
Re: Swerve vs. Mecanum Programming
Without getting into detailed equations, the mathematical principles of fully holonomic omni/mecanum drives are relatively simple and can be approached this way:
Each wheel has a direction vector along which it can transmit force in either direction. For a mecanum this is at 45 degrees to the plane of the wheel, parallel to the axle of the roller contacting the ground. For an omni it's along the flat plane of the wheel. No force is or can be transmitted except along this vector. To get the wheel speeds necessary for any desired motion, you need to compute the projection of the motion vector onto each wheel's direction vector. For mecanums there's an additional constant to correct for the 45 degree angle. This can be done with dot products and no trigonometry. For simple directional motion, regardless of direction, that's all there is to it. To handle rotation, the motion vectors are tangent to a circle about the center of rotation, projected on the same wheel vectors, and scaled by relative radius. For rotation about the center of a normally configured robot, these end up the same for each wheel. Rotation about other points or for odd wheel configurations is a bit more complex but conceptually the same. You can rotate and move simultaneously by solving the wheel speeds for each separately, then adding the motion and rotation components for each wheel to get its final drive speed. This approach lends itself well to a two stick motion/rotation or single stick/twist control setup, and the vector math shouldn't take more than a couple of dozen lines of Java or C. It handles any motion physically possible with the robot. The motor drive functions needed for swerve drives, especially for complex motions, are considerably more complicated. It should be noted that there are simpler but still useful ways to employ mecanum/omni wheels short of full holonomic, and other ways to program swerves short of the "almost holonomic" of which they're capable. |
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
Quote:
Quote:
x' = xcos(theta) - ysin(theta) y' = xsin(theta) + ycos(theta) ... but Buchanan's approach is technically more correct and will yield more optimal control (more accurate directional control, smoother operation, and less scrubbing of the wheels) ~ |
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
AM has a great powerpoint about omnidirectional drive, which has several diagrams that may make seeing the vectors talked about above easier to see.
http://www.andymark.biz/presentations.html Also, if you use a gamepad or similar control device, using the left joystick to control the movement of the actual robot and using the right joystick x axis to rotate the robot, it makes it very easy for someone who has played Halo to figure out how to drive your robot. |
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
Hey we are team 647 and we are trying to develop our own swerve drive and I was wondering if you can post some examples of your program we are having some troble with our program and we are using Lab View.
Thank You :D |
Re: Swerve vs. Mecanum Programming
Quote:
Baisically what my code does is it compares two numbers and if the pos_in(position the feedback tells you you are in) is greater than pos_to(Position to go to) then it sets the speed to -1 and 1 if it is the other way around. I also have a lot of safeties built in such as: If the feedback isn't counting, if it is turning the wrong way, etc. You may have a few questions because I really haven't commented any of it and it even confused my dad at first, so I will be willing to answer any other questions you have. |
Re: Swerve vs. Mecanum Programming
Quote:
it's called proportional control. p from pid. Basically, you say; Code:
error = setpoint - process_variableEdit: Forgot to talk about I and D: Integral (I): Basically you integrate the error and add it to the output: Code:
integral += errorDerivative (D): You calculate the derivative of the previous action to determine how momentum will affect the stopping ability. Basically, it works against P and I to slow it down when it nears the end, allowing a higher P gain. You will almost certainly not need this with crab steering, as the friction of turning the pods will probably slow their rotation very quickly (D would be useful for, say, a 6' arm that has a lot of mass at the end). |
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
1 Attachment(s)
Ok I have attached my code for the swerve drive. I will answer any questions.
|
Re: Swerve vs. Mecanum Programming
While I can't look at your code since I don't have LV on this computer, I can say a few things in general:
1. P should be good for steering, unless you have a lot of friction. 2. You should rely on the sensor. Not too much, but don't program all kinds of safeties like it going in the wrong direction. good limits are out of bounds, lost sensor (0 volts), and not moving if you are really worried about it. We have no mechanical limits on our swerve, except the wiring, and we leave a lot of extra wire. Using window and globe motors (especially the window motors), it doesn't have enough power to damage much in our application. 3. Use the same code in auto as teleop - best to put it in a new thread. 4. Make kP (gain) a front-panel control or global to tune it. If you are using four identical motors (e.g. window motors), you would probably be fine with one gain and volts/deg, and x centerpoints (where x is the number of controllers), if you mix motors (e.g. window+555 or window+globe), then you would need a different gain for each motor and volts/deg for each different sensor (e.g. when sensor gearing or # of turns is different). 5. Pots never completely fall off. We have had many problems with set screws coming loose and pots loosing connection, but never completely fall off. 6. Don't be scared of code changes. We change our code quite frequently, and generally try to test it before playing, depending on how major the change was (we don't generally test autonomous kick distance changes, for instance). |
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
Ok some questions on your example what are you using in your robot to know the position in which the wheel is, are you using limit switches, gyro or any thing else, also on the example it does not show the motors or joystick is that an additional program or how are you runing this program.
Thanks :) |
Re: Swerve vs. Mecanum Programming
He is using analog potentiometers.
This is a subVI. He calls it from his other code when he needs it. I would highly, highly, highly (I can't say this enough) recommend organizing code this way, especially separating mechanism control code from user interface code in separate threads. Since he has a potentiometer, he has no need for limit switches. It tells him everything he needs to know. I would generally not use his method of "check greater/equal/lesser and set output based on case" and instead use proportional control, LabVIEW has a nice PID block you can use for PID or you can write your own, its just a subtract, multiply, and check range. |
Re: Swerve vs. Mecanum Programming
Quote:
On the other hand, if you're moving a massive mechanism around, you definitely want to slow it down on its way to the target position. Stopping it abruptly can lead to extreme stress on the gears (as demonstrated well by the teeth being stripped off a large sector of a heavy gear on the TechnoKats 2004 robot's arm by the team's programming mentor :o a few minutes before the pre-ship open house was to begin). |
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
Ok I do undersand what your program does and its a really simple program, but what I am looking for is an even simple example, I am a senor so I am leaving this year and i am trainig some one for next year and I need something that is simple to explain.
Thanks |
Re: Swerve vs. Mecanum Programming
Quote:
|
Re: Swerve vs. Mecanum Programming
1 Attachment(s)
I have attached a simpler VI that could be used as a swerve drive. This one is commented so all your questions should be answered but I can still answer and other questions you have.
|
| All times are GMT -5. The time now is 23:13. |
Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © Chief Delphi