![]() |
Drive Train Curves Only While Backing Up
Hello,
For some reason our drive train is curving to the right only when we backup. When we use the joysticks, it does not curve. When we set the talon manually (Talon.set(-1)), it curves to the right pretty severely. We're using a 6-wheel drive train (3 on each side) with a mini toughbox. Our motors are 4 KoP CIM motors and we're using 4 talons for our motor controllers. We're splitting the PWM cable so we're only using two PWM cables to access the 4 talons. We're kind of unsure what this could be so I was wondering if anyone had an issue like this before or what your ideas might be as to what's causing it. Thanks! |
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
Did you calibrate the speed controllers?
|
Re: Drive Train Curves Only While Backing Up
Quote:
The lights are a solid green when backing up. This is due to the fact that our motors are sort of hooked up backwards -- from the way it was explained to me we would have to swap the negative and the positive wires to fix it in hardware (which is supposedly a big no-no) so I've been compensating for it in programming. Is this what most teams do? |
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
Quote:
http://www.crosstheroadelectronics.c...Manual_1_1.pdf On page 7 are the calibration instructions. |
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
It's the first thing I would do....it doesn't cost anything, but time.
|
Re: Drive Train Curves Only While Backing Up
Quote:
We swapped the PWM cables in the RoboRIO (port 0's cables are now in 1 and port 1's cables are now in 0) and now, when reversing, we reverse while curving in the opposite direction. We hooked the output of them up to an oscilloscope and it is showing that one port's PWM is getting more signal than the other although in the code I am giving them the same values. Any ideas? For example, if I do RobotDrive.tankDrive(-0.5, -0.5) it is producing the PWM similar to RobotDrive.tankDrive(-0.6, -0.5). |
Re: Drive Train Curves Only While Backing Up
Are you declaring both motor controllers to be of the same class (e.g. not one Talon and one Jaguar)?
See the second paragraph in the white area of: http://wpilib.screenstepslive.com/s/...ns-and-jaguars |
Re: Drive Train Curves Only While Backing Up
Are you saying that the direction of curving is following the code, not the hardware?
if so, you'll have to get some help from a programmer....and I suggest you post images or listings of your code so they can see what you have done. |
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
Quote:
Another thing to try is program for ports 1&2 to see if it related to a specific port since the issues are common to port 0 Aloha! |
Re: Drive Train Curves Only While Backing Up
Quote:
I suspect the call to the tank drive method or the open constructor would include similar parameters to invert the motor outputs. |
Re: Drive Train Curves Only While Backing Up
Thanks for all of the replies so far everyone.
I'm not there testing but have someone else testing. I'm going to be recalibrating them (and consequently posting here with my findings) sometime around 3 PM EST today. Maybe I'm interpreting the oscilloscope wrong -- here are the images I received. Linking to rather than embedding the pictures because they're massive. Oscilloscope Reading #1 Oscilloscope Reading #2 The readings are from the PWM signals with the ports swapped running the very basic code below I wrote to confirm it wasn't a programming issue. As for my code testing this, I literally just created a new IterativeRobot I just did: Code:
RobotInit() { |
Re: Drive Train Curves Only While Backing Up
I concur. What do the outputs of 3, 4, and so forth look like? Whichever one disagrees with the others should be reserved for standalone (one controller) functions, not the drive train.
|
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
I've seen strange discrepancies in drive motor response when the motors are cross-wired between a pair of speed controllers. It's probably not what you're seeing, but go ahead and double-check that each motor is properly wired to its single associated Talon.
Also double-check that your Talons are all the same variety. I didn't think the SR and non-SR models had different responses, but I know there are definitely differences between old and new Victors, so it's worth looking at. |
Re: Drive Train Curves Only While Backing Up
Those measurements are from the PWM port, right?
Can you post the full source code of the IterativeRobot test you just made? |
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
We had exactly the same problem earlier in the season and it turned out to be the joysticks, so make sure it's not those. You can do this by watching the joystick outputs on the Dashboard. If that is the problem, you can easily fix it by putting in a bigger deadband.
|
Re: Drive Train Curves Only While Backing Up
Quote:
Code:
Are those readings normal? Has anyone ever had this issue of the PWM signals having about a 200ms delay hooked up to an oscilloscope? Is this expected and does calibrating the talons somehow take care of this? |
Re: Drive Train Curves Only While Backing Up
This is expected behavior. -0.2 is represented by a different PWM pulsewidth than 0.2.
If you set both Talons to 0.2 or -0.2 simultaneously, I'd bet you see nearly identical pulses. |
Re: Drive Train Curves Only While Backing Up
Quote:
Code:
package org.usfirst.frc.team2559.robot; |
Re: Drive Train Curves Only While Backing Up
Quote:
tankDrive(-.4, .4) or visa versa should result in identical pulsewidths. |
Re: Drive Train Curves Only While Backing Up
Quote:
I'm trying to calibrate the talons at the moment but they're simply flashing red (which means failure, according to the document). I'm pressing and holding them while going full throttle forward, going to neutral, and then going full throttle backwards, and then back to neutral. After that, I put them back into neutral. Is that how you guys usually do it? |
Re: Drive Train Curves Only While Backing Up
Quote:
|
Re: Drive Train Curves Only While Backing Up
Quote:
Normally, if you wire red to + on both the left and right side, you would expect to see one speed controller flash red while the other flashes green when driving forward (since you will have needed to invert one side in code because it is in the opposite physical orientation). If you switch the motor leads on one side instead, you would NOT want to invert the command in code, and both sides would blink the same color. Since there are two ways to invert each motor, it is easy to get confused. For this reason, I HIGHLY recommend NEVER inverting motors electrically...always do red to +, and invert in the code as necessary. This way, if you need to swap in a spare motor or speed controller, you never need to guess which way to wire it up because they are all always the same. |
Re: Drive Train Curves Only While Backing Up
I just wanted to update this and thank you all for your help. Calibrating each of the individual talons fixed this issue (or at least made the curve very hard to notice). I hope that if anyone else has this issue they see this thread and don't have to go through what we did, lol.
|
Re: Drive Train Curves Only While Backing Up
Quote:
Quote:
|
| All times are GMT -5. The time now is 00:46. |
Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © Chief Delphi