00001 /*!@file BeoSub/test-PMComplex.C find pipe */ 00002 // //////////////////////////////////////////////////////////////////// // 00003 // The iLab Neuromorphic Vision C++ Toolkit - Copyright (C) 2001 by the // 00004 // University of Southern California (USC) and the iLab at USC. // 00005 // See http://iLab.usc.edu for information about this project. // 00006 // //////////////////////////////////////////////////////////////////// // 00007 // Major portions of the iLab Neuromorphic Vision Toolkit are protected // 00008 // under the U.S. patent ``Computation of Intrinsic Perceptual Saliency // 00009 // in Visual Environments, and Applications'' by Christof Koch and // 00010 // Laurent Itti, California Institute of Technology, 2001 (patent // 00011 // pending; application number 09/912,225 filed July 23, 2001; see // 00012 // http://pair.uspto.gov/cgi-bin/final/home.pl for current status). // 00013 // //////////////////////////////////////////////////////////////////// // 00014 // This file is part of the iLab Neuromorphic Vision C++ Toolkit. // 00015 // // 00016 // The iLab Neuromorphic Vision C++ Toolkit is free software; you can // 00017 // redistribute it and/or modify it under the terms of the GNU General // 00018 // Public License as published by the Free Software Foundation; either // 00019 // version 2 of the License, or (at your option) any later version. // 00020 // // 00021 // The iLab Neuromorphic Vision C++ Toolkit is distributed in the hope // 00022 // that it will be useful, but WITHOUT ANY WARRANTY; without even the // 00023 // implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR // 00024 // PURPOSE. See the GNU General Public License for more details. // 00025 // // 00026 // You should have received a copy of the GNU General Public License // 00027 // along with the iLab Neuromorphic Vision C++ Toolkit; if not, write // 00028 // to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, // 00029 // Boston, MA 02111-1307 USA. // 00030 // //////////////////////////////////////////////////////////////////// // 00031 // 00032 // Primary maintainer for this file: Michael Montalbo <montalbo@usc.edu> 00033 // $HeadURL: svn://isvn.usc.edu/software/invt/trunk/saliency/src/SeaBee/test-PMComplex.C $ 00034 // $Id: test-PMComplex.C 9057 2007-11-28 04:29:48Z beobot $ 00035 00036 #include "Component/ModelManager.H" 00037 #include "BeoSub/BeeBrain/PreMotorComplex.H" 00038 #include "BeoSub/BeeBrain/ComplexMovement.H" 00039 00040 int main(int argc, char* argv[]) { 00041 00042 <<<<<<< .mine 00043 ModelManager manager("premotor complex test"); 00044 ======= 00045 00046 rutz::shared_ptr<PreMotorComplex> test; 00047 test.reset(new PreMotorComplex("premotorcomplex")); 00048 >>>>>>> .r9393 00049 00050 nub::soft_ref<SubController> motorControl(new SubController(manager, "Controller", "PID")); 00051 manager.addSubComponent(motorControl); 00052 00053 manager.exportOptions(MC_RECURSE); 00054 00055 manager.start(); 00056 00057 PreMotorComplex test(motorControl, "premotorcomplex"); 00058 00059 rutz::shared_ptr<ComplexMovement> move_test; 00060 move_test.reset(new ComplexMovement()); 00061 //move_test.functionList.push_back(NULL); 00062 //move_test.functionList[0] = &PreMotorComplex::turn; 00063 00064 00065 SensorInput a; 00066 a.data = 5.0; 00067 a.angle = *(new Angle(55)); 00068 00069 VisionInput b; 00070 b.position.reset(new Point3D(5, 10, 15)); 00071 b.angle.reset(new Angle(55)); 00072 00073 //move_test->addOnceMove(FORWARD, 5.0, Angle(33.0)); 00074 move_test->addMove(&PreMotorComplex::turn, ONCE, Angle(120)); 00075 move_test->addMove(&PreMotorComplex::vis_turn, ONCE, b.position); 00076 00077 //move_test->addOnceMove(&PreMotorComplex::forward, 5.0, Angle(120)); 00078 00079 //move_test.addRecursiveMove(&PreMotorComplex::forward, dummy4, ang); 00080 //printf("happens at adding function pointer18\n"); 00081 00082 //move_test->addOnceMove(DIVE, b.position, b.angle); 00083 //move_test.addOnceMove(&PreMotorComplex::vturn, NULL, b.angle); 00084 //move_test->addRecursiveMove(&PreMotorComplex::vturn, b.position, b.angle); 00085 00086 test.run(move_test); 00087 //ang.setVal(-35.5); 00088 //c.position.x = 5555; 00089 //c.position.y = 5555; 00090 //c.position.z = 5555; 00091 //test.run(&move_test); 00092 printf("we are done\n"); 00093 00094 00095 return 0; 00096 00097 }