|
|
|
![]() |
|
|||||||
|
||||||||
![]() |
| Thread Tools |
Rating:
|
Display Modes |
|
#1
|
||||
|
||||
|
Child function problems
My goal right now is to put everything in our main code (west coast, motor automation, etc.) into child functions in the IterativeRobot.h header file. However, the CANTalon and Talon instances, when initialized within the function itself, executes over and over again as the main TeleopPeriodic section in the main program loops and therefore starts and shuts off the motor over and over again. Here's the code:
Code:
int motorAutomationEncoder(double encoderDist,
double encoderDistThresholdMax,
double encoderDistThresholdMin,
const int motorPort,
double motorSpeed)
{
CANTalon motor(motorPort);
if(encoderDist > encoderDistThresholdMax) {
motor.Set(0.0);
}
else if(encoderDist <= encoderDistThresholdMax && encoderDist >= encoderDistThresholdMin) {
motor.Set(motorSpeed);
}
else if(encoderDist < encoderDistThresholdMin) {
motor.Set(0.0);
}
SmartDashboard::PutNumber('current motor value', motor.Get());
}
|
|
#2
|
|||
|
|||
|
Re: Child function problems
You've basically explained the cause of the problem yourself. You need to declare the Talons as member variables of the class and initialize them in the function that starts your robot code. In other words, you need to move the initialization out of that function and into on that is only executed once. Its hard to be more specific without more code, but I hope this helps.
|
|
#3
|
||||
|
||||
|
Re: Child function problems
I agree with lopsided. I'll add a few things as well.
* As a bug/nit - I dont see encoderDist being 'set' or assigned or incremented anywhere. Maybe outside the scope of what you pasted in. But without...it'll not operate as you intend. * You talk about putting code into the .h header file. Header files are not the best place to put implementations (code). This is because there are other files which may EACH #include such a header file. When it gets included by multiple files, the implementation will be done multiple times and you'll at least get strange errors from the compiler which may be very non-obvious how to fix. Put implementation/code in .cpp files only. bob |
|
#4
|
|||
|
|||
|
Re: Child function problems
Quote:
|
|
#5
|
||||
|
||||
|
Re: Child function problems
Quote:
Code:
motorAutomationEncoder(e_encoder_dist, 200, -100, fan_motor_SRX, 1.0); Code:
int motorAutomationEncoder(double encoderDist,
double encoderDistThresholdMax,
double encoderDistThresholdMin,
CANTalon motor,
double motorSpeed)
{
if(encoderDist > encoderDistThresholdMax) {
motor.Set(0.0);
}
else if(encoderDist <= encoderDistThresholdMax && encoderDist >= encoderDistThresholdMin) {
motor.Set(motorSpeed);
}
else if(encoderDist < encoderDistThresholdMin) {
motor.Set(0.0);
}
}
|
|
#6
|
||||
|
||||
|
Re: Child function problems
Quote:
|
|
#7
|
|||
|
|||
|
Re: Child function problems
You can, but you just can't create the motor controller within that function. You need to create it when the robot starts, but then you can set its speed in the function.
|
|
#8
|
||||
|
||||
|
Re: Child function problems
Quote:
Code:
int motorAutomationEncoder(double encoderDist,
double encoderDistThresholdMax,
double encoderDistThresholdMin,
CANTalon motor,
double motorSpeed)
{
if(encoderDist > encoderDistThresholdMax) {
motor.Set(0.0);
}
else if(encoderDist <= encoderDistThresholdMax && encoderDist >= encoderDistThresholdMin) {
motor.Set(motorSpeed);
}
else if(encoderDist < encoderDistThresholdMin) {
motor.Set(0.0);
}
}
|
|
#9
|
||||
|
||||
|
Re: Child function problems
If you want to use your CANTalon object, you should pass it as a pointer .
Code:
CANTalon *pMySpeedController ... pMySpeedController->Set(x); ... |
|
#10
|
||||
|
||||
|
Re: Child function problems
Quote:
Code:
Info: Nothing to build for Encoder Info: Nothing to build for Intermediate Vision Info: Nothing to build for Mecanum Drive Info: Nothing to build for Motor Control With Encoder Info: Nothing to build for PDP CAN Monitoring Info: Nothing to build for Simple Vision Info: Nothing to build for Solenoids Info: Nothing to build for [FRC2015_MAINCODE] Info: Nothing to build for cases code Info: Nothing to build for example Main program Code:
... CANTalon *fan_motor_SRX; ... motorAutomationEncoder(e_encoder_dist, 300, -100, fan_motor_SRX, 1.0); ... START_ROBOT_CLASS(Robot); Code:
int motorAutomationEncoder(double encoderDist,
double encoderDistThresholdMax,
double encoderDistThresholdMin,
CANTalon *motor,
double motorSpeed)
{
if(encoderDist > encoderDistThresholdMax) {
motor->Set(0.0);
}
else if(encoderDist <= encoderDistThresholdMax && encoderDist >= encoderDistThresholdMin) {
motor->Set(motorSpeed);
}
else if(encoderDist < encoderDistThresholdMin) {
motor->Set(0.0);
}
}
Last edited by DrOmni9885 : 05-02-2015 at 19:36. Reason: removed irrelevant sections of code |
|
#11
|
||||
|
||||
|
Re: Child function problems
A couple thoughts...
I teach my students to right-click on the project they want to build (in the left pane) and select "Build Project" ... this way there's no question what was being asked of Eclipse. I would suggest doing the following to help further diagnose if the above doesn't help (which it probably wont since its really just general)... - Right click on the project and select 'clean project' - Verify it's clean by opening up the 'Debug' folder in eclipse for that project and you should NOT see FRCUserProgram which is the final binary output file that gets sent to the roborRIO - Click on the 'problems' tab in the lower / console area at the bottom of Eclipse. - Right click on 'Errors' and select 'Delete' - and confirm. - Right click on 'Warnings' and select 'Delete' - and confirm. - Confirm there is nothing in the 'problems' tab any longer. This is a bit painful but will make sure you're only looking at NEW problems and not old ones. - Now right click on the project again and select 'Build Project' ... After it completes, look in the 'problems' tab for errors and warnings. - If there are errors/warnings - post them here. - If there are no errors, take a look again in the Debug folder in the project (left pane) and see if there is a FRCUserProgram (this would indicate a successful compile) - If there is indeed an FRCUserProgram, then you should be good to right click on the project and select RunAs->WPILibC++Deploy If you got to the deploy - then check in the lower area for a 'Console' tab which will have the results of the deploy operation. Once this works well, it shouldn't be so painful as described above. I'm just trying to eliminate any variables I can so that the next step of troubleshooting becomes illuminating of the root cause. Hopefully. ![]() bob |
![]() |
| Thread Tools | |
| Display Modes | Rate This Thread |
|
|