Chief Delphi

Chief Delphi (http://www.chiefdelphi.com/forums/index.php)
-   C/C++ (http://www.chiefdelphi.com/forums/forumdisplay.php?f=183)
-   -   Child function problems (http://www.chiefdelphi.com/forums/showthread.php?t=133987)

DrOmni9885 04-02-2015 18:46

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());
        }

I'd appreciate any help. Thanks!

Ben Wolsieffer 04-02-2015 18:54

Re: Child function problems
 
Quote:

Originally Posted by DrOmni9885 (Post 1438417)
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

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.

bob.wolff68 04-02-2015 19:05

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

Ben Wolsieffer 04-02-2015 19:14

Re: Child function problems
 
Quote:

Originally Posted by bob.wolff68 (Post 1438426)
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.

Just a side note: It is not always bad to put implementation in a header, as long as you use include guards. The real problem is that every time you make a change to the implementation in the header, all files that include it need to be recompiled, which can take a long time in large projects. There are some times when you are required to put implementation in a header, such as when you are using templates, but that is another topic altogether.

DrOmni9885 04-02-2015 19:59

Re: Child function problems
 
Quote:

Originally Posted by bob.wolff68 (Post 1438426)
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

In my actual program, Robot.cpp, I currently have this line:

Code:

motorAutomationEncoder(e_encoder_dist, 200, -100, fan_motor_SRX, 1.0);
In other words, I have a variable in Robot.cpp, e_encoder_dist, that reads the distance returned by the encoder. Currently both the header file and the program itself give me the error "use of deleted function CANTalon::CANTalon(const CANTalon&)", and after I changed my function code to this:

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);
                }
        }

...the constantly-shutting-off-and-on problem seems to have disappeared.

DrOmni9885 04-02-2015 20:00

Re: Child function problems
 
Quote:

Originally Posted by lopsided98 (Post 1438421)
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.

In other words there's no way I can write a child function that dictates the movement of motors? That's... to bad I guess. I'll see what I can do. Thanks for your help.

Ben Wolsieffer 04-02-2015 20:04

Re: Child function problems
 
Quote:

Originally Posted by DrOmni9885 (Post 1438464)
In other words there's no way I can write a child function that dictates the movement of motors? That's... to bad I guess. I'll see what I can do. Thanks for your help.

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.

DrOmni9885 04-02-2015 20:05

Re: Child function problems
 
Quote:

Originally Posted by lopsided98 (Post 1438467)
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.

Will this work

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);
                }
        }

As aforementioned, the start-stop loop seems to have disappeared.

bob.wolff68 05-02-2015 00:48

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);
...


DrOmni9885 05-02-2015 19:32

Re: Child function problems
 
Quote:

Originally Posted by bob.wolff68 (Post 1438609)
If you want to use your CANTalon object, you should pass it as a pointer .

Code:

CANTalon *pMySpeedController
...
pMySpeedController->Set(x);
...


This is weird, but whenever I try deploying the code Eclipse tells me there's nothing to build for any project after I added the pointer. Here's the information from the console:

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

The project I'm trying to build is [FRC2015_MAINCODE]. Here's the portion of the code which I've changed:

Main program
Code:

...
        CANTalon *fan_motor_SRX;
...
        motorAutomationEncoder(e_encoder_dist, 300, -100, fan_motor_SRX, 1.0);
...
START_ROBOT_CLASS(Robot);

Header file (function):
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);
                }
        }

All other projects work when I try to deploy them. What could be wrong here?...

bob.wolff68 06-02-2015 18:52

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


All times are GMT -5. The time now is 12:07.

Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © Chief Delphi