ivdecision_brain.cpp 115 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903
  1. #include "ivdecision_brain.h"
  2. #include "common/obs_predict.h"
  3. #include "ivlog.h"
  4. extern iv::Ivlog * givlog;
  5. bool handPark;
  6. long handParkTime;
  7. bool rapidStop;
  8. int gpsMissCount;
  9. bool changeRoad;
  10. double avoidX;
  11. bool parkBesideRoad;
  12. double steerSpeed;
  13. bool transferPieriod;
  14. bool transferPieriod2;
  15. double traceDevi;
  16. using namespace iv::decition;
  17. namespace iv {
  18. ivdecision_brain::ivdecision_brain()
  19. {
  20. mvehState = VehState::normalRun;
  21. }
  22. int ivdecision_brain::getdecision(brain::decition &xdecition)
  23. {
  24. static qint64 nLastMapUpdate = 0;
  25. iv::GPSData now_gps_ins;
  26. if(GetGPS(now_gps_ins) == false)
  27. {
  28. return -1; //No GPS Position
  29. }
  30. if(IsMAPUpdate(nLastMapUpdate))
  31. {
  32. GetMAP(mgpsMapLine,nLastMapUpdate);
  33. mbisFirstRun = true;
  34. }
  35. iv::LidarGridPtr lidarptr;
  36. GetLIDARGrid(lidarptr);
  37. std::vector<iv::Perception::PerceptionOutput> xvectorper;
  38. iv::TrafficLight xtrafficlight;
  39. std::shared_ptr<iv::vbox::vbox> xvbox_ptr;
  40. if(Getvboxmsg(xvbox_ptr))
  41. {
  42. xtrafficlight.leftColor=xvbox_ptr->st_left();
  43. xtrafficlight.rightColor=xvbox_ptr->st_right();
  44. xtrafficlight.straightColor=xvbox_ptr->st_straight();
  45. xtrafficlight.uturnColor=xvbox_ptr->st_turn();
  46. xtrafficlight.leftTime=xvbox_ptr->time_left();
  47. xtrafficlight.rightTime=xvbox_ptr->time_right();
  48. xtrafficlight.straightTime=xvbox_ptr->time_straight();
  49. xtrafficlight.uturnTime=xvbox_ptr->time_turn();
  50. }
  51. updatev2x();
  52. updateultra();
  53. updateradar();
  54. iv::decition::Decition decition= getDecideFromGPS(*now_gps_ins,mgpsMapLine,lidarptr,xvectorper,xtrafficlight);
  55. xdecition.set_accelerator(decition->accelerator);
  56. xdecition.set_brake(decition->brake);
  57. xdecition.set_leftlamp(decition->leftlamp);
  58. xdecition.set_rightlamp(decition->rightlamp);
  59. xdecition.set_speed(decition->speed);
  60. xdecition.set_wheelangle(decition->wheel_angle);
  61. xdecition.set_wheelspeed(decition->angSpeed);
  62. xdecition.set_torque(decition->torque);
  63. xdecition.set_mode(decition->mode);
  64. xdecition.set_gear(decition->dangWei);
  65. xdecition.set_handbrake(decition->handBrake);
  66. xdecition.set_grade(decition->grade);
  67. xdecition.set_engine(decition->engine);
  68. xdecition.set_brakelamp(decition->brakeLight);
  69. xdecition.set_ttc(ServiceCarStatus.mfttc);
  70. xdecition.set_air_enable(decition->air_enable);
  71. xdecition.set_air_temp(decition->air_temp);
  72. xdecition.set_air_mode(decition->air_mode);
  73. xdecition.set_wind_level(decition->wind_level);
  74. xdecition.set_roof_light(decition->roof_light);
  75. xdecition.set_home_light(decition->home_light);
  76. xdecition.set_air_worktime(decition->air_worktime);
  77. xdecition.set_air_offtime(decition->air_offtime);
  78. xdecition.set_air_on(decition->air_on);
  79. xdecition.set_door(decition->door);
  80. return 0;
  81. }
  82. void ivdecision_brain::updatev2x()
  83. {
  84. std::shared_ptr<iv::v2x::v2x> xv2x_ptr;
  85. if(false == Getv2xmsg(xv2x_ptr))
  86. {
  87. return;
  88. }
  89. ServiceCarStatus.stationCmd.received=true;
  90. ServiceCarStatus.stationCmd.has_carID=xv2x_ptr->has_carid();
  91. if(ServiceCarStatus.stationCmd.has_carID)
  92. {
  93. ServiceCarStatus.stationCmd.carID=xv2x_ptr->carid();
  94. }
  95. ServiceCarStatus.stationCmd.has_carMode=xv2x_ptr->has_carmode();
  96. if(ServiceCarStatus.stationCmd.has_carMode)
  97. {
  98. ServiceCarStatus.stationCmd.carMode=xv2x_ptr->carmode();
  99. qDebug("ServiceCarStatus.stationCmd.carMode:",ServiceCarStatus.stationCmd.carMode);
  100. givlog->debug("brain_v2x","ServiceCarStatus.stationCmd.carMode:%d",ServiceCarStatus.stationCmd.carMode);
  101. }
  102. ServiceCarStatus.stationCmd.has_emergencyStop=xv2x_ptr->has_emergencystop();
  103. if(ServiceCarStatus.stationCmd.has_emergencyStop)
  104. {
  105. ServiceCarStatus.stationCmd.emergencyStop=xv2x_ptr->emergencystop();
  106. qDebug("ServiceCarStatus.stationCmd.emergencyStop:",ServiceCarStatus.stationCmd.emergencyStop);
  107. givlog->debug("brain_v2x","ServiceCarStatus.stationCmd.emergencyStop:%d",ServiceCarStatus.stationCmd.emergencyStop);
  108. }
  109. ServiceCarStatus.stationCmd.has_stationStop=xv2x_ptr->has_stationstop();
  110. if(ServiceCarStatus.stationCmd.has_stationStop)
  111. {
  112. ServiceCarStatus.stationCmd.stationStop=xv2x_ptr->stationstop();
  113. qDebug("ServiceCarStatus.stationCmd.stationStop:",ServiceCarStatus.stationCmd.stationStop);
  114. givlog->debug("brain_v2x","ServiceCarStatus.stationCmd.stationStop:%d",ServiceCarStatus.stationCmd.stationStop);
  115. }
  116. int num=xv2x_ptr->stationid_size();
  117. if(num>0)
  118. {
  119. ServiceCarStatus.stationCmd.stationTotalNum=num;
  120. for(int i=0;i<ServiceCarStatus.stationCmd.stationTotalNum;i++)
  121. {
  122. ServiceCarStatus.stationCmd.stationGps[i].gps_lat=xv2x_ptr->stgps(i).lat();
  123. ServiceCarStatus.stationCmd.stationGps[i].gps_lng=xv2x_ptr->stgps(i).lon();
  124. qDebug("stationGps: %d, lat: %.7f, lon: %.7f", xv2x_ptr->stationid(i), ServiceCarStatus.stationCmd.stationGps[i].gps_lat, ServiceCarStatus.stationCmd.stationGps[i].gps_lng);
  125. givlog->debug("brain_v2x","stationGps: %d, lat: %.7f, lon: %.7f",
  126. xv2x_ptr->stationid(i),ServiceCarStatus.stationCmd.stationGps[i].gps_lat,
  127. ServiceCarStatus.stationCmd.stationGps[i].gps_lng);
  128. }
  129. ServiceCarStatus.mbRunPause=false;
  130. }
  131. }
  132. void ivdecision_brain::updateultra()
  133. {
  134. std::shared_ptr<iv::ultrasonic::ultrasonic> xultra_ptr;
  135. if(false == Getultrasonic(xultra_ptr))
  136. {
  137. return;
  138. }
  139. ServiceCarStatus.ultraDistance[1]=xultra_ptr->sigobjdist_flcorner();
  140. ServiceCarStatus.ultraDistance[2]=xultra_ptr->sigobjdist_flmiddle();
  141. ServiceCarStatus.ultraDistance[3]=xultra_ptr->sigobjdist_flside();
  142. ServiceCarStatus.ultraDistance[4]=xultra_ptr->sigobjdist_frcorner();
  143. ServiceCarStatus.ultraDistance[5]=xultra_ptr->sigobjdist_frmiddle();
  144. ServiceCarStatus.ultraDistance[6]=xultra_ptr->sigobjdist_frside();
  145. ServiceCarStatus.ultraDistance[7]=xultra_ptr->sigobjdist_rlcorner();
  146. ServiceCarStatus.ultraDistance[8]=xultra_ptr->sigobjdist_rlmiddle();
  147. ServiceCarStatus.ultraDistance[9]=xultra_ptr->sigobjdist_rlside();
  148. ServiceCarStatus.ultraDistance[10]=xultra_ptr->sigobjdist_rrcorner();
  149. ServiceCarStatus.ultraDistance[11]=xultra_ptr->sigobjdist_rrmiddle();
  150. ServiceCarStatus.ultraDistance[12]=xultra_ptr->sigobjdist_rrside();
  151. }
  152. void ivdecision_brain::updateradar()
  153. {
  154. std::shared_ptr<iv::radar::radarobjectarray> xradar_ptr
  155. = std::shared_ptr<iv::radar::radarobjectarray>(new iv::radar::radarobjectarray);
  156. unsigned int i;
  157. if(false == GetRADAR(xradar_ptr))
  158. {
  159. for(i=0;i<64;i++)
  160. {
  161. ServiceCarStatus.obs_radar[i].valid = false;
  162. }
  163. return;
  164. }
  165. for(i=0;i<64;i++)
  166. {
  167. iv::radar::radarobject * pradarobj = xradar_ptr->mutable_obj(i);
  168. ServiceCarStatus.obs_radar[i].valid = pradarobj->bvalid();
  169. ServiceCarStatus.obs_radar[i].nomal_x = pradarobj->x();
  170. ServiceCarStatus.obs_radar[i].nomal_y = pradarobj->y();
  171. ServiceCarStatus.obs_radar[i].speed_relative = pradarobj->vel();
  172. ServiceCarStatus.obs_radar[i].speed_x = pradarobj->vx();
  173. ServiceCarStatus.obs_radar[i].speed_y = pradarobj->vy();
  174. }
  175. }
  176. //int ivdecision_brain::getdecision_normal(brain::decition &xdecition)
  177. //{
  178. // iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  179. // double obsDistance = -1;
  180. // int esrLineIndex = -1;
  181. // double lidarDistance = -1;
  182. // int roadPre = -1;
  183. // return 0;
  184. //}
  185. //std::vector<iv::Perception::PerceptionOutput> lidar_per,
  186. iv::decition::Decition ivdecision_brain::decision_reverseCar(GPS_INS now_gps_ins)
  187. {
  188. iv::decition::Compute00().bocheCompute(now_gps_ins, aim_gps_ins);
  189. vehState = reversing;
  190. qiedianCount=true;
  191. return decision_reversing(now_gps_ins);
  192. }
  193. iv::decition::Decition ivdecision_brain::decision_reversing(GPS_INS now_gps_ins)
  194. {
  195. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  196. double dis = GetDistance(now_gps_ins, iv::decition::Compute00().nearTpoint);
  197. if (dis<2.0)//0.5
  198. {
  199. vehState = reverseCircle;
  200. qiedianCount = true;
  201. cout<<"到达近切点+++++++++++++++++++++++++++++++++"<<endl;
  202. return decision_reverseCircle(now_gps_ins);
  203. }
  204. else {
  205. controlAng = 0;
  206. dSpeed = 2;
  207. dSecSpeed = dSpeed / 3.6;
  208. gps_decition->wheel_angle = 0;
  209. gps_decition->speed = dSpeed;
  210. obsDistance=-1;
  211. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  212. // gps_decition->accelerator = 0;
  213. return gps_decition;
  214. }
  215. }
  216. iv::decition::Decition ivdecision_brain::decision_reverseCircle(GPS_INS now_gps_ins)
  217. {
  218. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  219. double dis = GetDistance(now_gps_ins, iv::decition::Compute00().farTpoint);
  220. double angdis =abs(now_gps_ins.ins_heading_angle - aim_gps_ins.ins_heading_angle);
  221. if((((angdis<5)||(angdis>355)))&&(dis<3.0))
  222. // if((((angdis<4)||(angdis>356)))&&(dis<2.0))
  223. {
  224. vehState = reverseDirect;
  225. qiedianCount = true;
  226. cout<<"到达远切点+++++++++++++++++++++++++++++++++"<<endl;
  227. return decision_reverseDirect(now_gps_ins);
  228. }
  229. else {
  230. if (qiedianCount && trumpet()<0)
  231. // if (qiedianCount && trumpet()<1500)
  232. {
  233. // gps_decition->brake = 10;
  234. // gps_decition->torque = 0;
  235. dSpeed=0;
  236. minDecelerate=min(minDecelerate,-0.5f);
  237. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  238. }
  239. else
  240. {
  241. qiedianCount = false;
  242. trumpetFirstCount = true;
  243. dSpeed = 2;
  244. dSecSpeed = dSpeed / 3.6;
  245. gps_decition->speed = dSpeed;
  246. obsDistance=-1;
  247. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  248. }
  249. controlAng = iv::decition::Compute00().bocheAngle*16.5;
  250. gps_decition->wheel_angle = 0 - controlAng*1.05;
  251. cout<<"farTpointDistance================"<<dis<<endl;
  252. return gps_decition;
  253. }
  254. }
  255. iv::decition::Decition ivdecision_brain::decision_reverseDirect(GPS_INS now_gps_ins)
  256. {
  257. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  258. Point2D pt = Coordinate_Transfer(now_gps_ins.gps_x,now_gps_ins.gps_y, aim_gps_ins);
  259. if ((pt.y)<0.5)
  260. {
  261. qiedianCount=true;
  262. vehState=reverseArr;
  263. cout<<"到达泊车点+++++++++++++++++++++++++++++++++"<<endl;
  264. // gps_decition->accelerator = -3;
  265. // gps_decition->brake = 10;
  266. // gps_decition->torque = 0;
  267. gps_decition->wheel_angle=0;
  268. dSpeed=0;
  269. minDecelerate=min(minDecelerate,-0.5f);
  270. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  271. return gps_decition;
  272. }
  273. else {
  274. //if (qiedianCount && trumpet()<0)
  275. if (qiedianCount && trumpet()<1000)
  276. {
  277. // gps_decition->brake = 10;
  278. // gps_decition->torque = 0;
  279. dSpeed=0;
  280. minDecelerate=min(minDecelerate,-0.5f);
  281. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  282. }
  283. else
  284. {
  285. qiedianCount = false;
  286. trumpetFirstCount = true;
  287. dSpeed = 1;
  288. dSecSpeed = dSpeed / 3.6;
  289. gps_decition->speed = dSpeed;
  290. obsDistance=-1;
  291. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  292. }
  293. controlAng = 0;
  294. gps_decition->wheel_angle = 0;
  295. return gps_decition;
  296. }
  297. }
  298. iv::decition::Decition ivdecision_brain::decision_reverseArr(iv::GPS_INS now_gps_ins)
  299. {
  300. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  301. ServiceCarStatus.bocheMode=false;
  302. if (qiedianCount && trumpet()<1500)
  303. {
  304. // gps_decition->brake = 10;
  305. // gps_decition->torque = 0;
  306. dSpeed=0;
  307. minDecelerate=min(minDecelerate,-0.5f);
  308. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  309. ServiceCarStatus.bocheMode=false;
  310. }
  311. else
  312. {
  313. qiedianCount = false;
  314. trumpetFirstCount = true;
  315. ServiceCarStatus.bocheEnable=0;
  316. vehState=normalRun;
  317. ServiceCarStatus.mbRunPause=true;
  318. ServiceCarStatus.mnBocheComplete=100;
  319. cout<<"泊车daowei mbRunPause+++++++++++++++++++++++++++++++++"<<endl;
  320. }
  321. gps_decition->wheel_angle = 0 ;
  322. return gps_decition;
  323. }
  324. iv::decition::Decition ivdecision_brain::decision_dRever(GPS_INS now_gps_ins)
  325. {
  326. GaussProjCal(aim_gps_ins.gps_lng, aim_gps_ins.gps_lat, &aim_gps_ins.gps_x, &aim_gps_ins.gps_y);
  327. iv::decition::Compute00().bocheDirectCompute(now_gps_ins, aim_gps_ins);
  328. vehState = dRever0;
  329. qiedianCount=true;
  330. std::cout<<"enter side boche mode"<<std::endl;
  331. return decision_dRever0(now_gps_ins);
  332. }
  333. iv::decition::Decition ivdecision_brain::decision_dRever0(GPS_INS now_gps_ins)
  334. {
  335. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  336. double dis = GetDistance(now_gps_ins, iv::decition::Compute00().dTpoint0);
  337. if (dis<2.0)
  338. {
  339. vehState = dRever1;
  340. qiedianCount = true;
  341. cout<<"到达近切点+++++++++++++++++++++++++++++++++"<<endl;
  342. return decision_dRever1(now_gps_ins);
  343. }
  344. else {
  345. controlAng = 0;
  346. dSpeed = 2;
  347. dSecSpeed = dSpeed / 3.6;
  348. gps_decition->wheel_angle = 0;
  349. gps_decition->speed = dSpeed;
  350. obsDistance=-1;
  351. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  352. // gps_decition->accelerator = 0;
  353. return gps_decition;
  354. }
  355. }
  356. iv::decition::Decition ivdecision_brain::decision_dRever1(GPS_INS now_gps_ins)
  357. {
  358. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  359. double dis = GetDistance(now_gps_ins, iv::decition::Compute00().dTpoint1);
  360. if(dis<2.0)
  361. {
  362. vehState = dRever2;
  363. qiedianCount = true;
  364. cout<<"到达远切点+++++++++++++++++++++++++++++++++"<<endl;
  365. return decision_dRever2(now_gps_ins);
  366. }
  367. else {
  368. if (qiedianCount && trumpet()<1000)
  369. {
  370. // gps_decition->brake = 10;
  371. // gps_decition->torque = 0;
  372. dSpeed=0;
  373. minDecelerate=min(minDecelerate,-0.5f);
  374. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  375. }
  376. else
  377. {
  378. qiedianCount = false;
  379. trumpetFirstCount = true;
  380. dSpeed = 2;
  381. dSecSpeed = dSpeed / 3.6;
  382. gps_decition->speed = dSpeed;
  383. obsDistance=-1;
  384. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  385. }
  386. controlAng = iv::decition::Compute00().dBocheAngle*16.5;
  387. gps_decition->wheel_angle = 0 - controlAng;
  388. cout<<"farTpointDistance================"<<dis<<endl;
  389. return gps_decition;
  390. }
  391. }
  392. iv::decition::Decition ivdecision_brain::decision_dRever2(GPS_INS now_gps_ins)
  393. {
  394. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  395. double dis = GetDistance(now_gps_ins, iv::decition::Compute00().dTpoint2);
  396. Point2D pt1 = Coordinate_Transfer(now_gps_ins.gps_x,now_gps_ins.gps_y, aim_gps_ins);
  397. Point2D pt2 = Coordinate_Transfer(iv::decition::Compute00().dTpoint2.gps_x,iv::decition::Compute00().dTpoint2.gps_y, aim_gps_ins);
  398. double xx= (pt1.x-pt2.x);
  399. // if(xx>0)
  400. if(xx>-0.5)
  401. {
  402. GaussProjCal(aim_gps_ins.gps_lng, aim_gps_ins.gps_lat, &aim_gps_ins.gps_x, &aim_gps_ins.gps_y);
  403. Point2D ptt = Coordinate_Transfer(now_gps_ins.gps_x,now_gps_ins.gps_y, aim_gps_ins);
  404. double xxx=ptt.x;
  405. double yyy =ptt.y;
  406. // if(xxx<-1.5||xx>1){
  407. // int a=0;
  408. // }
  409. vehState = dRever3;
  410. qiedianCount = true;
  411. cout<<"到达远切点+++++++++++++++++++++++++++++++++"<<endl;
  412. cout<<"xxx+++++++++++++++++++++++++++++++++"<<xxx<<endl;
  413. cout<<"yyy+++++++++++++++++++++++++++++++++"<<yyy<<endl;
  414. return decision_dRever3(now_gps_ins);
  415. }
  416. else {
  417. if (qiedianCount && trumpet()<1000)
  418. {
  419. /* gps_decition->brake = 10;
  420. gps_decition->torque = 0; */
  421. dSpeed=0;
  422. minDecelerate=min(minDecelerate,-0.5f);
  423. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  424. }
  425. else
  426. {
  427. qiedianCount = false;
  428. trumpetFirstCount = true;
  429. dSpeed = 2;
  430. dSecSpeed = dSpeed / 3.6;
  431. gps_decition->speed = dSpeed;
  432. obsDistance=-1;
  433. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  434. }
  435. gps_decition->wheel_angle = 0 ;
  436. cout<<"farTpointDistance================"<<dis<<endl;
  437. return gps_decition;
  438. }
  439. }
  440. iv::decition::Decition ivdecision_brain::decision_dRever3(GPS_INS now_gps_ins)
  441. {
  442. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  443. double dis = GetDistance(now_gps_ins, iv::decition::Compute00().dTpoint3);
  444. double angdis =abs(now_gps_ins.ins_heading_angle - aim_gps_ins.ins_heading_angle);
  445. if((((angdis<5)||(angdis>355)))&&(dis<10.0))
  446. {
  447. vehState = dRever4;
  448. qiedianCount = true;
  449. cout<<"到达远切点+++++++++++++++++++++++++++++++++"<<endl;
  450. return decision_dRever4(now_gps_ins);
  451. }
  452. else {
  453. if (qiedianCount && trumpet()<1000)
  454. {
  455. // gps_decition->brake = 10;
  456. // gps_decition->torque = 0;
  457. dSpeed=0;
  458. minDecelerate=min(minDecelerate,-0.5f);
  459. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  460. }
  461. else
  462. {
  463. qiedianCount = false;
  464. trumpetFirstCount = true;
  465. dSpeed = 2;
  466. dSecSpeed = dSpeed / 3.6;
  467. gps_decition->speed = dSpeed;
  468. obsDistance=-1;
  469. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  470. }
  471. controlAng = 0-iv::decition::Compute00().dBocheAngle*16.5;
  472. gps_decition->wheel_angle = 0 - controlAng*0.95;
  473. cout<<"farTpointDistance================"<<dis<<endl;
  474. return gps_decition;
  475. }
  476. }
  477. iv::decition::Decition ivdecision_brain::decision_dRever4(GPS_INS now_gps_ins)
  478. {
  479. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  480. // double dis = GetDistance(now_gps_ins, aim_gps_ins);
  481. Point2D pt = Coordinate_Transfer(now_gps_ins.gps_x,now_gps_ins.gps_y, aim_gps_ins);
  482. if ((pt.y)<0.5)
  483. {
  484. qiedianCount=true;
  485. vehState=reverseArr;
  486. cout<<"到达泊车点+++++++++++++++++++++++++++++++++"<<endl;
  487. // gps_decition->accelerator = -3;
  488. // gps_decition->brake =10 ;
  489. dSpeed=0;
  490. minDecelerate=min(minDecelerate,-0.5f);
  491. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  492. gps_decition->wheel_angle=0;
  493. return gps_decition;
  494. }
  495. else {
  496. //if (qiedianCount && trumpet()<0)
  497. if (qiedianCount && trumpet()<1000)
  498. {
  499. // gps_decition->brake = 10;
  500. // gps_decition->torque = 0;
  501. dSpeed=0;
  502. minDecelerate=min(minDecelerate,-0.5f);
  503. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  504. }
  505. else
  506. {
  507. qiedianCount = false;
  508. trumpetFirstCount = true;
  509. dSpeed = 2;
  510. dSecSpeed = dSpeed / 3.6;
  511. gps_decition->speed = dSpeed;
  512. obsDistance=-1;
  513. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  514. }
  515. controlAng = 0;
  516. gps_decition->wheel_angle = 0;
  517. return gps_decition;
  518. }
  519. }
  520. void ivdecision_brain::decision_firstRun(GPS_INS now_gps_ins,
  521. const std::vector<GPSData> & gpsMapLine)
  522. {
  523. if (isFirstRun)
  524. {
  525. initMethods();
  526. vehState = normalRun;
  527. startAvoid_gps_ins = now_gps_ins;
  528. init();
  529. PathPoint = iv::decition::Compute00().getFirstNearestPointIndex(now_gps_ins, gpsMapLine,
  530. lastGpsIndex,
  531. minDis,
  532. maxAngle);
  533. lastGpsIndex = PathPoint;
  534. if(ServiceCarStatus.speed_control==true){
  535. iv::decition::Compute00().getDesiredSpeed(gpsMapLine); //add by zj
  536. }
  537. // ServiceCarStatus.carState = 1;
  538. // roadOri = gpsMapLine[PathPoint]->roadOri;
  539. // roadNow = roadOri;
  540. // roadSum = gpsMapLine[PathPoint]->roadSum;
  541. // busMode = false;
  542. // vehState = dRever;
  543. double dis = iv::decition::GetDistance(*gpsMapLine[0], *gpsMapLine[gpsMapLine.size()-1]);
  544. if(dis<15){
  545. circleMode=true; //201200102
  546. }else{
  547. circleMode=false;
  548. }
  549. // circleMode = true;
  550. getV2XTrafficPositionVector(gpsMapLine);
  551. // group_ori_gps=*gpsMapLine[0];
  552. ServiceCarStatus.bocheMode=false;
  553. ServiceCarStatus.daocheMode=false;
  554. parkMode=false;
  555. readyParkMode=false;
  556. finishPointNum=-1;
  557. isFirstRun = false;
  558. }
  559. }
  560. int ivdecision_brain::decision_ParkCalc(GPS_INS now_gps_ins,iv::decition::Decition & gps_decition)
  561. {
  562. //sidePark
  563. if(ServiceCarStatus.mnParkType==1){
  564. if( vehState!=dRever && vehState!=dRever0 && vehState!=dRever1 && vehState!=dRever2 && vehState!=dRever3 && vehState!=dRever4 && vehState!=reverseArr ){
  565. int bocheEN=iv::decition::Compute00().bocheDirectCompute(now_gps_ins, aim_gps_ins);
  566. if(bocheEN==1){
  567. ServiceCarStatus.bocheEnable=1;
  568. }else if(bocheEN==0){
  569. ServiceCarStatus.bocheEnable=0;
  570. }
  571. }else{
  572. ServiceCarStatus.bocheEnable=2;
  573. }
  574. if(ServiceCarStatus.bocheMode && vehState!=dRever && vehState!=dRever0 && vehState!=dRever1 &&
  575. vehState!=dRever2 && vehState!=dRever3 && vehState!=dRever4&& vehState!=reverseArr ){
  576. if(abs(realspeed)>0.1){
  577. dSpeed=0;
  578. minDecelerate=min(minDecelerate,-0.5f);
  579. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  580. gps_decition->wheel_angle=0;
  581. return 1;
  582. }else{
  583. if(trumpet()>3000){
  584. trumpetFirstCount=true;
  585. vehState=dRever;
  586. }
  587. }
  588. // ServiceCarStatus.bocheMode=false;
  589. }
  590. }
  591. //chuizhiPark
  592. if(ServiceCarStatus.mnParkType==0){
  593. if( vehState!=reverseCar && vehState!=reversing && vehState!=reverseCircle && vehState!=reverseDirect && vehState!=reverseArr ){
  594. int bocheEN=iv::decition::Compute00().bocheCompute(now_gps_ins, aim_gps_ins);
  595. if(bocheEN==1){
  596. ServiceCarStatus.bocheEnable=1;
  597. }else if(bocheEN==0){
  598. ServiceCarStatus.bocheEnable=0;
  599. }
  600. }else{
  601. ServiceCarStatus.bocheEnable=2;
  602. }
  603. if(ServiceCarStatus.bocheMode && vehState!=reverseCar && vehState!=reversing && vehState!=reverseCircle && vehState!=reverseDirect&& vehState!=reverseArr ){
  604. if(abs(realspeed)>0.1){
  605. dSpeed=0;
  606. minDecelerate=min(minDecelerate,-0.5f);
  607. phaseSpeedDecition(gps_decition, secSpeed, -1, 0, now_gps_ins);
  608. gps_decition->wheel_angle=0;
  609. return 1;
  610. }else{
  611. if(trumpet()>3000){
  612. trumpetFirstCount=true;
  613. vehState=reverseCar;
  614. }
  615. }
  616. // ServiceCarStatus.bocheMode=false;
  617. }
  618. }
  619. return 0;
  620. }
  621. void ivdecision_brain::decision_readyZhucheMode(GPS_INS now_gps_ins, const std::vector<GPSData> &gpsMapLine)
  622. {
  623. cout<<"ready ZHECHE STATE+++++++++++++++++++++++++++++++++"<<endl;
  624. cout<<"zhuche point : "<<zhuchePointNum<<endl;
  625. double dis = GetDistance(*gpsMapLine[zhuchePointNum], now_gps_ins);
  626. if (dis<35)
  627. {
  628. Point2D pt = Coordinate_Transfer((*gpsMapLine[zhuchePointNum]).gps_x, (*gpsMapLine[zhuchePointNum]).gps_y, now_gps_ins);
  629. double zhucheDistance = pt.y;
  630. #if 0
  631. if (dSpeed > 15)
  632. {
  633. dSpeed = 15;
  634. }
  635. if (zhucheDistance < 20 && dis < 25)
  636. {
  637. dSpeed = min(dSpeed, 5.0);
  638. }
  639. #else
  640. if (dSpeed > 12)
  641. {
  642. dSpeed = 12;
  643. }
  644. if (zhucheDistance < 9 && dis < 9)
  645. {
  646. dSpeed = min(dSpeed, 5.0);
  647. }
  648. #endif
  649. if (zhucheDistance < 3.0 && dis < 3.5)
  650. {
  651. dSpeed = min(dSpeed, 5.0);
  652. zhucheMode = true;
  653. readyZhucheMode = false;
  654. cout<<"jinru ZHECHE STATE+++++++++++++++++++++++++++++++++"<<endl;
  655. //1125
  656. // gps_decition->brake=20;
  657. // gps_decition->accelerator = -3;
  658. // gps_decition->wheel_angle = 0-controlAng;
  659. // gps_decition->speed = 0;
  660. // gps_decition->torque=0;
  661. // return gps_decition;
  662. }
  663. }
  664. }
  665. void ivdecision_brain::decision_readyParkMode(GPS_INS now_gps_ins, const std::vector<GPSData> &gpsMapLine)
  666. {
  667. double parkDis = GetDistance(now_gps_ins, *gpsMapLine[finishPointNum]);
  668. hasZhuched = true;
  669. if (parkDis < 25)
  670. {
  671. Point2D pt = Coordinate_Transfer((*gpsMapLine[finishPointNum]).gps_x, (*gpsMapLine[finishPointNum]).gps_y, now_gps_ins);
  672. double parkDistance = pt.y;
  673. if (dSpeed > 15)
  674. {
  675. dSpeed = 15;
  676. }
  677. //dSpeed = 15;//////////////////////////////
  678. if (parkDistance < 15 && parkDistance >= 12.5 && parkDis<20)
  679. {
  680. dSpeed = min(dSpeed, 8.0);
  681. }else if (parkDistance < 12.5 && parkDistance >= 8.5 && parkDis<15.0){
  682. dSpeed = min(dSpeed, 5.0);
  683. }else if (parkDistance < 8.5 && parkDistance >= 5.5 && parkDis<9.0){
  684. dSpeed = min(dSpeed, 3.0);
  685. }else if(parkDistance < 5.5 && parkDis<6.0){
  686. dSpeed = min(dSpeed, 1.0);
  687. }
  688. // float stopDis=2;
  689. // if(ServiceCarStatus.msysparam.mvehtype=="ge3"){
  690. // stopDis=1.6;
  691. // } else if(ServiceCarStatus.msysparam.mvehtype=="vv7"){
  692. // stopDis=1.8;
  693. // }
  694. if (parkDistance < 1.6 && parkDis<2.0)
  695. {
  696. // dSpeed = 0;
  697. parkMode = true;
  698. readyParkMode = false;
  699. }
  700. }
  701. }
  702. void ivdecision_brain::decision_speedctrl(Decition &gps_decition,const std::vector<GPSData> & gpsMapLine)
  703. {
  704. if (gpsMapLine[PathPoint]->roadMode ==0)
  705. {
  706. //dSpeed = min(10.0,dSpeed);
  707. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode0,dSpeed);
  708. gps_decition->leftlamp = false;
  709. gps_decition->rightlamp = false;
  710. }else if (gpsMapLine[PathPoint]->roadMode == 5)
  711. {
  712. //dSpeed = min(8.0,dSpeed);
  713. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode5,dSpeed);
  714. gps_decition->leftlamp = false;
  715. gps_decition->rightlamp = false;
  716. }else if (gpsMapLine[PathPoint]->roadMode == 11)
  717. {
  718. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode11,dSpeed);
  719. gps_decition->leftlamp = false;
  720. gps_decition->rightlamp = false;
  721. }else if (gpsMapLine[PathPoint]->roadMode == 14)
  722. {
  723. //dSpeed = min(8.0,dSpeed);
  724. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode14,dSpeed);
  725. gps_decition->leftlamp = true;
  726. gps_decition->rightlamp = false;
  727. }else if (gpsMapLine[PathPoint]->roadMode == 15)
  728. {
  729. //dSpeed = min(8.0,dSpeed);
  730. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode15,dSpeed);
  731. gps_decition->leftlamp = false;
  732. gps_decition->rightlamp = true;
  733. }else if (gpsMapLine[PathPoint]->roadMode == 16)
  734. {
  735. // dSpeed = min(10.0,dSpeed);
  736. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode16,dSpeed);
  737. //gps_decition->leftlamp = true;
  738. //gps_decition->rightlamp = false;
  739. }else if (gpsMapLine[PathPoint]->roadMode == 17)
  740. {
  741. // dSpeed = min(10.0,dSpeed);
  742. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode17,dSpeed);
  743. //gps_decition->leftlamp = false;
  744. //gps_decition->rightlamp = true;
  745. }else if (gpsMapLine[PathPoint]->roadMode == 18)
  746. {
  747. // dSpeed = min(10.0,dSpeed);
  748. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode18,dSpeed);
  749. gps_decition->leftlamp = false;
  750. gps_decition->rightlamp = false;
  751. /*if(gpsMapLine[PathPoint]->light_left_or_right == 1)
  752. {
  753. gps_decition->leftlamp = true;
  754. gps_decition->rightlamp = false;
  755. }
  756. else if(gpsMapLine[PathPoint]->light_left_or_right == 2)
  757. {
  758. gps_decition->leftlamp = false;
  759. gps_decition->rightlamp = true;
  760. }*/
  761. }else if (gpsMapLine[PathPoint]->roadMode == 1)
  762. {
  763. dSpeed = min(10.0,dSpeed);
  764. }else if (gpsMapLine[PathPoint]->roadMode == 2)
  765. {
  766. dSpeed = min(15.0,dSpeed);
  767. }
  768. else if (gpsMapLine[PathPoint]->roadMode == 7)
  769. {
  770. dSpeed = min(15.0,dSpeed);
  771. xiuzhengCs=1.5;
  772. }else if (gpsMapLine[PathPoint]->roadMode == 4) //1220
  773. {
  774. dSpeed = min(4.0,dSpeed);
  775. }else{
  776. dSpeed = min(ServiceCarStatus.mroadmode_vel.mfmode0,dSpeed);
  777. gps_decition->leftlamp = false;
  778. gps_decition->rightlamp = false;
  779. }
  780. if (gpsMapLine[PathPoint]->speed_mode == 2)
  781. {
  782. dSpeed = min(25.0,dSpeed);
  783. }
  784. if((gpsMapLine[PathPoint]->speed)>0.001)
  785. {
  786. dSpeed = min((gpsMapLine[PathPoint]->speed*3.6),dSpeed);
  787. }
  788. dSecSpeed = dSpeed / 3.6;
  789. std::cout<<"juecesudu2="<<dSpeed<<std::endl;
  790. }
  791. //std::vector<iv::Perception::PerceptionOutput> lidar_per,
  792. iv::decition::Decition ivdecision_brain::getDecideFromGPS(GPS_INS now_gps_ins,
  793. const std::vector<GPSData> gpsMapLine,
  794. iv::LidarGridPtr lidarGridPtr,
  795. std::vector<iv::Perception::PerceptionOutput> lidar_per,
  796. iv::TrafficLight trafficLight)
  797. {
  798. iv::decition::Decition gps_decition(new iv::decition::DecitionBasic);
  799. //如果useFrenet、useOldAvoid两者不互为相异,则采用原来的方法。“^”为异或运算符。
  800. if(!(useFrenet^useOldAvoid)){
  801. useFrenet = false;
  802. useOldAvoid = true;
  803. }
  804. if (isFirstRun)
  805. {
  806. decision_firstRun(now_gps_ins,gpsMapLine);
  807. }
  808. if(ServiceCarStatus.msysparam.gpsOffset_x!=0 || ServiceCarStatus.msysparam.gpsOffset_y!=0 ){
  809. GPS_INS gpsOffset = Coordinate_UnTransfer(ServiceCarStatus.msysparam.gpsOffset_x, ServiceCarStatus.msysparam.gpsOffset_y, now_gps_ins);
  810. now_gps_ins.gps_x=gpsOffset.gps_x;
  811. now_gps_ins.gps_y=gpsOffset.gps_y;
  812. GaussProjInvCal(now_gps_ins.gps_x, now_gps_ins.gps_y, &now_gps_ins.gps_lng, &now_gps_ins.gps_lat);
  813. }
  814. changingDangWei=false;
  815. minDecelerate=0;
  816. if(now_gps_ins.gps_lat<0||now_gps_ins.gps_lat>90){
  817. // int a=0;
  818. gps_decition->wheel_angle = 0;
  819. gps_decition->speed = dSpeed;
  820. gps_decition->accelerator = -0.5;
  821. gps_decition->brake=10;
  822. return gps_decition;
  823. }
  824. if(ServiceCarStatus.daocheMode){
  825. now_gps_ins.ins_heading_angle=now_gps_ins.ins_heading_angle+180;
  826. if( now_gps_ins.ins_heading_angle>=360)
  827. now_gps_ins.ins_heading_angle= now_gps_ins.ins_heading_angle-360;
  828. }
  829. //1125 traficc
  830. traffic_light_gps.gps_lat=ServiceCarStatus.iTrafficeLightLat;
  831. traffic_light_gps.gps_lng=ServiceCarStatus.iTrafficeLightLon;
  832. GaussProjCal(traffic_light_gps.gps_lng,traffic_light_gps.gps_lat, &traffic_light_gps.gps_x, &traffic_light_gps.gps_y);
  833. //xiesi
  834. ///kkcai, 2020-01-03
  835. //ServiceCarStatus.busmode=true;
  836. //ServiceCarStatus.busmode=false;//20200102
  837. ///////////////////////////////////////////////////
  838. //busMode = ServiceCarStatus.busmode;
  839. nearStation=false;
  840. gps_decition->leftlamp = false;
  841. gps_decition->rightlamp = false;
  842. // qDebug("heading is %g",now_gps_ins.ins_heading_angle);
  843. aim_gps_ins.gps_lat= ServiceCarStatus.mfParkLat;
  844. aim_gps_ins.gps_lng= ServiceCarStatus.mfParkLng;
  845. aim_gps_ins.ins_heading_angle= ServiceCarStatus.mfParkHeading;
  846. GaussProjCal(aim_gps_ins.gps_lng,aim_gps_ins.gps_lat, &aim_gps_ins.gps_x, &aim_gps_ins.gps_y);
  847. is_arrivaled = false;
  848. xiuzhengCs=0;
  849. realspeed = now_gps_ins.speed;
  850. secSpeed = realspeed / 3.6;
  851. if(decision_ParkCalc(now_gps_ins,gps_decition) == 1)
  852. {
  853. return gps_decition;
  854. }
  855. switch (vehState) {
  856. // ChuiZhiTingChe
  857. case reverseCar:
  858. return decision_reverseCar(now_gps_ins);
  859. break;
  860. case reversing:
  861. return decision_reversing(now_gps_ins);
  862. break;
  863. case reverseCircle:
  864. return decision_reverseCircle(now_gps_ins);
  865. break;
  866. case reverseDirect:
  867. return decision_reverseDirect(now_gps_ins);
  868. break;
  869. case reverseArr:
  870. return decision_reverseArr(now_gps_ins);
  871. break;
  872. //ceFangWeiBoChe
  873. case dRever:
  874. return decision_dRever(now_gps_ins);
  875. break;
  876. case dRever0:
  877. return decision_dRever0(now_gps_ins);
  878. break;
  879. case dRever1:
  880. return decision_dRever1(now_gps_ins);
  881. break;
  882. case dRever2:
  883. return decision_dRever2(now_gps_ins);
  884. break;
  885. case dRever3:
  886. return decision_dRever3(now_gps_ins);
  887. break;
  888. case dRever4:
  889. return decision_dRever4(now_gps_ins);
  890. break;
  891. default:
  892. break;
  893. }
  894. obsDistance = -1;
  895. esrIndex = -1;
  896. lidarDistance = -1;
  897. obsDistanceAvoid = -1;
  898. esrIndexAvoid = -1;
  899. roadPre = -1;
  900. gpsTraceOri.clear();
  901. gpsTraceNow.clear();
  902. gpsTraceAim.clear();
  903. gpsTraceAvoid.clear();
  904. gpsTraceBack.clear();
  905. if (!isFirstRun)
  906. {
  907. // PathPoint = iv::decition::Compute00().getNearestPointIndex(now_gps_ins, gpsMapLine, lastGpsIndex, minDis, maxAngle);
  908. // if(PathPoint<0){
  909. PathPoint = iv::decition::Compute00().getFirstNearestPointIndex(now_gps_ins, gpsMapLine, lastGpsIndex, minDis, maxAngle);
  910. // }
  911. }
  912. if (PathPoint<0)
  913. {
  914. minDecelerate=-1.0;
  915. phaseSpeedDecition(gps_decition, secSpeed, -1, 0,now_gps_ins);
  916. return gps_decition;
  917. }
  918. lastGpsIndex = PathPoint;
  919. //2020-01-03, kkcai
  920. //if(!circleMode && PathPoint>gpsMapLine.size()-200){
  921. if(!circleMode && PathPoint>gpsMapLine.size()-100){
  922. minDecelerate=-1.0;
  923. std::cout<<"map finish brake"<<std::endl;
  924. }
  925. if(!ServiceCarStatus.inRoadAvoid){
  926. roadOri = gpsMapLine[PathPoint]->roadOri;
  927. roadSum = gpsMapLine[PathPoint]->roadSum;
  928. }else{
  929. roadOri=gpsMapLine[PathPoint]->roadOri*3+1;
  930. roadSum = gpsMapLine[PathPoint]->roadSum*3;
  931. }
  932. if(ServiceCarStatus.avoidObs){
  933. gpsMapLine[PathPoint]->runMode=1;
  934. }else{
  935. gpsMapLine[PathPoint]->runMode=0;
  936. }
  937. if(roadNowStart){
  938. roadNow=roadOri;
  939. roadNowStart=false;
  940. }
  941. // avoidX = (roadOri-roadNow)*roadWidth;
  942. avoidX=computeAvoidX(roadNow,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  943. if ( gpsMapLine[PathPoint]->runMode == 0 &&(vehState == avoidObs||vehState ==stopObs||vehState == preAvoid
  944. ||vehState == avoiding||vehState == backOri||vehState ==preBack||vehState ==waitAvoid ) )
  945. {
  946. vehState = normalRun;
  947. roadNow = roadOri;
  948. }
  949. gpsTraceOri= getGpsTrace(now_gps_ins, gpsMapLine, lastGpsIndex,circleMode);
  950. // gpsTraceOri = laneChangePlanner->getPath(now_gps_ins,gpsMapLine,PathPoint,0,lidarGridPtr);
  951. if(gpsTraceOri.empty()){
  952. gps_decition->wheel_angle = 0;
  953. gps_decition->speed = dSpeed;
  954. gps_decition->accelerator = -0.5;
  955. gps_decition->brake=10;
  956. return gps_decition;
  957. }
  958. traceDevi=gpsTraceOri[0].x;
  959. //起步进行frenet规划后,车辆行驶至地图路线上,起步操作完毕。
  960. //如果车辆本身启动位置在地图路线上,可不用进行frenet规划。
  961. // if(GetDistance(now_gps_ins,*gpsMapLine[PathPoint]) < 1){
  962. // startingFlag = false;
  963. // }
  964. startingFlag = false;
  965. if(startingFlag){
  966. // gpsTraceAim = gpsTraceOri;
  967. if(abs(gpsTraceOri[0].x)>1){
  968. cout<<"frenetPlanner->getPath:pre"<<endl;
  969. gpsTraceNow = frenetPlanner->getPath(now_gps_ins,gpsMapLine,PathPoint,0,lidarGridPtr);
  970. cout<<"frenetPlanner->getPath,gpsTraceNow.size: "<<gpsTraceNow.size()<<endl;
  971. if(gpsTraceNow.size()==0){
  972. gps_decition->accelerator = 0;
  973. gps_decition->brake=10;
  974. gps_decition->wheel_angle = lastAngle;
  975. gps_decition->speed = 0;
  976. return gps_decition;
  977. }
  978. }else{
  979. startingFlag = false;
  980. }
  981. }
  982. if(useFrenet){
  983. //如果车辆在变道中,启用frenet规划局部路径
  984. if(vehState == avoiding || vehState == backOri){
  985. //avoidX = (roadOri - roadNow)*roadWidth;
  986. avoidX=computeAvoidX(roadNow,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  987. gpsTraceNow = frenetPlanner->getPath(now_gps_ins,gpsMapLine,PathPoint,avoidX,lidarGridPtr);
  988. //gpsTraceAim = laneChangePlanner->getPath(now_gps_ins,gpsMapLine,PathPoint,avoidX,lidarGridPtr);
  989. gpsTraceAim = getGpsTraceOffset(gpsTraceOri, avoidX);
  990. if(gpsTraceNow.size()==0){
  991. gps_decition->accelerator = 0;
  992. gps_decition->brake=10;
  993. gps_decition->wheel_angle = lastAngle;
  994. gps_decition->speed = 0;
  995. return gps_decition;
  996. }
  997. }
  998. }
  999. if(gpsTraceNow.size()==0){
  1000. if (roadNow==roadOri)
  1001. {
  1002. gpsTraceNow.assign(gpsTraceOri.begin(), gpsTraceOri.end());
  1003. //gpsTraceNow = getGpsTrace(now_gps_ins, gpsMapLine, lastGpsIndex);
  1004. }else
  1005. {
  1006. // gpsTraceNow = getGpsTrace(now_gps_ins, gmapsR[int(abs(roadWidth * 2)*(roadOri-roadNow))], lastGpsIndex);
  1007. gpsTraceNow = getGpsTraceOffset(gpsTraceOri, avoidX);
  1008. //gpsTraceNow = laneChangePlanner->getPath(now_gps_ins,gpsMapLine,PathPoint,avoidX,lidarGridPtr);
  1009. }
  1010. }
  1011. // dSpeed = getSpeed(gpsTraceNow);
  1012. dSpeed = 80;
  1013. // planTrace = gpsTraceNow; //Add By YuChuli, 2020.11.26
  1014. planTrace.clear();
  1015. for(int i=0;i<gpsTraceNow.size();i++){
  1016. TracePoint pt(gpsTraceNow[i].x,gpsTraceNow[i].y);
  1017. planTrace.push_back(pt);
  1018. }
  1019. dSpeed = limitSpeed(controlAng, dSpeed);
  1020. controlAng= getAngle(gpsTraceNow,now_gps_ins,gps_decition);
  1021. if(!circleMode && PathPoint>(gpsMapLine.size()-100)){
  1022. controlAng=0;
  1023. }
  1024. //1220
  1025. if(ServiceCarStatus.daocheMode){
  1026. controlAng=0-controlAng;
  1027. }
  1028. //2020-0106
  1029. if(vehState==avoiding){
  1030. controlAng=max(-150.0,controlAng);
  1031. controlAng=min(150.0,controlAng);
  1032. }
  1033. if(vehState==backOri){
  1034. controlAng=max(-120.0,controlAng);
  1035. controlAng=min(120.0,controlAng);
  1036. }
  1037. //准备驻车
  1038. if (readyZhucheMode)
  1039. {
  1040. decision_readyZhucheMode(now_gps_ins,gpsMapLine);
  1041. }
  1042. if (readyParkMode)
  1043. {
  1044. decision_readyParkMode(now_gps_ins,gpsMapLine);
  1045. }
  1046. decision_speedctrl(gps_decition,gpsMapLine);
  1047. if(vehState==changingRoad){
  1048. if(gpsTraceNow[0].x>1.0){
  1049. gps_decition->leftlamp = false;
  1050. gps_decition->rightlamp = true;
  1051. }else if(gpsTraceNow[0].x<-1.0){
  1052. gps_decition->leftlamp = true;
  1053. gps_decition->rightlamp = false;
  1054. }else{
  1055. vehState==normalRun;
  1056. }
  1057. }
  1058. // qDebug("decide0 time is %d",xTime.elapsed());
  1059. //1220
  1060. if(!ServiceCarStatus.daocheMode){
  1061. computeObsOnRoad(lidarGridPtr, gpsTraceNow, roadNow,gpsMapLine,lidar_per);
  1062. }else{
  1063. gpsTraceRear.clear();
  1064. for(int i=0;i<gpsTraceNow.size();i++){
  1065. Point2D pt;
  1066. pt.x=0-gpsTraceNow[i].x;
  1067. pt.y=0-gpsTraceNow[i].y;
  1068. gpsTraceRear.push_back(pt);
  1069. }
  1070. computeObsOnRoad(lidarGridPtr, gpsTraceNow, roadNow,gpsMapLine,lidar_per);
  1071. // obsDistance=-1; //1227
  1072. }
  1073. //old_bz--------------------------------------------------------------------------------------------------
  1074. if (vehState == avoiding)
  1075. {
  1076. cout<<"\n==================avoiding=================\n"<<endl;
  1077. // vehState=normalRun; //1025
  1078. if (dSpeed > 10) {
  1079. dSpeed = 10;
  1080. }
  1081. //若车辆到达变道后的路径,改变车辆状态,关闭frenet规划
  1082. if (useFrenet && abs(gpsTraceAim[0].x)<1.0) {
  1083. vehState = normalRun;
  1084. // useFrenet = false;
  1085. // useOldAvoid = true;
  1086. }
  1087. else if (useOldAvoid && abs(gpsTraceNow[0].x)<1.0) {
  1088. // vehState = avoidObs; 0929
  1089. vehState = normalRun;
  1090. }
  1091. else if (gpsTraceNow[0].x>0)
  1092. {
  1093. gps_decition->leftlamp = false;
  1094. gps_decition->rightlamp = true;
  1095. }
  1096. else if(gpsTraceNow[0].x<0)
  1097. {
  1098. gps_decition->leftlamp = true;
  1099. gps_decition->rightlamp = false;
  1100. }
  1101. }
  1102. if (vehState==preBack)
  1103. {
  1104. vehState = backOri;
  1105. }
  1106. if (vehState==backOri)
  1107. {
  1108. cout<<"\n================backOri===========\n"<<endl;
  1109. // vehState=normalRun; //1025
  1110. if (dSpeed > 10) {
  1111. dSpeed = 10;
  1112. }
  1113. //若车辆到达变道后的路径,改变车辆状态,关闭frenet规划
  1114. if (useFrenet && abs(gpsTraceAim[0].x)<1.0) {
  1115. vehState = normalRun;
  1116. // useFrenet = false;
  1117. // useOldAvoid = true;
  1118. }
  1119. else if (useOldAvoid && abs(gpsTraceNow[0].x)<1.0) {
  1120. // vehState = avoidObs; 0929
  1121. vehState = normalRun;
  1122. }
  1123. else if (gpsTraceNow[0].x>0)
  1124. {
  1125. gps_decition->leftlamp = false;
  1126. gps_decition->rightlamp = true;
  1127. }
  1128. else if (gpsTraceNow[0].x<0)
  1129. {
  1130. gps_decition->leftlamp = true;
  1131. gps_decition->rightlamp = false;
  1132. }
  1133. }
  1134. std::cout<<"\n原始RoadOri:%d\n"<<roadOri<<endl;
  1135. cout<<"\n当前RoadNum:%d\n"<<roadNow<<endl;
  1136. // 计算回归原始路线
  1137. if (roadNow!=roadOri)
  1138. {
  1139. // useFrenet = true;
  1140. // useOldAvoid = false;
  1141. if(useFrenet){
  1142. if ((GetDistance(now_gps_ins, startAvoidGpsInsVector[roadOri])>max(avoidMinDistanceVector[roadOri],30.0)))
  1143. {
  1144. double offsetL = -(roadSum - 1)*roadWidth;
  1145. double offsetR = (roadOri - 0)*roadWidth;
  1146. roadPre = frenetPlanner->chooseRoadByFrenet(now_gps_ins,gpsMapLine,PathPoint,offsetL,offsetR,lidarGridPtr,roadNow);
  1147. }
  1148. }
  1149. else if(useOldAvoid){
  1150. roadPre = chooseBackRoad(lidarGridPtr, now_gps_ins, gpsMapLine,lidar_per);
  1151. // avoidX = (roadOri - roadNow)*roadWidth; //1012
  1152. avoidX=computeAvoidX(roadNow,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  1153. }
  1154. }
  1155. if (roadNow != roadOri && roadPre!=-1)
  1156. {
  1157. roadNow = roadPre;
  1158. // avoidX = (roadOri - roadNow)*roadWidth;
  1159. avoidX=computeAvoidX(roadNow,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  1160. gpsTraceNow.clear();
  1161. if(useOldAvoid){
  1162. gpsTraceNow = getGpsTraceOffset(gpsTraceOri, avoidX);
  1163. }
  1164. else if(useFrenet){
  1165. gpsTraceNow = frenetPlanner->getPath(now_gps_ins,gpsMapLine,PathPoint,avoidX,lidarGridPtr);
  1166. }
  1167. vehState = backOri;
  1168. hasCheckedBackLidar = false;
  1169. // checkBackObsTimes = 0;
  1170. cout<<"\n回归RoadNum:%d\n"<< roadNow<<endl;
  1171. }
  1172. //shiyanbizhang 0929
  1173. if(obsDistance>0&& (obsDistance<ServiceCarStatus.socfDis+20.0) &&(abs(realspeed)<1.0) &&
  1174. (vehState==normalRun||vehState==backOri || vehState==avoiding) &&(ObsTimeStart==-1)
  1175. && (gpsMapLine[PathPoint]->runMode==1)){
  1176. ObsTimeStart=GetTickCount();
  1177. cout<<"\n====================preAvoid time count start==================\n"<<endl;
  1178. }
  1179. if(ObsTimeStart!=-1){
  1180. ObsTimeEnd=GetTickCount();
  1181. }
  1182. if(ObsTimeEnd!=-1){
  1183. ObsTimeSpan=ObsTimeEnd-ObsTimeStart;
  1184. }
  1185. if(ObsTimeSpan>ObsTimeWidth &&(obsDistance>1.5||obsDistance<0) && (gpsMapLine[PathPoint]->runMode==1)){ //1026
  1186. vehState=avoidObs;
  1187. ObsTimeStart=-1;
  1188. ObsTimeEnd=-1;
  1189. ObsTimeSpan=-1;
  1190. cout<<"\n====================preAvoid time count finish==================\n"<<endl;
  1191. }
  1192. if(obsDistance<0 ||obsDistance>ServiceCarStatus.socfDis){
  1193. ObsTimeStart=-1;
  1194. ObsTimeEnd=-1;
  1195. ObsTimeSpan=-1;
  1196. }
  1197. //避障模式
  1198. if (vehState == avoidObs || vehState==waitAvoid ) {
  1199. // if (obsDistance <20 && obsDistance >0)
  1200. if (obsDistance <ServiceCarStatus.aocfDis && obsDistance >0)
  1201. {
  1202. dSpeed = min(7.0,dSpeed);
  1203. avoidTimes++;
  1204. // if (avoidTimes>=6)
  1205. if (avoidTimes>=ServiceCarStatus.aocfTimes)
  1206. {
  1207. vehState = preAvoid;
  1208. avoidTimes = 0;
  1209. }
  1210. }
  1211. // else if (obsDistance < 35 && obsDistance >0 && dSpeed>10)
  1212. // {
  1213. // dSpeed = 10;
  1214. // avoidTimes = 0;
  1215. // }
  1216. else if (obsDistance < 40 && obsDistance >0 && dSpeed>15)
  1217. {
  1218. dSpeed = min(15.0,dSpeed);
  1219. avoidTimes = 0;
  1220. }
  1221. else
  1222. {
  1223. avoidTimes = 0;
  1224. }
  1225. }
  1226. if (vehState == preAvoid)
  1227. {
  1228. cout<<"\n====================preAvoid==================\n"<<endl;
  1229. /* if (obsDisVector[roadNow]>30)*/ //if (obsDisVector[roadNow]>30||obsDisVector[roadNow]<0)
  1230. if (obsDisVector[roadNow]>ServiceCarStatus.aocfDis)
  1231. {
  1232. // vehState = avoidObs; 0929
  1233. vehState=normalRun;
  1234. }
  1235. else
  1236. {
  1237. //roadPre = chooseAvoidRoad(lidarGridPtr, now_gps_ins,gpsMapLine);
  1238. if(useOldAvoid){
  1239. roadPre = chooseAvoidRoad(lidarGridPtr, now_gps_ins,gpsMapLine,lidar_per);
  1240. // avoidX = (roadOri - roadNow)*roadWidth; //1012
  1241. avoidX=computeAvoidX(roadNow,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  1242. }
  1243. else if(useFrenet){
  1244. double offsetL = -(roadSum - 1)*roadWidth;
  1245. double offsetR = (roadOri - 0)*roadWidth;
  1246. roadPre = frenetPlanner->chooseRoadByFrenet(now_gps_ins,gpsMapLine,PathPoint,offsetL,offsetR,lidarGridPtr,roadNow);
  1247. }
  1248. if (roadPre == -1 && obsDisVector[roadNow]<1.5 && obsDisVector[roadNow]>0)
  1249. {
  1250. // vehState = waitAvoid; 0929
  1251. vehState = avoidObs;
  1252. }
  1253. else if (roadPre != -1)
  1254. {
  1255. if(useOldAvoid){
  1256. roadNow = roadPre;
  1257. // avoidX = (roadOri - roadNow)*roadWidth;
  1258. avoidX=computeAvoidX(roadNow,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  1259. gpsTraceNow.clear();
  1260. gpsTraceNow = getGpsTraceOffset(gpsTraceOri, avoidX);
  1261. }
  1262. else if(useFrenet){
  1263. if(roadPre != roadNow){
  1264. avoidMinDistanceVector[roadNow] = obsDisVector[roadNow] + ServiceCarStatus.msysparam.vehLenth;
  1265. startAvoidGpsInsVector[roadNow] = now_gps_ins;
  1266. }
  1267. roadNow = roadPre;
  1268. // avoidX = (roadOri - roadNow)*roadWidth;
  1269. avoidX=computeAvoidX(roadNow,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  1270. gpsTraceNow = frenetPlanner->getPath(now_gps_ins,gpsMapLine,PathPoint,avoidX,lidarGridPtr);
  1271. }
  1272. vehState = avoiding;
  1273. hasCheckedAvoidLidar = false;
  1274. cout<<"\n避障到RoadNum:%d\n"<<roadNow<<endl;
  1275. }
  1276. }
  1277. }
  1278. //--------------------------------------------------------------------------------old_bz_end
  1279. if (parkMode)
  1280. {
  1281. minDecelerate=-0.4;
  1282. if(finishPointNum<0||finishPointNum>=gpsMapLine.size()){
  1283. parkMode=false;
  1284. }else if(GetDistance(now_gps_ins, *gpsMapLine[finishPointNum])>4){
  1285. parkMode=false;
  1286. }
  1287. }
  1288. //驻车
  1289. if (zhucheMode)
  1290. {
  1291. int mzcTime = ServiceCarStatus.msysparam.mzhuchetime * 1000;
  1292. // if(trumpet()<16000)
  1293. if (trumpet()<mzcTime)
  1294. {
  1295. // if (trumpet()<12000){
  1296. cout<<"ZHECHE ING STATE+++++++++++++++++++++++++++++++++"<<endl;
  1297. minDecelerate=-1.0;
  1298. if(abs(realspeed)<0.2){
  1299. controlAng=0; //tju
  1300. }
  1301. }
  1302. else
  1303. {
  1304. hasZhuched = true; //1125
  1305. zhucheMode = false;
  1306. trumpetFirstCount = true;
  1307. cout<<"ZHECHE STATE JIESHU +++++++++++++++++++++++++++++++++"<<endl;
  1308. }
  1309. }
  1310. //判断驻车标志位
  1311. if (hasZhuched && GetDistance(now_gps_ins,*gpsMapLine[zhuchePointNum])>20)
  1312. {
  1313. hasZhuched = false;
  1314. }
  1315. if ( vehState==changingRoad || vehState==chaocheBack)
  1316. {
  1317. double lastAng = 0.0 - lastAngle;
  1318. if (controlAng>40)
  1319. {
  1320. controlAng =40;
  1321. }
  1322. else if (controlAng<-40)
  1323. {
  1324. controlAng = - 40;
  1325. }
  1326. }
  1327. //速度结合角度的限制
  1328. controlAng = limitAngle(realspeed, controlAng);
  1329. std::cout << "\n呼车指令状态:%d\n" << ServiceCarStatus.carState << std::endl;
  1330. //1220
  1331. if(PathPoint+80<gpsMapLine.size()-1){
  1332. if(gpsMapLine[PathPoint+80]->roadMode==4 && !ServiceCarStatus.daocheMode){
  1333. changingDangWei=true;
  1334. }
  1335. }
  1336. if(changingDangWei){
  1337. if(abs(realspeed)>0.1){
  1338. dSpeed=0;
  1339. }else{
  1340. dSpeed=0;
  1341. gps_decition->dangWei=2;
  1342. ServiceCarStatus.daocheMode=true;
  1343. }
  1344. }
  1345. //1220 end
  1346. for(int i = 0;i<ServiceCarStatus.car_stations.size();i++)
  1347. {
  1348. GPS_INS gpsIns;
  1349. GaussProjCal(ServiceCarStatus.car_stations[i].longtitude, ServiceCarStatus.car_stations[i].latitude, &gpsIns.gps_x, &gpsIns.gps_y);
  1350. double dis = GetDistance(gpsIns, now_gps_ins);
  1351. if(dis<20)
  1352. ServiceCarStatus.currentstation = ServiceCarStatus.car_stations[i].ID;
  1353. }
  1354. // 解析云平台数据
  1355. if(ServiceCarStatus.stationCmd.received==true)
  1356. {
  1357. std::vector<Station> station_received;
  1358. Station station_aa,station_nearest;
  1359. if(ServiceCarStatus.stationCmd.has_emergencyStop)
  1360. {
  1361. if(ServiceCarStatus.stationCmd.emergencyStop==0x01)
  1362. {
  1363. //ServiceCarStatus.carState = 0;
  1364. //busMode=true;
  1365. ServiceCarStatus.emergencyStop=1;
  1366. }
  1367. else
  1368. {
  1369. //ServiceCarStatus.carState = 1;
  1370. //busMode=false;
  1371. ServiceCarStatus.emergencyStop=0;
  1372. }
  1373. }
  1374. if(ServiceCarStatus.stationCmd.has_stationStop)
  1375. {
  1376. //寻找最近站点
  1377. station_received.clear();
  1378. for(int i=0;i<ServiceCarStatus.stationCmd.stationTotalNum;i++)
  1379. {
  1380. station_aa.index=i;
  1381. station_aa.station_location.gps_lat=ServiceCarStatus.stationCmd.stationGps[i].gps_lat;
  1382. station_aa.station_location.gps_lng=ServiceCarStatus.stationCmd.stationGps[i].gps_lng;
  1383. GaussProjCal(station_aa.station_location.gps_lng,station_aa.station_location.gps_lat, &station_aa.station_location.gps_x, &station_aa.station_location.gps_y);
  1384. station_received.push_back(station_aa);
  1385. }
  1386. station_nearest=getNearestStation(now_gps_ins,station_received,gpsMapLine);
  1387. qDebug("station_nearest: %d, lat: %.7f, lon: %.7f", station_nearest.map_index, station_nearest.station_location.gps_lat, ServiceCarStatus.amilng=station_nearest.station_location.gps_lng);
  1388. givlog->debug("brain_v2x","station_nearest: %d, lat: %.7f, lon: %.7f",
  1389. station_nearest.map_index, station_nearest.station_location.gps_lat,
  1390. station_nearest.station_location.gps_lng);
  1391. //进入站点模式
  1392. if((ServiceCarStatus.stationCmd.stationStop==0x00))
  1393. {
  1394. ServiceCarStatus.carState = 2;
  1395. ServiceCarStatus.amilat=station_nearest.station_location.gps_lat;
  1396. ServiceCarStatus.amilng=station_nearest.station_location.gps_lng;
  1397. busMode=true;
  1398. }else
  1399. {
  1400. ServiceCarStatus.carState = 1;
  1401. busMode=false;
  1402. ServiceCarStatus.station_control_door=0;
  1403. ServiceCarStatus.station_control_door_option=false;
  1404. }
  1405. }
  1406. if(ServiceCarStatus.stationCmd.has_carMode)
  1407. {
  1408. if(ServiceCarStatus.stationCmd.carMode==0x00)
  1409. {
  1410. ServiceCarStatus.stationCmd.mode_manual_drive=true;
  1411. }else
  1412. {
  1413. ServiceCarStatus.stationCmd.mode_manual_drive=false;
  1414. }
  1415. }
  1416. ServiceCarStatus.stationCmd.received=false;
  1417. }
  1418. //carState == 0,紧急停车
  1419. if ((ServiceCarStatus.emergencyStop==1)) //||(adjuseultra()==true))
  1420. {
  1421. minDecelerate=-1.0;
  1422. }
  1423. if (ServiceCarStatus.carState == 3 && busMode)
  1424. {
  1425. if(realspeed<0.1){
  1426. ServiceCarStatus.carState=0;
  1427. minDecelerate=-1.0;
  1428. }else{
  1429. nearStation=true;
  1430. dSpeed=0;
  1431. }
  1432. }
  1433. //carState==2,站点停车
  1434. if ((ServiceCarStatus.carState==2)&&busMode)
  1435. {
  1436. aim_gps_ins.gps_lat=ServiceCarStatus.amilat;
  1437. aim_gps_ins.gps_lng=ServiceCarStatus.amilng;
  1438. GaussProjCal( aim_gps_ins.gps_lng, aim_gps_ins.gps_lat, &aim_gps_ins.gps_x, &aim_gps_ins.gps_y);
  1439. double dis = GetDistance(aim_gps_ins, now_gps_ins);
  1440. Point2D pt = Coordinate_Transfer((aim_gps_ins).gps_x, (aim_gps_ins).gps_y, now_gps_ins);
  1441. if (dis<20 && pt.y<5 && abs(pt.x)<3)
  1442. {
  1443. dSpeed = 0;
  1444. nearStation=true;
  1445. //is_arrivaled = true;
  1446. //ServiceCarStatus.status[0] = true;
  1447. ServiceCarStatus.istostation=1;
  1448. minDecelerate=-1.0;
  1449. }
  1450. else if (dis<20 && pt.y<15 && abs(pt.x)<3)
  1451. {
  1452. nearStation=true;
  1453. dSpeed = min(8.0, dSpeed);
  1454. }
  1455. else if (dis<30 && pt.y<20 && abs(pt.x)<3)
  1456. {
  1457. dSpeed = min(15.0, dSpeed);
  1458. }
  1459. else if (dis<50 && abs(pt.x)<3)
  1460. {
  1461. dSpeed = min(20.0, dSpeed);
  1462. }
  1463. if((pt.y<5)&&(abs(realspeed)<0.1)&&(ServiceCarStatus.station_control_door==0))
  1464. {
  1465. ServiceCarStatus.station_control_door=1; //open door
  1466. }
  1467. //站点停车log
  1468. givlog->debug("brain_v2x","aim_gps_ins.gps_lat: %.7f, aim_gps_ins.gps_lng: %.7f, dis: %.2f, dSpeed: %.1f",
  1469. aim_gps_ins.gps_lat, aim_gps_ins.gps_lng,
  1470. dis,dSpeed);
  1471. }
  1472. dSecSpeed = dSpeed / 3.6;
  1473. gps_decition->speed = dSpeed;
  1474. if (gpsMapLine[PathPoint]->runMode == 2)
  1475. {
  1476. obsDistance = -1;
  1477. }
  1478. std::cout<<"juecesudu0="<<dSpeed<<std::endl;
  1479. //-------------------------------traffic light----------------------------------------------------------------------------------------
  1480. if(traffic_light_gps.gps_lat!=0 && traffic_light_gps.gps_lng!=0){
  1481. traffic_light_pathpoint = iv::decition::Compute00().getNoAngleNearestPointIndex(traffic_light_gps, gpsMapLine);
  1482. // traffic_light_pathpoint=130;
  1483. float traffic_speed=ComputeTrafficLightSpeed(ServiceCarStatus.iTrafficeLightColor,ServiceCarStatus.iTrafficeLightTime,gpsMapLine,
  1484. traffic_light_pathpoint ,PathPoint,secSpeed,dSpeed);
  1485. dSpeed = min((double)traffic_speed,dSpeed);
  1486. if(traffic_speed==0){
  1487. minDecelerate=-2.0;
  1488. }
  1489. }
  1490. //-------------------------------traffic light end-----------------------------------------------------------------------------------------------
  1491. //-------------------------------v2x traffic light-----------------------------------------------------------------------------------------
  1492. double v2xTrafficSpeed= ComputeV2XTrafficLightSpeed( trafficLight, gpsMapLine, v2xTrafficVector,
  1493. PathPoint, secSpeed, dSpeed, circleMode);
  1494. dSpeed = min(v2xTrafficSpeed,dSpeed);
  1495. //------------------------------v2x traffic light end--------------------------------------------------------------------------------------
  1496. transferGpsMode2(gpsMapLine);
  1497. if((ServiceCarStatus.msysparam.mvehtype=="hapo")&&(abs(realspeed)<18)){
  1498. if(obsDistance>0 && obsDistance<6){
  1499. dSpeed=0;
  1500. }
  1501. }else if(obsDistance>0 && obsDistance<10){
  1502. dSpeed=0;
  1503. }
  1504. // obsDistance=-1; //1227
  1505. if(ServiceCarStatus.group_control){
  1506. dSpeed = ServiceCarStatus.group_comm_speed;
  1507. }
  1508. if(dSpeed==0){
  1509. minDecelerate=min(-1.0f,minDecelerate);
  1510. }
  1511. std::cout<<"dSpeed= "<<dSpeed<<std::endl;
  1512. // givlog->debug("SPEED","dSpeed is %f",dSpeed);
  1513. gps_decition->wheel_angle = 0.0 - controlAng;
  1514. phaseSpeedDecition(gps_decition, secSpeed, obsDistance, obsSpeed,now_gps_ins);
  1515. lastAngle=gps_decition->wheel_angle;
  1516. // qDebug("decide1 time is %d",xTime.elapsed());
  1517. for(int i=0;i<ServiceCarStatus.obsTraceLeft.size();i++){
  1518. givlog->debug("obs_distance","obsTraceLeftX: %f, obsTraceLeftY: %f",
  1519. ServiceCarStatus.obsTraceLeft.at(i).x, ServiceCarStatus.obsTraceLeft.at(i).y);
  1520. }
  1521. return gps_decition;
  1522. }
  1523. iv::Station ivdecision_brain::getNearestStation(iv::GPS_INS now_gps_ins,std::vector<Station> station_n,std::vector<GPSData> gpsMap){
  1524. int now_index=0,front_index=0;
  1525. int station_size=station_n.size();
  1526. for(int i=0;i<station_size;i++)
  1527. {
  1528. int minDistance=10;
  1529. for (int j = 0; j < gpsMap.size(); j++)
  1530. {
  1531. double tmpdis = GetDistance(station_n[i].station_location, (*gpsMap[j]));
  1532. if (tmpdis < minDistance )
  1533. {
  1534. minDistance = tmpdis;
  1535. station_n[i].map_index=j;
  1536. }
  1537. }
  1538. givlog->debug("brain_v2x","stationi: %d, map_index: %d",
  1539. i,station_n[i].map_index);
  1540. }
  1541. int minDistance=10;
  1542. for (int j = 0; j < gpsMap.size(); j++)
  1543. {
  1544. double tmpdis = GetDistance(now_gps_ins, (*gpsMap[j]));
  1545. if (tmpdis < minDistance )
  1546. {
  1547. minDistance = tmpdis;
  1548. now_index=j;
  1549. }
  1550. }
  1551. givlog->debug("brain_v2x","now_index: %d",
  1552. now_index);
  1553. int min_index=gpsMap.size()-1;
  1554. int station_index=0;
  1555. for(int i=0;i<station_size;i++)
  1556. {
  1557. if(station_n[i].map_index>now_index)
  1558. {
  1559. front_index=station_n[i].map_index;
  1560. if(front_index<min_index)
  1561. {
  1562. min_index=front_index;
  1563. station_index=i;
  1564. }
  1565. }
  1566. }
  1567. qDebug("station_index:%d",station_index);
  1568. return station_n[station_index];
  1569. }
  1570. void ivdecision_brain::initMethods(){
  1571. pid_Controller= new PIDController();
  1572. ge3_Adapter = new Ge3Adapter();
  1573. qingyuan_Adapter = new QingYuanAdapter();
  1574. vv7_Adapter = new VV7Adapter();
  1575. zhongche_Adapter = new ZhongcheAdapter();
  1576. bus_Adapter = new BusAdapter();
  1577. hapo_Adapter = new HapoAdapter();
  1578. yuhesen_Adapter = new YuHeSenAdapter();
  1579. mpid_Controller.reset(pid_Controller);
  1580. mbus_Adapter.reset(bus_Adapter);
  1581. mhapo_Adapter.reset(hapo_Adapter);
  1582. myuhesen_Adapter.reset(yuhesen_Adapter);
  1583. frenetPlanner = new FrenetPlanner();
  1584. // laneChangePlanner = new LaneChangePlanner();
  1585. mfrenetPlanner.reset(frenetPlanner);
  1586. // mlaneChangePlanner.reset(laneChangePlanner);
  1587. }
  1588. void ivdecision_brain::phaseSpeedDecition(iv::decition::Decition decition, double secSpeed, double obsDis, double obsSpeed, GPS_INS gpsIns ) {
  1589. pid_Controller->getControlDecition( gpsIns, gpsTraceNow, dSpeed, obsDis, obsSpeed, false, true, &decition);
  1590. if(ServiceCarStatus.msysparam.mvehtype=="ge3"){
  1591. ge3_Adapter->getAdapterDeciton(gpsIns, gpsTraceNow, dSpeed, obsDis,obsSpeed, decition->accelerator,ServiceCarStatus.mfCalAcc ,changingDangWei, &decition);
  1592. }else if( ServiceCarStatus.msysparam.mvehtype=="qingyuan"){
  1593. qingyuan_Adapter->getAdapterDeciton(gpsIns, gpsTraceNow, dSpeed, obsDis,obsSpeed, decition->accelerator,ServiceCarStatus.mfCalAcc ,changingDangWei, &decition);
  1594. }else if( ServiceCarStatus.msysparam.mvehtype=="vv7"){
  1595. vv7_Adapter->getAdapterDeciton(gpsIns, gpsTraceNow, dSpeed, obsDis,obsSpeed, decition->accelerator,ServiceCarStatus.mfCalAcc ,changingDangWei, &decition);
  1596. }else if( ServiceCarStatus.msysparam.mvehtype=="zhongche"){
  1597. zhongche_Adapter->getAdapterDeciton(gpsIns, gpsTraceNow, dSpeed, obsDis,obsSpeed, decition->accelerator,ServiceCarStatus.mfCalAcc ,changingDangWei, &decition);
  1598. }else if(ServiceCarStatus.msysparam.mvehtype=="bus"){
  1599. bus_Adapter->getAdapterDeciton(gpsIns, gpsTraceNow, dSpeed, obsDis,obsSpeed, decition->accelerator,ServiceCarStatus.mfCalAcc ,changingDangWei, &decition);
  1600. }else if(ServiceCarStatus.msysparam.mvehtype=="hapo"){
  1601. hapo_Adapter->getAdapterDeciton(gpsIns, gpsTraceNow, dSpeed, obsDis,obsSpeed, decition->accelerator,ServiceCarStatus.mfCalAcc ,changingDangWei, &decition);
  1602. }
  1603. else if(ServiceCarStatus.msysparam.mvehtype=="yuhesen"){
  1604. yuhesen_Adapter->getAdapterDeciton(gpsIns, gpsTraceNow, dSpeed, obsDis,obsSpeed, decition->accelerator,ServiceCarStatus.mfCalAcc ,changingDangWei, &decition);
  1605. }
  1606. }
  1607. std::vector<iv::Point2D> ivdecision_brain::getGpsTrace(iv::GPS_INS now_gps_ins, const std::vector<GPSData> gpsMapLine, int lastIndex, bool circleMode) {
  1608. vector<iv::Point2D> trace;
  1609. // int PathPoint = iv::decition::Compute00().getNearestPointIndex(now_gps_ins, gpsMapLine, lastGpsIndex, minDis, maxAngle);
  1610. /*if (PathPoint != -1)
  1611. lastGpsIndex = PathPoint;*/
  1612. if (gpsMapLine.size() > 600 && PathPoint >= 0) {
  1613. int aimIndex;
  1614. if(circleMode){
  1615. aimIndex=PathPoint+600;
  1616. }else{
  1617. aimIndex=min((PathPoint+600),(int)gpsMapLine.size());
  1618. }
  1619. for (int i = PathPoint; i < aimIndex; i++)
  1620. {
  1621. int index = i % gpsMapLine.size();
  1622. Point2D pt = Coordinate_Transfer((*gpsMapLine[index]).gps_x, (*gpsMapLine[index]).gps_y, now_gps_ins);
  1623. pt.x += offset_real * 0.032;
  1624. pt.v1 = (*gpsMapLine[index]).speed_mode;
  1625. pt.v2 = (*gpsMapLine[index]).mode2;
  1626. pt.roadMode=(*gpsMapLine[index]).roadMode;
  1627. if (gpsMapLine[index]->roadMode==3 && !hasZhuched)
  1628. {
  1629. readyZhucheMode = true;
  1630. zhuchePointNum = index;
  1631. }
  1632. if (gpsMapLine[index]->roadMode==3 && !hasZhuched)
  1633. {
  1634. readyZhucheMode = true;
  1635. zhuchePointNum = index;
  1636. }
  1637. //csvv7
  1638. if (gpsMapLine[index]->speed_mode==22 || gpsMapLine[index]->speed_mode==23)
  1639. {
  1640. readyParkMode = true;
  1641. finishPointNum = index;
  1642. }
  1643. // if (pt.v1 == 22 || pt.v1 == 23)
  1644. // {
  1645. // readyParkMode = true;
  1646. // finishPointNum = i;
  1647. // }
  1648. switch (pt.v1)
  1649. {
  1650. case 0:
  1651. pt.speed = 80;
  1652. break;
  1653. case 1:
  1654. pt.speed = 25;
  1655. break;
  1656. case 2:
  1657. pt.speed =25;
  1658. break;
  1659. case 3:
  1660. pt.speed = 20;
  1661. break;
  1662. case 4:
  1663. pt.speed =18;
  1664. break;
  1665. case 5:
  1666. pt.speed = 18;
  1667. break;
  1668. case 7:
  1669. pt.speed = 10;
  1670. break;
  1671. case 22:
  1672. pt.speed = 5;
  1673. break;
  1674. case 23:
  1675. pt.speed = 5;
  1676. break;
  1677. default:
  1678. break;
  1679. }
  1680. trace.push_back(pt);
  1681. }
  1682. }
  1683. return trace;
  1684. }
  1685. std::vector<iv::Point2D> ivdecision_brain::getGpsTraceOffset(std::vector<Point2D> gpsTrace, double offset) {
  1686. if (offset==0)
  1687. {
  1688. return gpsTrace;
  1689. }
  1690. std::vector<iv::Point2D> trace;
  1691. for (int j = 0; j < gpsTrace.size(); j++)
  1692. {
  1693. double sumx1 = 0, sumy1 = 0, count1 = 0;
  1694. double sumx2 = 0, sumy2 = 0, count2 = 0;
  1695. for (int k = max(0, j - 4); k <= j; k++)
  1696. {
  1697. count1 = count1 + 1;
  1698. sumx1 += gpsTrace[k].x;
  1699. sumy1 += gpsTrace[k].y;
  1700. }
  1701. for (int k = j; k <= min(gpsTrace.size() - 1, (size_t)(j + 4)); k++)
  1702. {
  1703. count2 = count2 + 1;
  1704. sumx2 += gpsTrace[k].x;
  1705. sumy2 += gpsTrace[k].y;
  1706. }
  1707. sumx1 /= count1; sumy1 /= count1;
  1708. sumx2 /= count2; sumy2 /= count2;
  1709. double anglevalue = atan2(sumy2 - sumy1, sumx2 - sumx1);
  1710. double carFrontx = gpsTrace[j].x;// -Form1.CarRear * Math.Cos(anglevalue);
  1711. double carFronty = gpsTrace[j].y;// -Form1.CarRear * Math.Sin(anglevalue);
  1712. double avoidLenth = abs(offset);
  1713. if (offset<0)
  1714. {
  1715. Point2D ptLeft(carFrontx + avoidLenth * cos(anglevalue + M_PI / 2),
  1716. carFronty + avoidLenth * sin(anglevalue + M_PI / 2));
  1717. ptLeft.speed = gpsTrace[j].speed;
  1718. ptLeft.v1 = gpsTrace[j].v1;
  1719. ptLeft.v2 = gpsTrace[j].v2;
  1720. trace.push_back(ptLeft);
  1721. }
  1722. else
  1723. {
  1724. Point2D ptRight(carFrontx + avoidLenth * cos(anglevalue - M_PI / 2),
  1725. carFronty + avoidLenth * sin(anglevalue - M_PI / 2));
  1726. ptRight.speed = gpsTrace[j].speed;
  1727. ptRight.v1 = gpsTrace[j].v1;
  1728. ptRight.v2 = gpsTrace[j].v2;
  1729. trace.push_back(ptRight);
  1730. }
  1731. }
  1732. return trace;
  1733. }
  1734. double ivdecision_brain::getAngle(std::vector<Point2D> gpsTrace,GPS_INS gpsIns,iv::decition::Decition decition) {
  1735. double angle=0;
  1736. if ( abs(minDis) < 20 && abs(maxAngle) < 100)
  1737. {
  1738. // angle = iv::decition::iv::decition::Compute00().getDecideAngle(gpsTrace, realspeed);
  1739. pid_Controller->getControlDecition(gpsIns, gpsTrace, -1, -1, -1, true, false, &decition);
  1740. angle= decition->wheel_angle;
  1741. }
  1742. return angle;
  1743. }
  1744. double ivdecision_brain::getSpeed(std::vector<Point2D> gpsTrace) {
  1745. double speed=0;
  1746. int speedPoint = iv::decition::Compute00().getSpeedPointIndex(gpsTrace, max(10.0, realspeed));
  1747. speed = gpsTrace[speedPoint].speed;
  1748. for (int i = 0; i < speedPoint; i++) {
  1749. speed = min(speed, gpsTrace[i].speed);
  1750. }
  1751. return speed;
  1752. }
  1753. //void ivdecision_brain::getEsrObs(std::vector<iv::ObstacleBasic> obsRadars) {
  1754. //
  1755. // if (!obsRadars.empty())
  1756. // {
  1757. // esrIndex = iv::decition::iv::decition::Compute00().getEsrIndex(gpsTrace, obsRadars);
  1758. //
  1759. // if (esrIndex != -1)
  1760. // {
  1761. // esrDistance = obsRadars[esrIndex].nomal_y;
  1762. //
  1763. //
  1764. //
  1765. // obsSpeed = obsRadars[esrIndex].speed_y;
  1766. //
  1767. // }
  1768. // else {
  1769. // esrDistance = -1;
  1770. // }
  1771. //
  1772. // }
  1773. // else
  1774. // {
  1775. // esrIndex = -1;
  1776. // esrDistance = -1;
  1777. // }
  1778. // if (esrDistance < 0) {
  1779. // ODS("\n------------------>ESR障碍物距离:%f\n", esrDistance);
  1780. // }
  1781. // else {
  1782. // ODS("\n------------------>ESR障碍物距离:%f ( %.05f , %.05f )\n", esrDistance, obsRadars[esrIndex].nomal_x, obsRadars[esrIndex].nomal_y);
  1783. // }
  1784. //
  1785. // ODS("\n------------------>ESR障碍物速度:%f\n", obsSpeed);
  1786. //}
  1787. void ivdecision_brain::getEsrObsDistance(std::vector<Point2D> gpsTrace, int roadNum) {
  1788. int esrPathpoint;
  1789. esrIndex = iv::decition::Compute00().getEsrIndex(gpsTrace, roadNum, &esrPathpoint,xiuzhengCs);
  1790. if (esrIndex != -1)
  1791. {
  1792. //优化
  1793. // double distance = 0.0;
  1794. // for(int i=0; i<esrPathpoint; ++i){
  1795. // distance+=DirectDistance(gpsTrace[i].x,gpsTrace[i].y,gpsTrace[i+1].x,gpsTrace[i+1].y);
  1796. // }
  1797. // esrDistance = distance - Esr_Y_Offset;
  1798. // if(esrDistance<=0){
  1799. // esrDistance=1;
  1800. // }
  1801. esrDistance = ServiceCarStatus.obs_radar[esrIndex].nomal_y;
  1802. obsSpeed = ServiceCarStatus.obs_radar[esrIndex].speed_y;
  1803. }
  1804. else {
  1805. esrDistance = -1;
  1806. }
  1807. }
  1808. void ivdecision_brain::getEsrObsDistanceAvoid() {
  1809. esrIndexAvoid = iv::decition::Compute00().getEsrIndexAvoid(gpsTraceAvoid);
  1810. if (esrIndexAvoid != -1)
  1811. {
  1812. esrDistanceAvoid = ServiceCarStatus.obs_radar[esrIndexAvoid].nomal_y;
  1813. obsSpeedAvoid = ServiceCarStatus.obs_radar[esrIndexAvoid].speed_y;
  1814. }
  1815. else {
  1816. esrDistanceAvoid = -1;
  1817. }
  1818. if (esrDistanceAvoid < 0) {
  1819. std::cout << "\nESR障碍物距离Avoid:%f\n" << esrDistanceAvoid << std::endl;
  1820. }
  1821. else {
  1822. std::cout << "\nESR障碍物距离Avoid:%f %d:( %.05f , %.05f ,%.05f )\n" << esrDistanceAvoid << esrIndexAvoid << ServiceCarStatus.obs_radar[esrIndexAvoid].nomal_x << ServiceCarStatus.obs_radar[esrIndexAvoid].nomal_y << std::endl;
  1823. }
  1824. std::cout << "\nESR障碍物速度Avoid:%f\n" << obsSpeedAvoid <<std::endl;
  1825. }
  1826. double ivdecision_brain::limitAngle(double speed, double angle) {
  1827. double preAngle = angle;
  1828. if (speed > 15)
  1829. {
  1830. if (preAngle > 350)
  1831. {
  1832. preAngle = 350;
  1833. }
  1834. if (preAngle < -350)
  1835. {
  1836. preAngle = -350;
  1837. }
  1838. }
  1839. if (speed > 22)
  1840. {
  1841. if (preAngle > 200)
  1842. {
  1843. preAngle = 200;
  1844. }
  1845. if (preAngle < -200)
  1846. {
  1847. preAngle = -200;
  1848. }
  1849. }
  1850. if (speed > 25)
  1851. {
  1852. if (preAngle > 150)
  1853. {
  1854. preAngle = 150;
  1855. }
  1856. if (preAngle < -150)
  1857. {
  1858. preAngle = -150;
  1859. }
  1860. }
  1861. if (speed > 30)
  1862. {
  1863. if (preAngle > 70)
  1864. {
  1865. preAngle = 70;
  1866. }
  1867. if (preAngle < -70)
  1868. {
  1869. preAngle = -70;
  1870. }
  1871. }
  1872. if (speed > 45) //20
  1873. {
  1874. if (preAngle > 15)
  1875. {
  1876. preAngle = 15;
  1877. }
  1878. if (preAngle < -15)
  1879. {
  1880. preAngle = -15;
  1881. }
  1882. }
  1883. return preAngle;
  1884. }
  1885. double ivdecision_brain::limitSpeed(double angle, double speed) {
  1886. if (abs(angle) > 500 && speed > 8) speed = 8;
  1887. else if (abs(angle) > 350 && speed > 14) speed = 14;
  1888. else if (abs(angle) > 200 && speed > 21) speed = 21;
  1889. else if (abs(angle) > 150 && speed > 24) speed = 24;
  1890. else if (abs(angle) > 60 && speed > 29) speed = 29;
  1891. else if (abs(angle) > 20 && speed > 34) speed = 34;
  1892. return max(0.0, speed);
  1893. }
  1894. bool ivdecision_brain::checkAvoidEnable(double avoidX, iv::LidarGridPtr lidarGridPtr,int roadNum) {
  1895. if ((obsDisVector[roadNum]>0 && obsDisVector[roadNum]<obsDisVector[roadNow]+ServiceCarStatus.msysparam.vehLenth)||
  1896. (obsDisVector[roadNum]>0 && obsDisVector[roadNum]<15))
  1897. {
  1898. return false;
  1899. }
  1900. if (roadNum-roadNow>1)
  1901. {
  1902. for (int i = roadNow+1; i < roadNum; i++)
  1903. {
  1904. if (obsDisVector[i] < 8 + (i-roadNow) * 2 && obsDisVector[i]>0) {
  1905. return false;
  1906. }
  1907. }
  1908. }
  1909. else if (roadNow-roadNum>1)
  1910. {
  1911. for (int i = roadNow-1; i >roadNum; i--)
  1912. {
  1913. if (obsDisVector[i] < 8 + (roadNow-i) * 2 && obsDisVector[i]>0) {
  1914. return false;
  1915. }
  1916. }
  1917. }
  1918. return true;
  1919. }
  1920. bool ivdecision_brain::checkReturnEnable(double avoidX, iv::LidarGridPtr lidarGridPtr, int roadNum) {
  1921. //lsn
  1922. if (obsDisVector[roadNum]>0 && obsDisVector[roadNum]<20)
  1923. {
  1924. return false;
  1925. }
  1926. if ((obsDisVector[roadNum]>0 && obsDisVector[roadNum]<50 && obsDisVector[roadNum]< obsDisVector[roadNow]) ||
  1927. (obsDisVector[roadNum]>0 && obsDisVector[roadNum]<50 && obsDisVector[roadNow]<0))
  1928. {
  1929. return false;
  1930. }
  1931. if (roadNum - roadNow>1)
  1932. {
  1933. for (int i = roadNow + 1; i < roadNum; i++)
  1934. {
  1935. if (obsDisVector[i] < 8 + (i-roadNow) * 2 && obsDisVector[i]>0) {
  1936. return false;
  1937. }
  1938. }
  1939. }
  1940. else if (roadNow - roadNum>1)
  1941. {
  1942. for (int i = roadNow - 1; i >roadNum; i--)
  1943. {
  1944. if (obsDisVector[i] < 8 + (roadNow-i) * 2 && obsDisVector[i]>0) {
  1945. return false;
  1946. }
  1947. }
  1948. }
  1949. return true;
  1950. }
  1951. void ivdecision_brain::getObsAvoid(iv::LidarGridPtr lidarGridPtr) {
  1952. if (lidarGridPtr == NULL)
  1953. {
  1954. lidarDistanceAvoid = lastLidarDisAvoid;
  1955. }
  1956. else {
  1957. obsPointAvoid = iv::decition::Compute00().getLidarObsPointAvoid(gpsTraceAvoid, lidarGridPtr,lidarDistanceAvoid);
  1958. lastLidarDisAvoid = lidarDistanceAvoid;
  1959. }
  1960. std::cout << "\nLidarAvoid距离:%f\n" << lidarDistanceAvoid << std::endl;
  1961. getEsrObsDistanceAvoid();
  1962. //lidarDistanceAvoid = -1; //20200103 apollo_fu
  1963. if (esrDistanceAvoid>0 && lidarDistanceAvoid > 0)
  1964. {
  1965. if (lidarDistanceAvoid >= esrDistanceAvoid)
  1966. {
  1967. obsDistanceAvoid = esrDistanceAvoid;
  1968. obsSpeedAvoid = ServiceCarStatus.obs_radar[esrIndexAvoid].speed_y;
  1969. }
  1970. else if (!ServiceCarStatus.obs_radar.empty())
  1971. {
  1972. obsDistanceAvoid = lidarDistanceAvoid;
  1973. obsSpeedAvoid = iv::decition::Compute00().getObsSpeed(obsPointAvoid, secSpeed);
  1974. std::cout << "\n计算obsSpeed:%f\n" << obsSpeedAvoid << std::endl;
  1975. }
  1976. else
  1977. {
  1978. obsDistanceAvoid = lidarDistanceAvoid;
  1979. obsSpeedAvoid = obsSpeedAvoid = 0 - secSpeed;;
  1980. std::cout << "\n毫米波无数据,计算obsSpeed:%f\n" << obsSpeedAvoid << std::endl;
  1981. }
  1982. }
  1983. else if (esrDistanceAvoid>0)
  1984. {
  1985. obsDistanceAvoid = esrDistanceAvoid;
  1986. obsSpeedAvoid = ServiceCarStatus.obs_radar[esrIndexAvoid].speed_y;
  1987. }
  1988. else if (lidarDistanceAvoid > 0)
  1989. {
  1990. obsDistanceAvoid = lidarDistanceAvoid;
  1991. obsSpeedAvoid = iv::decition::Compute00().getObsSpeed(obsPointAvoid, secSpeed);
  1992. std::cout << "\n计算obsSpeed:%f\n" << obsSpeedAvoid << std::endl;
  1993. }
  1994. else {
  1995. obsDistanceAvoid = esrDistanceAvoid;
  1996. obsSpeedAvoid = 0 - secSpeed;
  1997. }
  1998. std::cout << "\n最终得出的obsDistanceAvoid:%f\n" << obsDistanceAvoid << std::endl;
  1999. if (obsDistanceAvoid <0 && obsLostTimeAvoid<4)
  2000. {
  2001. obsDistanceAvoid = lastDistanceAvoid;
  2002. obsLostTimeAvoid++;
  2003. }
  2004. else
  2005. {
  2006. obsLostTimeAvoid = 0;
  2007. lastDistanceAvoid = -1;
  2008. }
  2009. if (obsDistanceAvoid>0)
  2010. {
  2011. lastDistanceAvoid = obsDistanceAvoid;
  2012. }
  2013. std::cout << "\nODSAvoid距离:%f\n" << obsDistanceAvoid << std::endl;
  2014. }
  2015. void ivdecision_brain::init() {
  2016. for (int i = 0; i < roadSum; i++)
  2017. {
  2018. lastEsrIdVector.push_back(-1);
  2019. lastEsrCountVector.push_back(0);
  2020. GPS_INS gps_ins;
  2021. gps_ins.gps_x = 0;
  2022. gps_ins.gps_y = 0;
  2023. startAvoidGpsInsVector.push_back(gps_ins);
  2024. avoidMinDistanceVector.push_back(0);
  2025. }
  2026. }
  2027. #include <QTime>
  2028. void ivdecision_brain::computeObsOnRoad(iv::LidarGridPtr lidarGridPtr, std::vector<Point2D> gpsTrace, int roadNum,
  2029. const std::vector<GPSData> gpsMapLine, std::vector<iv::Perception::PerceptionOutput> lidar_per) {
  2030. // QTime xTime;
  2031. // xTime.start();
  2032. // qDebug("time 0 is %d ",xTime.elapsed());
  2033. double obs,obsSd;
  2034. if (lidarGridPtr == NULL)
  2035. {
  2036. lidarDistance = lastLidarDis;
  2037. // lidarDistance = lastlidarDistance;
  2038. }
  2039. else {
  2040. obsPoint = iv::decition::Compute00().getLidarObsPoint(gpsTrace, lidarGridPtr);
  2041. float lidarXiuZheng=0;
  2042. if(!ServiceCarStatus.useMobileEye){
  2043. lidarXiuZheng=0-ServiceCarStatus.msysparam.frontGpsXiuzheng;
  2044. }
  2045. lidarDistance = obsPoint.y + lidarXiuZheng; //激光距离推到车头 gjw20191110 lidar
  2046. // lidarDistance=-1;
  2047. if (lidarDistance<0)
  2048. {
  2049. lidarDistance = -1;
  2050. }
  2051. lastLidarDis = lidarDistance;
  2052. }
  2053. // obsPredict start
  2054. if(ServiceCarStatus.useObsPredict){
  2055. float preObsDis=200;
  2056. if(!lidar_per.empty()){
  2057. preObsDis=PredictObsDistance( secSpeed, gpsTrace, lidar_per);
  2058. lastPreObsDistance=preObsDis;
  2059. }else{
  2060. preObsDis=lastPreObsDistance;
  2061. }
  2062. if(preObsDis<lidarDistance || lidarDistance==-1){
  2063. lidarDistance=preObsDis;
  2064. }
  2065. }
  2066. // obsPredict end
  2067. // qDebug("time 1 is %d ",xTime.elapsed());
  2068. // if(gpsMapLine[PathPoint]->roadMode==14||gpsMapLine[PathPoint]->roadMode==15){
  2069. // lidarDistance=-1;
  2070. // }
  2071. getEsrObsDistance(gpsTrace, roadNum);
  2072. double mobieye_ttc,mobieye_obsid,mobieye_speed,mobieye_distance;
  2073. double fveh_width = 2.0;
  2074. #ifdef USE_MOBIEYE_OBS
  2075. MobieyeInst.GetObsFromMobieye(&gpsTrace,mobieye_distance,mobieye_speed,mobieye_ttc,mobieye_obsid,fveh_width);
  2076. #endif
  2077. // qDebug("time 2 is %d ",xTime.elapsed());
  2078. // esrDistance=-1;
  2079. // if(PathPoint>2992 && PathPoint<4134){
  2080. // lidarDistance=-1;
  2081. // }
  2082. // if(PathPoint>10193 && PathPoint<10929){
  2083. // esrDistance=-1;
  2084. // }
  2085. if(lidarDistance<0){
  2086. lidarDistance=500;
  2087. }
  2088. #ifdef USE_MOBIEYE_OBS
  2089. esrDistance = mobieye_distance;
  2090. if(esrDistance>150){
  2091. esrDistance=500;
  2092. }
  2093. #else
  2094. if(esrDistance>30){
  2095. esrDistance=500;
  2096. }
  2097. #endif
  2098. if(esrDistance<0){
  2099. esrDistance=500;
  2100. }
  2101. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "激光雷达距离:" << lidarDistance << std::endl;
  2102. // if(esrDistance>30){
  2103. // esrDistance=-1;
  2104. // }
  2105. // if(esrDistance>=15 && esrDistance<=50&& ServiceCarStatus.mLidarS>0&&ServiceCarStatus.mLidarPer>0 ){
  2106. // if(abs(lidarDistance-esrDistance)>5){
  2107. // esrDistance=-1;
  2108. // }
  2109. // }
  2110. // if(esrDistance>=1&& esrDistance<=50&& ServiceCarStatus.mLidarS>0&&ServiceCarStatus.mLidarPer>0
  2111. // && gpsMapLine[PathPoint]->runMode == 1 ){
  2112. // if(abs(lidarDistance-esrDistance)>5){
  2113. // esrDistance=-1;
  2114. // }
  2115. // }
  2116. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "毫米波距离:" << esrDistance << std::endl;
  2117. myesrDistance = esrDistance;
  2118. if(lidarDistance==500){
  2119. lidarDistance=-1;
  2120. }
  2121. if(esrDistance==500){
  2122. esrDistance=-1;
  2123. }
  2124. ServiceCarStatus.mRadarObs = esrDistance;
  2125. ServiceCarStatus.mLidarObs = lidarDistance;
  2126. //zhuanwan pingbi haomibo
  2127. if(gpsTraceNow[0].v1==4||gpsTraceNow[0].v1==5){
  2128. esrDistance=-1;
  2129. }
  2130. if (esrDistance>0 && lidarDistance > 0)
  2131. {
  2132. if (lidarDistance >= esrDistance)
  2133. {
  2134. #ifdef USE_MOBIEYE_OBS
  2135. obs = esrDistance;
  2136. obsSd = mobieye_speed;
  2137. #else
  2138. // obsDistance = esrDistance;
  2139. obs = esrDistance;
  2140. // obsSpeed = ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2141. obsSd=ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2142. #endif
  2143. }
  2144. else if (!ServiceCarStatus.obs_radar.empty())
  2145. {
  2146. // obsDistance = lidarDistance;
  2147. obs = lidarDistance;
  2148. // obsSpeed = iv::decition::Compute00().getObsSpeed(obsPoint, secSpeed);
  2149. obsSd = iv::decition::Compute00().getObsSpeed(obsPoint, secSpeed);
  2150. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "计算obsSpeed:" << obsSpeed << std::endl;
  2151. }
  2152. else
  2153. {
  2154. // obsDistance = lidarDistance;
  2155. obs=lidarDistance;
  2156. // obsSpeed = 0 - secSpeed;
  2157. obsSd = 0 -secSpeed;
  2158. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "毫米波无数据,计算obsSpeed:" << obsSpeed << std::endl;
  2159. }
  2160. }
  2161. else if (esrDistance>0)
  2162. {
  2163. // obsDistance = esrDistance;
  2164. // obsSpeed = ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2165. #ifdef USE_MOBIEYE_OBS
  2166. obs = esrDistance;
  2167. obsSd = mobieye_speed;
  2168. #else
  2169. obs = esrDistance;
  2170. obsSd = ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2171. #endif
  2172. }
  2173. else if (lidarDistance > 0)
  2174. {
  2175. // obsDistance = lidarDistance;
  2176. // obsSpeed = iv::decition::Compute00().getObsSpeed(obsPoint, secSpeed);
  2177. obs = lidarDistance;
  2178. obsSd = iv::decition::Compute00().getObsSpeed(obsPoint, secSpeed);
  2179. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "计算obsSpeed:" << obsSpeed << std::endl;
  2180. }
  2181. else {
  2182. // obsDistance = esrDistance;
  2183. // obsSpeed = 0 - secSpeed;
  2184. obs = esrDistance;
  2185. obsSd = 0 - secSpeed;
  2186. }
  2187. if(roadNum==roadNow){
  2188. obsDistance=obs;
  2189. obsSpeed=obsSd;
  2190. }
  2191. // if (obsDistance <0 && obsLostTime<4)
  2192. // {
  2193. // obsDistance = lastDistance;
  2194. // obsLostTime++;
  2195. // }
  2196. // else
  2197. // {
  2198. // obsLostTime = 0;
  2199. // lastDistance = -1;
  2200. // }
  2201. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "最终得出的obsDistance:" << obsDistance << std::endl;
  2202. ServiceCarStatus.mObs = obsDistance;
  2203. if(ServiceCarStatus.mObs>100){
  2204. ServiceCarStatus.mObs =-1;
  2205. }
  2206. if (obsDistance>0)
  2207. {
  2208. lastDistance = obsDistance;
  2209. }
  2210. //lsn
  2211. if(obs<0){
  2212. obsDisVector[roadNum]=500;
  2213. }else{
  2214. obsDisVector[roadNum]=obs;
  2215. }
  2216. givlog->debug("obs_distance","obs: %f, lidar_obs: %f, Radar_obs: %f, lidar_obs_x: %f, lidar_obs_y: %f",
  2217. ServiceCarStatus.mObs, ServiceCarStatus.mLidarObs,
  2218. ServiceCarStatus.mRadarObs,obsPoint.x,lidarDistance);
  2219. // qDebug("time 3 is %d ",xTime.elapsed());
  2220. }
  2221. //1220
  2222. void ivdecision_brain::computeRearObsOnRoad(iv::LidarGridPtr lidarGridPtr, std::vector<Point2D> gpsTrace, int roadNum,
  2223. const std::vector<GPSData> gpsMapLine) {
  2224. double obs,obsSd;
  2225. if(!ServiceCarStatus.obs_rear_radar.empty()){
  2226. getRearEsrObsDistance(gpsTrace, roadNum);
  2227. }
  2228. if (lidarGridPtr == NULL)
  2229. {
  2230. lidarDistance = lastLidarDis;
  2231. // lidarDistance = lastlidarDistance;
  2232. }
  2233. else {
  2234. obsPoint = iv::decition::Compute00().getLidarRearObsPoint(gpsTrace, lidarGridPtr);
  2235. float lidarXiuZheng=0;
  2236. if(!ServiceCarStatus.useMobileEye){
  2237. lidarXiuZheng = ServiceCarStatus.msysparam.rearGpsXiuzheng;
  2238. }
  2239. if(abs(obsPoint.y)>lidarXiuZheng)
  2240. lidarDistance = abs(obsPoint.y)-lidarXiuZheng; //激光距离推到车头 1220
  2241. // lidarDistance=-1;
  2242. if (lidarDistance<0)
  2243. {
  2244. lidarDistance = -1;
  2245. }
  2246. lastLidarDis = lidarDistance;
  2247. }
  2248. // if(gpsMapLine[PathPoint]->roadMode==14||gpsMapLine[PathPoint]->roadMode==15){
  2249. // lidarDistance=-1;
  2250. // }
  2251. // getEsrObsDistance(gpsTrace, roadNum);
  2252. esrDistance=-1;
  2253. // if(PathPoint>2992 && PathPoint<4134){
  2254. // lidarDistance=-1;
  2255. // }
  2256. // if(PathPoint>10193 && PathPoint<10929){
  2257. // esrDistance=-1;
  2258. // }
  2259. if(lidarDistance<0){
  2260. lidarDistance=500;
  2261. }
  2262. if(esrDistance<0){
  2263. esrDistance=500;
  2264. }
  2265. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "激光雷达距离:" << lidarDistance << std::endl;
  2266. // if(esrDistance>30){
  2267. // esrDistance=-1;
  2268. // }
  2269. // if(esrDistance>=15 && esrDistance<=50&& ServiceCarStatus.mLidarS>0&&ServiceCarStatus.mLidarPer>0 ){
  2270. // if(abs(lidarDistance-esrDistance)>5){
  2271. // esrDistance=-1;
  2272. // }
  2273. // }
  2274. // if(esrDistance>=1&& esrDistance<=50&& ServiceCarStatus.mLidarS>0&&ServiceCarStatus.mLidarPer>0
  2275. // && gpsMapLine[PathPoint]->runMode == 1 ){
  2276. // if(abs(lidarDistance-esrDistance)>5){
  2277. // esrDistance=-1;
  2278. // }
  2279. // }
  2280. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "毫米波距离:" << esrDistance << std::endl;
  2281. myesrDistance = esrDistance;
  2282. if(lidarDistance==500){
  2283. lidarDistance=-1;
  2284. }
  2285. if(esrDistance==500){
  2286. esrDistance=-1;
  2287. }
  2288. ServiceCarStatus.mRadarObs = esrDistance;
  2289. ServiceCarStatus.mLidarObs = lidarDistance;
  2290. //zhuanwan pingbi haomibo
  2291. if(gpsTraceNow[0].v1==4||gpsTraceNow[0].v1==5){
  2292. esrDistance=-1;
  2293. }
  2294. if (esrDistance>0 && lidarDistance > 0)
  2295. {
  2296. if (lidarDistance >= esrDistance)
  2297. {
  2298. // obsDistance = esrDistance;
  2299. obs = esrDistance;
  2300. // obsSpeed = ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2301. obsSd=ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2302. }
  2303. else if (!ServiceCarStatus.obs_radar.empty())
  2304. {
  2305. // obsDistance = lidarDistance;
  2306. obs = lidarDistance;
  2307. // obsSpeed = iv::decition::Compute00().getObsSpeed(obsPoint, secSpeed);
  2308. obsSd = iv::decition::Compute00().getObsSpeed(obsPoint, secSpeed);
  2309. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "计算obsSpeed:" << obsSpeed << std::endl;
  2310. }
  2311. else
  2312. {
  2313. // obsDistance = lidarDistance;
  2314. obs=lidarDistance;
  2315. // obsSpeed = 0 - secSpeed;
  2316. obsSd = 0 -secSpeed;
  2317. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "毫米波无数据,计算obsSpeed:" << obsSpeed << std::endl;
  2318. }
  2319. }
  2320. else if (esrDistance>0)
  2321. {
  2322. // obsDistance = esrDistance;
  2323. // obsSpeed = ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2324. obs = esrDistance;
  2325. obsSd = ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2326. }
  2327. else if (lidarDistance > 0)
  2328. {
  2329. // obsDistance = lidarDistance;
  2330. // obsSpeed = iv::decition::Compute00().getObsSpeed(obsPoint, secSpeed);
  2331. obs = lidarDistance;
  2332. obsSd = iv::decition::Compute00().getObsSpeed(obsPoint, secSpeed);
  2333. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "计算obsSpeed:" << obsSpeed << std::endl;
  2334. }
  2335. else {
  2336. // obsDistance = esrDistance;
  2337. // obsSpeed = 0 - secSpeed;
  2338. obs = esrDistance;
  2339. obsSd = 0 - secSpeed;
  2340. }
  2341. if(roadNum==roadNow){
  2342. obsDistance=obs;
  2343. obsSpeed=obsSd;
  2344. }
  2345. if (obsDistance <0 && obsLostTime<4)
  2346. {
  2347. obsDistance = lastDistance;
  2348. obsLostTime++;
  2349. }
  2350. else
  2351. {
  2352. obsLostTime = 0;
  2353. lastDistance = -1;
  2354. }
  2355. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "最终得出的obsDistance:" << obsDistance << std::endl;
  2356. ServiceCarStatus.mObs = obsDistance;
  2357. if(ServiceCarStatus.mObs>100){
  2358. ServiceCarStatus.mObs =-1;
  2359. }
  2360. if (obsDistance>0)
  2361. {
  2362. lastDistance = obsDistance;
  2363. }
  2364. //lsn
  2365. if(obs<0){
  2366. obsDisVector[roadNum]=500;
  2367. }else{
  2368. obsDisVector[roadNum]=obs;
  2369. }
  2370. }
  2371. void ivdecision_brain::predictObsOnRoad(std::vector<iv::Perception::PerceptionOutput> lidar_per,std::vector<Point2D> gpsTrace,double realSpeed){
  2372. double preObsDis;
  2373. if(!lidar_per.empty()){
  2374. preObsDis=PredictObsDistance( realSpeed, gpsTrace, lidar_per);
  2375. lastPreObsDistance=preObsDis;
  2376. }else{
  2377. preObsDis=lastPreObsDistance;
  2378. }
  2379. if(preObsDis<obsDistance){
  2380. obsDistance=preObsDis;
  2381. lastDistance=obsDistance;
  2382. }
  2383. }
  2384. int ivdecision_brain::chooseAvoidRoad(iv::LidarGridPtr lidarGridPtr, GPS_INS now_gps_ins, const std::vector<GPSData> gpsMapLine,std::vector<iv::Perception::PerceptionOutput> lidar_per) {
  2385. roadPre = -1;
  2386. // if (roadNow<roadOri)
  2387. // {
  2388. // for (int i = 0; i < roadNow; i++)
  2389. // {
  2390. // gpsTraceAvoid.clear();
  2391. // // gpsTraceAvoid = getGpsTrace(now_gps_ins, gmapsR[int(abs(roadWidth * 2)*(roadOri-i))], lastGpsIndex);
  2392. // avoidX = (roadWidth)*(roadOri - i);
  2393. // gpsTraceAvoid = getGpsTraceOffset(gpsTraceOri, avoidX);
  2394. // // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, roadNow + i);
  2395. // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, i,gpsMapLine,lidar_per);
  2396. // }
  2397. // for (int i = roadOri+1; i < roadSum; i++)
  2398. // {
  2399. // gpsTraceAvoid.clear();
  2400. // // gpsTraceAvoid = getGpsTrace(now_gps_ins, gmapsL[int(abs(roadWidth * 2)*(i - roadOri))], lastGpsIndex);
  2401. // avoidX = (roadWidth)*(roadOri - i);
  2402. // gpsTraceAvoid = getGpsTraceOffset(gpsTraceOri, avoidX);
  2403. // // bsOnRoad(lidarGridPtr, gpsTraceAvoid, roadNow + i);
  2404. // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, i,gpsMapLine,lidar_per);
  2405. // }
  2406. // }
  2407. // else if (roadNow>roadOri)
  2408. // {
  2409. // for (int i = 0; i < roadOri; i++)
  2410. // {
  2411. // gpsTraceAvoid.clear();
  2412. // // gpsTraceAvoid = getGpsTrace(now_gps_ins, gmapsR[int(abs(roadWidth * 2)*(roadOri - i))], lastGpsIndex);
  2413. // avoidX = (roadWidth)*(roadOri - i);
  2414. // gpsTraceAvoid = getGpsTraceOffset(gpsTraceOri, avoidX);
  2415. // // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, roadNow + i);
  2416. // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, i,gpsMapLine,lidar_per);
  2417. // }
  2418. // for (int i = roadNow + 1; i < roadSum; i++)
  2419. // {
  2420. // gpsTraceAvoid.clear();
  2421. // // gpsTraceAvoid = getGpsTrace(now_gps_ins, gmapsL[int(abs(roadWidth * 2)*(i - roadOri))], lastGpsIndex);
  2422. // avoidX = (roadWidth)*(roadOri - i);
  2423. // gpsTraceAvoid = getGpsTraceOffset(gpsTraceOri, avoidX);
  2424. // // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, roadNow + i);
  2425. // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, i,gpsMapLine,lidar_per);
  2426. // }
  2427. // }
  2428. // else
  2429. // {
  2430. // for (int i = 0; i < roadOri; i++)
  2431. // {
  2432. // gpsTraceAvoid.clear();
  2433. // // gpsTraceAvoid = getGpsTrace(now_gps_ins, gmapsR[int(abs(roadWidth * 2)*(roadOri - i))], lastGpsIndex);
  2434. // avoidX = (roadWidth)*(roadOri - i);
  2435. // gpsTraceAvoid = getGpsTraceOffset(gpsTraceOri, avoidX);
  2436. // // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, roadNow + i);
  2437. // computeObsOnRoad(lidarGridPtr, gpsTraceNow, roadNow,gpsMapLine,lidar_per);
  2438. // }
  2439. // for (int i = roadOri + 1; i < roadSum; i++)
  2440. // {
  2441. // gpsTraceAvoid.clear();
  2442. // // gpsTraceAvoid = getGpsTrace(now_gps_ins, gmapsL[int(abs(roadWidth * 2)*(i - roadOri))], lastGpsIndex);
  2443. // avoidX = (roadWidth)*(roadOri - i);
  2444. // gpsTraceAvoid = getGpsTraceOffset(gpsTraceOri, avoidX);
  2445. // // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, roadNow + i);
  2446. // computeObsOnRoad(lidarGridPtr, gpsTraceNow, roadNow,gpsMapLine,lidar_per);
  2447. // }
  2448. // }
  2449. for (int i = 0; i < roadSum; i++)
  2450. {
  2451. gpsTraceAvoid.clear();
  2452. // gpsTraceAvoid = getGpsTrace(now_gps_ins, gmapsL[int(abs(roadWidth * 2)*(i - roadOri))], lastGpsIndex);
  2453. // avoidX = (roadWidth)*(roadOri - i);
  2454. avoidX=computeAvoidX(i,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  2455. gpsTraceAvoid = getGpsTraceOffset(gpsTraceOri, avoidX);
  2456. // computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, roadNow + i);
  2457. computeObsOnRoad(lidarGridPtr, gpsTraceAvoid, i,gpsMapLine,lidar_per);
  2458. }
  2459. if (lidarGridPtr!=NULL)
  2460. {
  2461. hasCheckedAvoidLidar = true;
  2462. }
  2463. for(int i=0; i<roadSum;i++){
  2464. std::cout<<"\odsjuli====================:\n"<<i<<"chedaojuli:"<<obsDisVector[i]<<endl;
  2465. }
  2466. checkAvoidObsTimes++;
  2467. if (checkAvoidObsTimes<4 || hasCheckedAvoidLidar==false)
  2468. {
  2469. return - 1;
  2470. }
  2471. for (int i = 1; i < roadSum; i++)
  2472. {
  2473. if (roadNow + i < roadSum) {
  2474. // avoidX = (roadOri-roadNow-i)*roadWidth;
  2475. avoidX=computeAvoidX(roadNow+i,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  2476. if (checkAvoidEnable(avoidX, lidarGridPtr, roadNow+i))
  2477. {
  2478. /*if (roadNow==roadOri)
  2479. {
  2480. avoidRunDistance = obsDisVector[roadNow] + ServiceCarStatus.msysparam.vehLenth;
  2481. startAvoid_gps_ins = now_gps_ins;
  2482. } */
  2483. avoidMinDistanceVector[roadNow]= obsDisVector[roadNow] + ServiceCarStatus.msysparam.vehLenth;
  2484. startAvoidGpsInsVector[roadNow] = now_gps_ins;
  2485. roadPre = roadNow + i;
  2486. return roadPre;
  2487. }
  2488. }
  2489. if (roadNow - i >= 0)
  2490. {
  2491. // avoidX = (roadOri - roadNow+i)*roadWidth;
  2492. avoidX=computeAvoidX(roadNow-i,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  2493. if (checkAvoidEnable(avoidX, lidarGridPtr, roadNow - i))
  2494. {
  2495. /*if (roadNow == roadOri)
  2496. {
  2497. avoidRunDistance = obsDisVector[roadNow] + ServiceCarStatus.msysparam.vehLenth;
  2498. startAvoid_gps_ins = now_gps_ins;
  2499. }*/
  2500. avoidMinDistanceVector[roadNow] = obsDisVector[roadNow] + ServiceCarStatus.msysparam.vehLenth;
  2501. startAvoidGpsInsVector[roadNow] = now_gps_ins;
  2502. roadPre = roadNow - i;
  2503. return roadPre;
  2504. }
  2505. }
  2506. }
  2507. return roadPre;
  2508. }
  2509. int ivdecision_brain::chooseBackRoad(iv::LidarGridPtr lidarGridPtr, GPS_INS now_gps_ins, std::vector<GPSData> gpsMapLine,std::vector<iv::Perception::PerceptionOutput> lidar_per) {
  2510. roadPre = -1;
  2511. // computeObsOnRoad(lidarGridPtr, gpsTraceNow, roadNow,gpsMapLine,lidar_per);
  2512. // if (roadNow>=roadOri+1)
  2513. // {
  2514. // for (int i = roadOri+1; i < roadNow; i++)
  2515. // {
  2516. // gpsTraceBack.clear();
  2517. // // gpsTraceBack = getGpsTrace(now_gps_ins, gmapsL[int(abs(roadWidth * 2)*(i-roadOri))], lastGpsIndex);
  2518. // avoidX = (roadWidth)*(roadOri - i);
  2519. // gpsTraceBack = getGpsTraceOffset(gpsTraceOri, avoidX);
  2520. // computeObsOnRoad(lidarGridPtr, gpsTraceNow, roadNow,gpsMapLine,lidar_per);
  2521. // }
  2522. // }
  2523. // else if (roadNow <= roadOri - 1) {
  2524. // for (int i = roadOri - 1; i > roadNow; i--)
  2525. // {
  2526. // gpsTraceBack.clear();
  2527. // // gpsTraceBack = getGpsTrace(now_gps_ins, gmapsR[int(abs(roadWidth * 2)*(roadOri-i))], lastGpsIndex);
  2528. // avoidX = (roadWidth)*(roadOri - i);
  2529. // gpsTraceBack = getGpsTraceOffset(gpsTraceOri, avoidX);
  2530. // computeObsOnRoad(lidarGridPtr, gpsTraceNow, roadNow,gpsMapLine,lidar_per);
  2531. // }
  2532. // }
  2533. for (int i = 0; i <roadSum; i++)
  2534. {
  2535. gpsTraceBack.clear();
  2536. // gpsTraceBack = getGpsTrace(now_gps_ins, gmapsR[int(abs(roadWidth * 2)*(roadOri-i))], lastGpsIndex);
  2537. // avoidX = (roadWidth)*(roadOri - i);
  2538. avoidX=computeAvoidX(i,roadOri,gpsMapLine[PathPoint],ServiceCarStatus.msysparam.vehWidth);
  2539. gpsTraceBack = getGpsTraceOffset(gpsTraceOri, avoidX);
  2540. computeObsOnRoad(lidarGridPtr, gpsTraceBack, i,gpsMapLine,lidar_per);
  2541. }
  2542. if (lidarGridPtr != NULL)
  2543. {
  2544. hasCheckedBackLidar = true;
  2545. }
  2546. checkBackObsTimes++;
  2547. if (checkBackObsTimes<4 || hasCheckedBackLidar == false)
  2548. {
  2549. return -1;
  2550. }
  2551. //if ((GetDistance(now_gps_ins, startAvoid_gps_ins)>avoidRunDistance)&&
  2552. //(checkReturnEnable(avoidX, lidarGridPtr,roadOri)))
  2553. if ((GetDistance(now_gps_ins, startAvoidGpsInsVector[roadOri])>max(avoidMinDistanceVector[roadOri],30.0)) &&
  2554. (checkReturnEnable(avoidX, lidarGridPtr, roadOri)))
  2555. {
  2556. roadPre = roadOri;
  2557. return roadPre;
  2558. }
  2559. if (roadNow-roadOri>1)
  2560. {
  2561. for (int i = roadOri + 1;i < roadNow;i++) {
  2562. if (checkReturnEnable(avoidX, lidarGridPtr, i)&&
  2563. (GetDistance(now_gps_ins, startAvoidGpsInsVector[i])> avoidMinDistanceVector[i])&&
  2564. (GetDistance(now_gps_ins, startAvoidGpsInsVector[i])> 30.0))
  2565. {
  2566. roadPre = i;
  2567. return roadPre;
  2568. }
  2569. }
  2570. }
  2571. else if (roadNow <roadOri-1)
  2572. {
  2573. for (int i = roadOri - 1;i > roadNow;i--) {
  2574. if (checkReturnEnable(avoidX, lidarGridPtr, i)&&
  2575. (GetDistance(now_gps_ins, startAvoidGpsInsVector[i])>avoidMinDistanceVector[i])&&
  2576. (GetDistance(now_gps_ins, startAvoidGpsInsVector[i])> 30.0))
  2577. {
  2578. roadPre = i;
  2579. return roadPre;
  2580. }
  2581. }
  2582. }
  2583. return roadPre;
  2584. }
  2585. double ivdecision_brain::trumpet() {
  2586. if (trumpetFirstCount)
  2587. {
  2588. trumpetFirstCount = false;
  2589. trumpetLastTime= GetTickCount();
  2590. trumpetTimeSpan = 0.0;
  2591. }
  2592. else
  2593. {
  2594. trumpetStartTime= GetTickCount();
  2595. trumpetTimeSpan += trumpetStartTime - trumpetLastTime;
  2596. trumpetLastTime = trumpetStartTime;
  2597. }
  2598. return trumpetTimeSpan;
  2599. }
  2600. double ivdecision_brain::transferP() {
  2601. if (transferFirstCount)
  2602. {
  2603. transferFirstCount = false;
  2604. transferLastTime= GetTickCount();
  2605. transferTimeSpan = 0.0;
  2606. }
  2607. else
  2608. {
  2609. transferStartTime= GetTickCount();
  2610. transferTimeSpan += transferStartTime - transferLastTime;
  2611. transferLastTime = transferStartTime;
  2612. }
  2613. return transferTimeSpan;
  2614. }
  2615. void ivdecision_brain::handBrakePark(iv::decition::Decition decition, long duringTime, GPS_INS now_gps_ins) {
  2616. if (abs(now_gps_ins.speed)>0.1)
  2617. {
  2618. decition->accelerator = 0;
  2619. decition->brake = 20;
  2620. decition->wheel_angle = 0;
  2621. }
  2622. else
  2623. {
  2624. decition->accelerator = 0;
  2625. decition->brake = 20;
  2626. decition->wheel_angle = 0;
  2627. handPark = true;
  2628. handParkTime = duringTime;
  2629. }
  2630. }
  2631. void ivdecision_brain::getMapBeside(std::vector<iv::GPSData> navigation_data, iv::GPS_INS now_gps_ins) {
  2632. gmapsL.clear();
  2633. gmapsR.clear();
  2634. for (int i = 0; i < 31; i++)
  2635. {
  2636. std::vector<iv::GPSData> gpsMapLineBeside;
  2637. // gpsMapLineBeside = iv::decition::ComputeUnit().getBesideGpsMapLine(*ServiceCarStatus.location, navigation_data, -0.5*i);
  2638. gpsMapLineBeside = iv::decition::Compute00().getBesideGpsMapLine(now_gps_ins, navigation_data, -0.5*i);
  2639. gmapsL.push_back(gpsMapLineBeside);
  2640. }
  2641. for (int i = 0; i < 31; i++)
  2642. {
  2643. std::vector<iv::GPSData> gpsMapLineBeside;
  2644. // gpsMapLineBeside = iv::decition::ComputeUnit().getBesideGpsMapLine(*ServiceCarStatus.location, navigation_data, 0.5*i);
  2645. gpsMapLineBeside = iv::decition::Compute00().getBesideGpsMapLine(now_gps_ins, navigation_data, 0.5*i);
  2646. gmapsR.push_back(gpsMapLineBeside);
  2647. }
  2648. }
  2649. bool ivdecision_brain::checkChaoCheBack(iv::LidarGridPtr lidarGridPtr) {
  2650. if (lidarGridPtr == NULL)
  2651. {
  2652. return false;
  2653. // lidarDistance = lastlidarDistance;
  2654. }
  2655. else {
  2656. obsPoint = iv::decition::Compute00().getLidarObsPoint(gpsTraceOri, lidarGridPtr);
  2657. double lidarDistance = obsPoint.y - 2.5; //激光距离推到车头
  2658. // ODS("\n超车雷达距离:%f\n", lidarDistance);
  2659. if (lidarDistance >-20 && lidarDistance<35)
  2660. {
  2661. checkChaoCheBackCounts = 0;
  2662. return false;
  2663. }
  2664. else {
  2665. checkChaoCheBackCounts++;
  2666. }
  2667. if (checkChaoCheBackCounts>2) {
  2668. checkChaoCheBackCounts = 0;
  2669. return true;
  2670. }
  2671. }
  2672. return false;
  2673. }
  2674. void ivdecision_brain::updateGroupDate(GPS_INS now_gps_ins,float realspeed,float theta,float s){
  2675. Point2D pt = Coordinate_Transfer( now_gps_ins.gps_x, now_gps_ins.gps_y, group_ori_gps);
  2676. ServiceCarStatus.group_x_local=pt.x;
  2677. // ServiceCarStatus.group_y_local=pt.y;
  2678. ServiceCarStatus.group_y_local=s;
  2679. if(realspeed<0.36){
  2680. ServiceCarStatus.group_velx_local=0;
  2681. ServiceCarStatus.group_vely_local=0;
  2682. }else{
  2683. ServiceCarStatus.group_velx_local=realspeed*sin(theta)/3.6;
  2684. ServiceCarStatus.group_vely_local=realspeed*cos(theta)/3.6;
  2685. }
  2686. ServiceCarStatus.group_pathpoint=PathPoint;
  2687. }
  2688. float ivdecision_brain::ComputeTrafficLightSpeed(int traffic_light_color, int traffic_light_time, const std::vector<GPSData> gpsMapLine,int traffic_light_pathpoint,
  2689. int pathpoint,float secSpeed,float dSpeed){
  2690. float traffic_speed=200;
  2691. float traffic_dis=0;
  2692. float passTime;
  2693. float passSpeed;
  2694. bool passEnable=false;
  2695. if(abs(secSpeed)<0.1){
  2696. secSpeed=0;
  2697. }
  2698. if(pathpoint <= traffic_light_pathpoint){
  2699. for(int i=pathpoint;i<traffic_light_pathpoint;i++){
  2700. traffic_dis +=GetDistance(*gpsMapLine[i],*gpsMapLine[i+1]);
  2701. }
  2702. }else{
  2703. for(int i=pathpoint;i<gpsMapLine.size()-1;i++){
  2704. traffic_dis +=GetDistance(*gpsMapLine[i],*gpsMapLine[i+1]);
  2705. }
  2706. for(int i=0;i<traffic_light_pathpoint;i++){
  2707. traffic_dis+=GetDistance(*gpsMapLine[i],*gpsMapLine[i+1]);
  2708. }
  2709. }
  2710. // if(traffic_light_color != 0)
  2711. // {
  2712. // int a = 3;
  2713. // }
  2714. if(traffic_light_color==0 && traffic_dis<10){
  2715. traffic_speed=0;
  2716. }
  2717. // else //20200108
  2718. // {
  2719. // traffic_speed=10;
  2720. // }
  2721. return traffic_speed;
  2722. passSpeed = min((float)(dSpeed/3.6),secSpeed);
  2723. passTime = traffic_dis/(dSpeed/3.6);
  2724. switch(traffic_light_color){
  2725. case 0:
  2726. if(passTime>traffic_light_time+1 && traffic_dis>10){
  2727. passEnable=true;
  2728. }else{
  2729. passEnable=false;
  2730. }
  2731. break;
  2732. case 1:
  2733. if(passTime<traffic_light_time-1 && traffic_dis<10){
  2734. passEnable=true;
  2735. }else{
  2736. passEnable = false;
  2737. }
  2738. break;
  2739. case 2:
  2740. if(passTime<traffic_light_time){
  2741. passEnable= true;
  2742. }else{
  2743. passEnable=false;
  2744. }
  2745. break;
  2746. default:
  2747. break;
  2748. }
  2749. if(!passEnable){
  2750. if(traffic_dis<5){
  2751. traffic_speed=0;
  2752. }else if(traffic_dis<10){
  2753. traffic_speed=5;
  2754. }else if(traffic_dis<20){
  2755. traffic_speed=15;
  2756. }else if(traffic_dis<30){
  2757. traffic_speed=25;
  2758. }else if(traffic_dis<50){
  2759. traffic_speed=30;
  2760. }
  2761. }
  2762. return traffic_speed;
  2763. }
  2764. void ivdecision_brain::computeObsOnRoadByFrenet(iv::LidarGridPtr lidarGridPtr, const std::vector<Point2D>& gpsTrace, double & obs, const std::vector<iv::GPSData>& gpsMap,int pathpoint,GPS_INS nowGps)
  2765. {
  2766. // Point2D obsCombinePoint = Point2D(-1,-1);
  2767. iv::decition::FrenetPoint car_now_frenet_point = iv::decition::FrenetPlanner::getFrenetfromXY(0,0,gpsTrace,gpsMap,pathpoint,nowGps);
  2768. double obsSd;
  2769. if (lidarGridPtr == NULL)
  2770. {
  2771. lidarDistance = lastLidarDis;
  2772. // lidarDistance = lastlidarDistance;
  2773. }
  2774. else {
  2775. obsPoint = iv::decition::Compute00().getLidarObsPoint(gpsTrace, lidarGridPtr);
  2776. // lidarDistance = obsPoint.y-2.5; //激光距离推到车头
  2777. iv::decition::FrenetPoint lidarFPointTmp = iv::decition::FrenetPlanner::getFrenetfromXY(this->obsPoint.x,this->obsPoint.y,gpsTrace,gpsMap,pathpoint,nowGps);
  2778. lidarDistance = lidarFPointTmp.s - car_now_frenet_point.s - 2.5;
  2779. // lidarDistance=-1;
  2780. if (lidarDistance<0)
  2781. {
  2782. lidarDistance = -1;
  2783. }
  2784. lastLidarDis = lidarDistance;
  2785. }
  2786. FrenetPoint esr_obs_frenet_point;
  2787. getEsrObsDistanceByFrenet(gpsTrace, car_now_frenet_point,esr_obs_frenet_point,gpsMap,pathpoint,nowGps);
  2788. if(lidarDistance<0){
  2789. lidarDistance=500;
  2790. }
  2791. if(esrDistance<0){
  2792. esrDistance=500;
  2793. }
  2794. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "激光雷达距离:" << lidarDistance << std::endl;
  2795. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "毫米波距离:" << esrDistance << std::endl;
  2796. myesrDistance = esrDistance;
  2797. if(lidarDistance==500){
  2798. lidarDistance=-1;
  2799. }
  2800. if(esrDistance==500){
  2801. esrDistance=-1;
  2802. }
  2803. ServiceCarStatus.mRadarObs = esrDistance;
  2804. ServiceCarStatus.mLidarObs = lidarDistance;
  2805. // //zhuanwan pingbi haomibo
  2806. // if(gpsTraceNow[0].v1==4||gpsTraceNow[0].v1==5){
  2807. // esrDistance=-1;
  2808. // }
  2809. if (esrDistance>0 && lidarDistance > 0)
  2810. {
  2811. if (lidarDistance >= esrDistance)
  2812. {
  2813. obs = esrDistance;
  2814. // obsSd=ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2815. obsSd = obsSpeed;
  2816. //障碍物信息使用毫米波采集的。其位置坐标加上偏移量,转换成相对于惯导的位置,即转换成车辆坐标系下的位置坐标。
  2817. // obsCombinePoint = Point2D(ServiceCarStatus.obs_radar[esrIndex].nomal_x+Esr_Offset,ServiceCarStatus.obs_radar[esrIndex].nomal_y+Esr_Y_Offset);
  2818. }
  2819. else if (!ServiceCarStatus.obs_radar.empty())
  2820. {
  2821. obs = lidarDistance;
  2822. // obsCombinePoint = obsPoint;
  2823. // obsSd = iv::decition::Compute00().getObsSpeedByFrenet(obsPoint, secSpeed,gpsTrace);
  2824. obsSd = iv::decition::Compute00().getObsSpeedByFrenet(obsPoint, secSpeed,gpsTrace,gpsMap,pathpoint,nowGps);
  2825. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "计算obsSpeed:" << obsSpeed << std::endl;
  2826. }
  2827. else
  2828. {
  2829. obs=lidarDistance;
  2830. // obsCombinePoint = obsPoint;
  2831. obsSd = 0 -secSpeed*cos(car_now_frenet_point.tangent_Ang-M_PI/2);
  2832. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "毫米波无数据,计算obsSpeed:" << obsSpeed << std::endl;
  2833. }
  2834. }
  2835. else if (esrDistance>0)
  2836. {
  2837. obs = esrDistance;
  2838. // obsSd = ServiceCarStatus.obs_radar[esrIndex].speed_y;
  2839. obsSd = obsSpeed;
  2840. //障碍物信息使用毫米波采集的。其位置坐标加上偏移量,转换成相对于惯导的位置,即转换成车辆坐标系下的位置坐标。
  2841. // obsCombinePoint = Point2D(ServiceCarStatus.obs_radar[esrIndex].nomal_x+Esr_Offset,ServiceCarStatus.obs_radar[esrIndex].nomal_y+Esr_Y_Offset);
  2842. }
  2843. else if (lidarDistance > 0)
  2844. {
  2845. obs = lidarDistance;
  2846. // obsCombinePoint = obsPoint;
  2847. obsSd = iv::decition::Compute00().getObsSpeedByFrenet(obsPoint, secSpeed,gpsTrace,gpsMap,pathpoint,nowGps);
  2848. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "计算obsSpeed:" << obsSpeed << std::endl;
  2849. }
  2850. else {
  2851. obs = esrDistance;
  2852. // obsCombinePoint = Point2D(ServiceCarStatus.obs_radar[esrIndex].nomal_x+Esr_Offset,ServiceCarStatus.obs_radar[esrIndex].nomal_y+Esr_Y_Offset);
  2853. obsSd = 0 - secSpeed*cos(car_now_frenet_point.tangent_Ang-M_PI/2);
  2854. }
  2855. obsDistance=obs;
  2856. obsSpeed=obsSd;
  2857. std::cout <<ServiceCarStatus.mRunTime.elapsed()<<"ms:"<< "最终得出的obsDistance:" << obsDistance << std::endl;
  2858. ServiceCarStatus.mObs = obsDistance;
  2859. if(ServiceCarStatus.mObs>100){
  2860. ServiceCarStatus.mObs =-1;
  2861. }
  2862. if (obsDistance>0)
  2863. {
  2864. lastDistance = obsDistance;
  2865. }
  2866. if(obs<0){
  2867. obsDistance=500;
  2868. }else{
  2869. obsDistance=obs;
  2870. }
  2871. }
  2872. void ivdecision_brain::getRearEsrObsDistance(std::vector<Point2D> gpsTrace, int roadNum) {
  2873. esrIndex = iv::decition::Compute00().getRearEsrIndex(gpsTrace, roadNum,xiuzhengCs);
  2874. if (esrIndex != -1)
  2875. {
  2876. esrDistance = ServiceCarStatus.obs_rear_radar[esrIndex].nomal_y;
  2877. obsSpeed = ServiceCarStatus.obs_rear_radar[esrIndex].speed_y;
  2878. }
  2879. else {
  2880. esrDistance = -1;
  2881. }
  2882. }
  2883. void ivdecision_brain::getEsrObsDistanceByFrenet(const std::vector<Point2D>& gpsTrace, const FrenetPoint car_now_frenet_point, FrenetPoint &esrObs_F_Point, const std::vector<iv::GPSData>& gpsMap,int pathpoint,GPS_INS nowGps) {
  2884. esrIndex = iv::decition::Compute00().getEsrIndexByFrenet(gpsTrace,esrObs_F_Point,gpsMap,pathpoint,nowGps,xiuzhengCs);
  2885. if (esrIndex != -1)
  2886. {
  2887. //障碍物的距离,是障碍物和车辆沿道路上的距离,即s。并不直接是它的x坐标或y坐标或两点直线坐标。
  2888. //严格来说应是 esrDistance=障碍物的s - 车辆的s - Esr_Y_Offset,但这是根据车辆位置实时搜索路径,故车辆的s极其小。
  2889. esrDistance = esrObs_F_Point.s - car_now_frenet_point.s - Esr_Y_Offset; //-Esr_Y_Offset是把距离推到车头,换算frenet坐标时,把它加上了的。故需减去。
  2890. double speedx=ServiceCarStatus.obs_radar[esrIndex].speed_x; //障碍物相对于车辆x轴的速度
  2891. double speedy=ServiceCarStatus.obs_radar[esrIndex].speed_y; //障碍物相对于车辆y轴的速度
  2892. double speed_combine = sqrt(speedx*speedx+speedy*speedy); //将x、y轴两个方向的速度求矢量和
  2893. //障碍物的速度方向与道路方向的夹角。用于将速度分解到s方向和d方向。
  2894. //所谓道路方向是指,道路上离障碍物的最近的点沿道路弧线的切线方向。
  2895. double Etheta = esrObs_F_Point.tangent_Ang - atan2(speedy,speedx);
  2896. obsSpeed = speed_combine*cos(Etheta); //由speed_combine分解的s轴方向上的速度
  2897. }
  2898. else {
  2899. esrDistance = -1;
  2900. }
  2901. }
  2902. void ivdecision_brain::getV2XTrafficPositionVector(const std::vector<GPSData> gpsMapLine){
  2903. v2xTrafficVector.clear();
  2904. for (int var = 0; var < gpsMapLine.size(); var++) {
  2905. if(gpsMapLine[var]->roadMode==6 || gpsMapLine[var]->mode2==1000001){
  2906. v2xTrafficVector.push_back(var);
  2907. }
  2908. }
  2909. }
  2910. float ivdecision_brain::ComputeV2XTrafficLightSpeed(iv::TrafficLight trafficLight, const std::vector<GPSData> gpsMapLine,std::vector<int> v2xTrafficVector,
  2911. int pathpoint,float secSpeed,float dSpeed, bool circleMode){
  2912. float trafficSpeed=200;
  2913. int nearTraffixPoint=-1;
  2914. float nearTrafficDis=0;
  2915. int traffic_color=0;
  2916. int traffic_time=0;
  2917. bool passThrough=false;
  2918. float dSecSpeed=dSpeed/3.6;
  2919. if(v2xTrafficVector.empty()){
  2920. return trafficSpeed;
  2921. }
  2922. if(!circleMode){
  2923. if(pathpoint>v2xTrafficVector.back()){
  2924. return trafficSpeed;
  2925. }else {
  2926. for(int i=0; i< v2xTrafficVector.size();i++){
  2927. if (pathpoint<= v2xTrafficVector[i]){
  2928. nearTraffixPoint=v2xTrafficVector[i];
  2929. break;
  2930. }
  2931. }
  2932. }
  2933. }else if(circleMode){
  2934. if(pathpoint>v2xTrafficVector.back()){
  2935. nearTraffixPoint=v2xTrafficVector[0];
  2936. }else {
  2937. for(int i=0; i< v2xTrafficVector.size();i++){
  2938. if (pathpoint<= v2xTrafficVector[i]){
  2939. nearTraffixPoint=v2xTrafficVector[i];
  2940. break;
  2941. }
  2942. }
  2943. }
  2944. }
  2945. if(nearTraffixPoint!=-1){
  2946. for(int i=pathpoint;i<nearTraffixPoint;i++){
  2947. nearTrafficDis +=GetDistance(*gpsMapLine[i],*gpsMapLine[i+1]);
  2948. }
  2949. }
  2950. if(nearTrafficDis>50){
  2951. return trafficSpeed;
  2952. }
  2953. int roadMode = gpsMapLine[pathpoint]->roadMode;
  2954. if(roadMode==14 || roadMode==16){
  2955. traffic_color=trafficLight.leftColor;
  2956. traffic_time=trafficLight.leftTime;
  2957. }else if(roadMode==15 ||roadMode==17){
  2958. traffic_color=trafficLight.rightColor;
  2959. traffic_time=trafficLight.rightTime;
  2960. }else {
  2961. traffic_color=trafficLight.straightColor;
  2962. traffic_time=trafficLight.straightTime;
  2963. }
  2964. passThrough=computeTrafficPass(nearTrafficDis,traffic_color,traffic_time,secSpeed,dSecSpeed);
  2965. if(passThrough){
  2966. return trafficSpeed;
  2967. }else{
  2968. trafficSpeed=computeTrafficSpeedLimt(nearTrafficDis);
  2969. if(nearTrafficDis<6){
  2970. float decelerate =0-( secSpeed*secSpeed*0.5/nearTrafficDis);
  2971. minDecelerate=min(minDecelerate,decelerate);
  2972. }
  2973. return trafficSpeed;
  2974. }
  2975. return trafficSpeed;
  2976. }
  2977. bool ivdecision_brain::computeTrafficPass(float trafficDis,int trafficColor,float trafficTime,float realSecSpeed,float dSecSpeed){
  2978. float passTime=0;
  2979. if (trafficColor==2 || trafficColor==3){
  2980. return false;
  2981. }else if(trafficColor==0){
  2982. return true;
  2983. }else{
  2984. passTime=trafficDis/dSecSpeed;
  2985. if(passTime+1< trafficTime){
  2986. return true;
  2987. }else{
  2988. return false;
  2989. }
  2990. }
  2991. }
  2992. float ivdecision_brain::computeTrafficSpeedLimt(float trafficDis){
  2993. float limit=200;
  2994. if(trafficDis<10){
  2995. limit = 0;
  2996. }else if(trafficDis<15){
  2997. limit = 5;
  2998. }else if(trafficDis<20){
  2999. limit=10;
  3000. }else if(trafficDis<30){
  3001. limit=15;
  3002. }
  3003. return limit;
  3004. }
  3005. bool ivdecision_brain::adjuseultra(){
  3006. bool front=false,back=false,left=false,right=false;
  3007. for(int i=1;i<=13;i++)
  3008. {
  3009. if((i==2)||(i==3)||(i==4)||(i==5)) //front
  3010. {
  3011. if(ServiceCarStatus.ultraDistance[i]<100)
  3012. {
  3013. front=true;
  3014. }
  3015. }else if((i==1)||(i==12)||(i==6)||(i==7)) //left,right
  3016. {
  3017. if(ServiceCarStatus.ultraDistance[i]<30)
  3018. {
  3019. left=true;
  3020. }
  3021. }else if((i==8)||(i==9)||(i==10)||(i==11)) //back
  3022. {
  3023. if(ServiceCarStatus.ultraDistance[i]<10)
  3024. {
  3025. back=true;
  3026. }
  3027. }
  3028. }
  3029. if(front||left||back)
  3030. return true;
  3031. else
  3032. return false;
  3033. }
  3034. void ivdecision_brain::transferGpsMode2( const std::vector<GPSData> gpsMapLine){
  3035. if( gpsMapLine[PathPoint]->mode2==3000){
  3036. if(obsDistance>5){
  3037. obsDistance=200;
  3038. }
  3039. dSpeed=min(dSpeed,5.0);
  3040. }
  3041. }
  3042. float ivdecision_brain::computeAvoidX(int roadAim,int roadOri,GPSData gps,float vehWidth){
  3043. if(roadAim==roadOri){
  3044. return 0;
  3045. }
  3046. float x=0;
  3047. float veh_to_roadSide=(gps->mfRoadWidth- ServiceCarStatus.msysparam.vehWidth)*0.5;
  3048. float roadSide_to_roadSide=ServiceCarStatus.msysparam.vehWidth;
  3049. if(!ServiceCarStatus.inRoadAvoid){
  3050. x= (roadOri-roadAim)*gps->mfRoadWidth;
  3051. }else{
  3052. int num=roadOri-roadAim;
  3053. switch (abs(num%3)) {
  3054. case 0:
  3055. x=(num/3)*gps->mfRoadWidth;
  3056. break;
  3057. case 1:
  3058. if(num>0){
  3059. x=(num/3)*gps->mfRoadWidth +veh_to_roadSide;
  3060. }else{
  3061. x=(num/3)*gps->mfRoadWidth -veh_to_roadSide;
  3062. }
  3063. break;
  3064. case 2:
  3065. if(num>0){
  3066. x=(num/3)*gps->mfRoadWidth +veh_to_roadSide+roadSide_to_roadSide;
  3067. }else{
  3068. x=(num/3)*gps->mfRoadWidth -veh_to_roadSide-roadSide_to_roadSide;
  3069. }
  3070. break;
  3071. default:
  3072. break;
  3073. }
  3074. }
  3075. return x;
  3076. }
  3077. }