![]() |
RELAY!!
is it possible to set a relay to get the Y-axis on a joystick? I have tried
Code:
Relay->Set(Thirdstick.kYAxis());Code:
Relay->Set(Thirdstick.GetY()); |
Re: RELAY!!
A joystick axis gives a value from -1 to +1. A relay is either on or off. Can you describe in detail what you're trying to do? Right now, I'm as confused as the compiler is about the intended behavior.
|
Re: RELAY!!
the relay is used to control a motor on our arm. For the motor to go forward or backward I had set a button for it and used an "else" statement which would keep it off. Now I would like to use the joystick to make the motor go forward or backward.
|
Re: RELAY!!
So you want the relay to be set "forward" if the joystick is pushed forward, you want the relay to be set "reverse" if the joystick is pulled backward, and you want the relay to be set "off" if the joystick is left at center?
The joystick Y-axis value will be negative if you push it forward. The value will be positive if you pull it backward. The value will be zero if you leave it at center. Does that help send you in the right direction? |
Re: RELAY!!
Quote:
|
Re: RELAY!!
The code you have definitely won't work. It doesn't look like you're creating instances of the classes. Assuming that I'm misunderstanding your code, your problem comes in with what Relay::Set expects as input vs what Victor::Set or Jaguar::Set expect. Compare the prototypes that are found in WPILib
Code:
void Jaguar::Set(float speed)Code:
typedef enum {kOff, kOn, kForward, kReverse} Value;In order to do what you want to do, you'll need some logic. Here's an example for using a forward and reverse threshold (I'm using .5 as my threshold in either direction) to set the state of the relay. Don't forget to turn it off if the stick is between the thresholds. Spoiler for For Jared:
|
Re: RELAY!!
The joystick axes output a double between -1 and 1. Victors and Jaguars conveniently accept a double value between -1 and 1 as an input.
Relays can be set to kForward, kReverse, or kOff (or kOn, but that doesn't seem to matter here). So you need to write some code that translates from [-1, 1] to [kForward, kReverse, kOff]. All you need to do is write an if...else statement that checks if the joystick axis is pushed forward, backwards, or is in the center. In other words, is the axis <0, >0, or ==0 (note that you might not want to check if it is exactly zero, since the tiniest bit of movement would make your motor move - you probably want a threshold so that if the stick is within, say, .1 of 0, just call it zero). EDIT: Aww, Dave - he was getting so close! :) |
Re: RELAY!!
Ok, now I understand, Thanks alot!!
|
Re: RELAY!!
Sorry Jared :o
I went back and put the code in a spoiler tag if krudeboy wants to go through the thinking exercise. EDIT: He just posted which means he probably saw it before the spoiler tag was in. Oh well. It can still be a thinking exercise for those new to programming |
Re: RELAY!!
One Problem, Does anyone know what this error is:
[Qoute] Fatal error "Attempting to resuse an allocated resource" in Allocate() in C:/WindRiver/workspace/WPILib/Resource.cpp at line 76 [/quote] I looked at line 76 of the code, all I have there is a "wait" in autonomous |
Re: RELAY!!
The line 76 is in C:/WindRiver/workspace/WPILib/Resource.cpp not in your code.
That line is checking to see if the index has already been allocated. Code:
if ( m_isAllocated[index] )Check where you declare your variables. You'll get that error if you're trying to create two relays on the same slot. Make sure you don't have something like: Relay r1(1); Relay r2(1); |
Re: RELAY!!
I only have one relay:
Code:
myRobot(1, 2), |
Re: RELAY!!
I went back and added the spoiler tag to retain my original post but to hide it from the casual reader. As Joe said below, my analysis is incorrect. I'll leave the post here for reference.
Spoiler for Hiding bad info:
|
Re: RELAY!!
Quote:
Quote:
|
Re: RELAY!!
What do the numbers in this line represent?
Code:
myRobot(1, 2),Code:
pair1 = new Victor(1); |
Re: RELAY!!
Quote:
|
Re: RELAY!!
Thanks for the correction Joe. After reading through the WPILib code again, I see how this is being done and agree with what you said about the resources. I also see what you mean about my code example. With the realays and digitial i/o on the same slot, it doesn't make any difference to specify the slot number in this case. I went back and put my original post in a spoiler tag to prevent confusion yet still have my bad analysis still available to learn from.
So, back to the analysis of the original error. The error clearly states that a resource is being allocated that was already allocated. I saw that Alan just posted a good suggestion that I was going to suggest next. My other suggestion (somewhat related) was to make sure there were no other places in the code that create relays, speed controllers, or analog/digital inputs on channels that were already in use for that resource type. |
Re: RELAY!!
Quote:
You might want to look into using one of these two implementations of RobotDrive. RobotDrive::RobotDrive(SpeedController *leftMotor, SpeedController *rightMotor, float sensitivity); RobotDrive::RobotDrive(SpeedController &leftMotor, SpeedController &rightMotor, float sensitivity); |
Re: RELAY!!
Quote:
|
| All times are GMT -5. The time now is 14:26. |
Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © Chief Delphi