00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036 #include "Component/ModelManager.H"
00037
00038 #include "Media/FrameSeries.H"
00039 #include "Transport/FrameIstream.H"
00040 #include "Media/MediaOpts.H"
00041
00042 #include "Image/Image.H"
00043 #include "Image/Pixels.H"
00044 #include "Raster/Raster.H"
00045 #include "Image/CutPaste.H"
00046
00047 #include "BeoSub/IsolateColor.H"
00048 #include "Image/DrawOps.H"
00049 #include "Image/ColorOps.H"
00050
00051 #include "GUI/XWinManaged.H"
00052
00053 #include "SeaBee/PipeRecognizer.H"
00054 #include "BeoSub/BeoSubBin.H"
00055 #include "SeaBee/BinRecognizer.H"
00056
00057
00058 #include "SeaBee/SubController.H"
00059
00060 #include "SeaBee/SubGUI.H"
00061
00062
00063 #define SIM_MODE true
00064
00065 #define CREATE_MOVIE true
00066
00067 int main(int argc, char* argv[])
00068 {
00069
00070 MYLOGVERB = LOG_INFO;
00071
00072 ModelManager manager("PipeRecognizer Tester");
00073
00074
00075 nub::soft_ref<InputFrameSeries> ifs;
00076 #if SIM_MODE == false
00077 ifs.reset(new InputFrameSeries(manager));
00078 manager.addSubComponent(ifs);
00079 #endif
00080
00081 nub::soft_ref<OutputFrameSeries> ofs(new OutputFrameSeries(manager));
00082 manager.addSubComponent(ofs);
00083
00084
00085 nub::soft_ref<SubGUI> subGUI(new SubGUI(manager));
00086 manager.addSubComponent(subGUI);
00087
00088 nub::soft_ref<SubController> subController(new SubController(manager, "SubController", "SubController", SIM_MODE));
00089 manager.addSubComponent(subController);
00090
00091 manager.exportOptions(MC_RECURSE);
00092
00093
00094 if (manager.parseCommandLine(argc, argv,
00095 "[image {*.ppm}]",
00096 0, 1)
00097 == false) return(1);
00098
00099 int w, h;
00100
00101 #if SIM_MODE == false
00102 w = ifs->getWidth();
00103 h = ifs->getHeight();
00104 #else
00105 w = 320;
00106 h = 240;
00107 #endif
00108
00109 std::string dims = convertToString(Dims(w, h));
00110 LINFO("image size: [%dx%d]", w, h);
00111 manager.setOptionValString(&OPT_InputFrameDims, dims);
00112
00113 manager.setModelParamVal("InputFrameDims", Dims(w, h),
00114 MC_RECURSE | MC_IGNORE_MISSING);
00115
00116 manager.start();
00117
00118 bool goforever = true;
00119
00120 rutz::shared_ptr<XWinManaged> dispWin;
00121 dispWin.reset(new XWinManaged(Dims(w*2,h*2), 0, 0, "Pipe Recognizer Display"));
00122
00123 rutz::shared_ptr<PipeRecognizer> pipeRecognizer(new PipeRecognizer());
00124
00125 rutz::shared_ptr<Point2D<int> > pipeCenter(new Point2D<int>(0,0));
00126
00127 rutz::shared_ptr<BinRecognizer> binRecognizer(new BinRecognizer());
00128 rutz::shared_ptr<Point2D<int> > binCenter(new Point2D<int>(0,0));
00129
00130
00131 Point2D<int> projPoint(Point2D<int>(0,0));
00132
00133
00134 rutz::shared_ptr<double> pipeAngle(new double);
00135
00136
00137
00138 subGUI->startThread(ofs);
00139 subGUI->setupGUI(subController.get(), true);
00140 subGUI->addMeter(subController->getIntPressurePtr(),
00141 "Int Pressure", 500, PixRGB<byte>(255, 0, 0));
00142 subGUI->addMeter(subController->getHeadingPtr(),
00143 "Heading", 360, PixRGB<byte>(192, 255, 0));
00144 subGUI->addMeter(subController->getPitchPtr(),
00145 "Pitch", 256, PixRGB<byte>(192, 255, 0));
00146 subGUI->addMeter(subController->getRollPtr(),
00147 "Roll", 256, PixRGB<byte>(192, 255, 0));
00148 subGUI->addMeter(subController->getDepthPtr(),
00149 "Depth", 300, PixRGB<byte>(192, 255, 0));
00150
00151 subGUI->addMeter(subController->getThruster_Up_Left_Ptr(),
00152 "Motor_Up_Left", -100, PixRGB<byte>(0, 255, 0));
00153 subGUI->addMeter(subController->getThruster_Up_Right_Ptr(),
00154 "Motor_Up_Right", -100, PixRGB<byte>(0, 255, 0));
00155 subGUI->addMeter(subController->getThruster_Up_Back_Ptr(),
00156 "Motor_Up_Back", -100, PixRGB<byte>(0, 255, 0));
00157 subGUI->addMeter(subController->getThruster_Fwd_Left_Ptr(),
00158 "Motor_Fwd_Left", -100, PixRGB<byte>(0, 255, 0));
00159 subGUI->addMeter(subController->getThruster_Fwd_Right_Ptr(),
00160 "Motor_Fwd_Right", -100, PixRGB<byte>(0, 255, 0));
00161
00162
00163 subGUI->addImage(subController->getSubImagePtr());
00164 subGUI->addImage(subController->getPIDImagePtr());
00165
00166
00167
00168 rutz::shared_ptr<Image< PixRGB<byte> > > img;
00169 img.reset(new Image< PixRGB<byte> >(w,h, ZEROS));
00170
00171
00172 rutz::shared_ptr<Image<byte> > orangeIsoImage(new Image<byte>(w,h, ZEROS));
00173 Image< PixRGB<byte> > dispImg(w*2,h*2, ZEROS);
00174
00175 rutz::shared_ptr<Image< PixRGB<byte> > > pipelineOutputImg(new Image<PixRGB<byte> >(w,h, ZEROS));
00176 rutz::shared_ptr<Image< PixRGB<byte> > > outputImg(new Image<PixRGB<byte> >(w,h, ZEROS));
00177
00178
00179
00180 Point2D<int> centerOfMass;
00181 std::vector<Point2D<int> > avgCenter;
00182
00183
00184 #if SIM_MODE == true
00185 uint staleCount = 0;
00186 #endif
00187
00188 while(goforever)
00189 {
00190
00191 orangeIsoImage.reset(new Image<byte>(w,h, ZEROS));
00192 outputImg.reset(new Image<PixRGB<byte> >(w,h, ZEROS));
00193
00194 #if SIM_MODE == false
00195 ifs->updateNext(); *img = ifs->readRGB();
00196 if(!img->initialized()) {Raster::waitForKey(); break; }
00197 #else
00198
00199 *img = subController->getImage(2);
00200 #endif
00201
00202 inplacePaste(dispImg, *img, Point2D<int>(0,0));
00203
00204 orangeIsoImage->resize(w,h);
00205 isolateOrange(*img, *orangeIsoImage);
00206
00207 inplacePaste(dispImg, toRGB(*orangeIsoImage), Point2D<int>(w,0));
00208
00209
00210
00211 std::vector<LineSegment2D> pipelines = pipeRecognizer->getPipeLocation(orangeIsoImage,
00212 pipelineOutputImg,
00213 PipeRecognizer::HOUGH);
00214
00215
00216 #if SIM_MODE == true
00217
00218 binRecognizer->getBinLocation(img,
00219 outputImg,
00220 BinRecognizer::CONTOUR,
00221 binCenter,
00222 staleCount);
00223
00224 drawCircle(*outputImg, *binCenter, 2, PixRGB <byte> (255, 0,0), 3);
00225 #endif
00226 inplacePaste(dispImg, *outputImg, Point2D<int>(w,h));
00227
00228
00229 dispWin->drawImage(dispImg, 0, 0);
00230
00231
00232
00233
00234
00235
00236
00237
00238
00239
00240
00241
00242
00243
00244
00245
00246
00247
00248
00249
00250
00251
00252
00253
00254
00255
00256
00257 int minY = -1;
00258 int followLineIndex = -1;
00259
00260
00261 for(uint i = 0; i < pipelines.size(); i++)
00262 {
00263 LineSegment2D pipeline = pipelines[i];
00264 Point2D<int> midpoint = (pipeline.point1() + pipeline.point2())/2;
00265
00266 if(midpoint.j < minY || minY == -1)
00267 {
00268 minY = midpoint.j;
00269 followLineIndex = i;
00270 }
00271 }
00272
00273
00274 if(followLineIndex != -1)
00275 {
00276
00277 LineSegment2D followLine = pipelines[followLineIndex];
00278 Point2D<int> midpoint = (followLine.point1() + followLine.point2())/2;
00279
00280 projPoint.i = (int)(midpoint.i+30*cos(followLine.angle()));
00281 projPoint.j = (int)(midpoint.j+30*sin(followLine.angle()));
00282
00283 drawLine(*pipelineOutputImg, midpoint, projPoint, PixRGB <byte> (255, 255,0), 3);
00284
00285
00286 inplacePaste(dispImg, *pipelineOutputImg, Point2D<int>(0,h));
00287
00288
00289 int desiredHeading = ((int)((followLine.angle()) * 180 / M_PI));
00290
00291 if(desiredHeading > 360) desiredHeading = desiredHeading - 360;
00292 if(desiredHeading < 0) desiredHeading = desiredHeading + 360;
00293
00294 int absHeading = (subController->getHeading() + desiredHeading) % 360;
00295 subController->setHeading(absHeading);
00296
00297
00298 if(!((desiredHeading >= 270 && desiredHeading <= 275) || (desiredHeading <= 90 && desiredHeading >= 85)))
00299 {
00300 usleep(100000);
00301 }
00302 else
00303 {
00304 subController->setHeading(subController->getHeading());
00305 subController->setSpeed(75);
00306 }
00307
00308 }
00309 else
00310 {
00311 subController->setHeading(subController->getHeading());
00312 }
00313 }
00314
00315
00316 manager.stop();
00317 return 0;
00318 }
00319
00320
00321
00322
00323
00324