dispatch_process.cpp 374 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921
  1. //
  2. // Created by huli on 2021/3/22.
  3. //
  4. #include "dispatch_process.h"
  5. #include "../system/system_communication.h"
  6. #include "../dispatch/dispatch_manager.h"
  7. Dispatch_process::Dispatch_process()
  8. {
  9. m_dispatch_process_status = DISPATCH_PROCESS_STATUS_UNKNOW;
  10. m_dispatch_process_type = Common_data::Dispatch_process_type::DISPATCH_PROCESS_TYPE_UNKNOW;
  11. m_dispatch_source = 0;
  12. m_dispatch_destination = 0;
  13. m_wheel_base = 0;
  14. }
  15. Dispatch_process::~Dispatch_process()
  16. {
  17. Dispatch_process_uninit();
  18. }
  19. //初始化, 就把主控发送的请求传入即可.
  20. Error_manager Dispatch_process::Dispatch_process_init(message::Dispatch_request_msg &dispatch_request_msg)
  21. {
  22. //设定超时时间, 默认比任务指令里面的时间少10秒,
  23. if ( dispatch_request_msg.base_info().has_timeout_ms() )
  24. {
  25. m_timeout_ms = dispatch_request_msg.base_info().timeout_ms() - DISPATCH_PROCESS_ATTENUATION_TIMEOUT_MS;
  26. }
  27. else
  28. {
  29. m_timeout_ms = DISPATCH_PROCESS_TIMEOUT_MS - DISPATCH_PROCESS_ATTENUATION_TIMEOUT_MS;
  30. }
  31. m_command_key = dispatch_request_msg.command_key();
  32. m_start_time = std::chrono::system_clock::now();
  33. //检查调度请求消息
  34. if ( dispatch_request_msg.terminal_id() < Dispatch_coordinates::get_instance_references().m_passageway_terminal_id_min ||
  35. dispatch_request_msg.terminal_id() > Dispatch_coordinates::get_instance_references().m_passageway_terminal_id_max)
  36. {
  37. return Error_manager(Error_code::DISPATCH_PROCESS_INIT_ERROR, Error_level::MINOR_ERROR,
  38. " dispatch_request_msg.terminal_id() is error ");
  39. }
  40. //解析调度请求消息
  41. if ( dispatch_request_msg.dispatch_motion_direction() == message::E_STORE_CAR )
  42. {
  43. //检查调度请求消息
  44. if ( Dispatch_coordinates::get_instance_references().m_passageway_functioning_pattern_map[dispatch_request_msg.terminal_id()] != Dispatch_coordinates::PASSAGEWAY_FUNCTIONING_PATTERN_INLET &&
  45. Dispatch_coordinates::get_instance_references().m_passageway_functioning_pattern_map[dispatch_request_msg.terminal_id()] != Dispatch_coordinates::PASSAGEWAY_FUNCTIONING_PATTERN_BIDIRECTION )
  46. {
  47. return Error_manager(Error_code::DISPATCH_PROCESS_INIT_ERROR, Error_level::MINOR_ERROR,
  48. " m_passageway_functioning_pattern_map[dispatch_request_msg.terminal_id()] is error ");
  49. }
  50. //存车的车位可以是1~3个
  51. if ( dispatch_request_msg.parkspace_info_ex_size() <=0 || dispatch_request_msg.parkspace_info_ex_size() >3 )
  52. {
  53. return Error_manager(Error_code::DISPATCH_PROCESS_INIT_ERROR, Error_level::MINOR_ERROR,
  54. " dispatch_request_msg.parkspace_info_ex_size() is error ");
  55. }
  56. //检查定位信息
  57. if ( dispatch_request_msg.has_locate_information() == false )
  58. {
  59. return Error_manager(Error_code::DISPATCH_PROCESS_INIT_ERROR, Error_level::MINOR_ERROR,
  60. " dispatch_request_msg.has_locate_information() is error ");
  61. }
  62. m_dispatch_process_type = Common_data::Dispatch_process_type::DISPATCH_PROCESS_STORE;
  63. m_dispatch_source = dispatch_request_msg.terminal_id() + PASSAGEWAY_ID_BASE ;
  64. //终点在运动过程中动态分配//存车需要在完全确定车位之后, 才能判断车位类型
  65. // m_dispatch_destination = dispatch_request_msg.parkspace_info().parkingspace_index_id() + PARKSPACE_ID_BASE;
  66. for (int i = 0; i < dispatch_request_msg.parkspace_info_ex_size(); ++i)
  67. {
  68. if(dispatch_request_msg.parkspace_info_ex(i).parkspace_path() == message::Parkspace_path::LEFT_PATH)
  69. {
  70. Common_data::copy_data(m_parkspace_information_left, dispatch_request_msg.parkspace_info_ex(i));
  71. Common_data::scaling(m_parkspace_information_left, 1000);
  72. }
  73. if(dispatch_request_msg.parkspace_info_ex(i).parkspace_path() == message::Parkspace_path::RIGHT_PATH)
  74. {
  75. Common_data::copy_data(m_parkspace_information_right, dispatch_request_msg.parkspace_info_ex(i));
  76. Common_data::scaling(m_parkspace_information_right, 1000);
  77. }
  78. if(dispatch_request_msg.parkspace_info_ex(i).parkspace_path() == message::Parkspace_path::TEMPORARY_CACHE_PATH)
  79. {
  80. Common_data::copy_data(m_parkspace_information_temporary, dispatch_request_msg.parkspace_info_ex(i));
  81. Common_data::scaling(m_parkspace_information_temporary, 1000);
  82. }
  83. }
  84. // Common_data::copy_data(m_parkspace_information, dispatch_request_msg.parkspace_info());
  85. // Common_data::scaling(m_parkspace_information, 1000);
  86. Common_data::copy_data(m_car_measure_information, dispatch_request_msg.locate_information());
  87. Common_data::scaling(m_car_measure_information, 1000);
  88. m_wheel_base = m_car_measure_information.car_wheel_base;
  89. }
  90. else if( dispatch_request_msg.dispatch_motion_direction() == message::E_PICKUP_CAR )
  91. {
  92. //检查调度请求消息
  93. if ( Dispatch_coordinates::get_instance_references().m_passageway_functioning_pattern_map[dispatch_request_msg.terminal_id()] != Dispatch_coordinates::PASSAGEWAY_FUNCTIONING_PATTERN_OUTLET &&
  94. Dispatch_coordinates::get_instance_references().m_passageway_functioning_pattern_map[dispatch_request_msg.terminal_id()] != Dispatch_coordinates::PASSAGEWAY_FUNCTIONING_PATTERN_BIDIRECTION )
  95. {
  96. return Error_manager(Error_code::DISPATCH_PROCESS_INIT_ERROR, Error_level::MINOR_ERROR,
  97. " m_passageway_functioning_pattern_map[dispatch_request_msg.terminal_id()] is error ");
  98. }
  99. //取车的车位必须是1个
  100. if ( dispatch_request_msg.parkspace_info_ex_size() != 1 )
  101. {
  102. return Error_manager(Error_code::DISPATCH_PROCESS_INIT_ERROR, Error_level::MINOR_ERROR,
  103. " dispatch_request_msg.parkspace_info_ex_size() is error ");
  104. }
  105. m_dispatch_process_type = Common_data::Dispatch_process_type::DISPATCH_PROCESS_PICKUP;
  106. m_dispatch_source = dispatch_request_msg.parkspace_info_ex(0).parkingspace_index_id() + PARKSPACE_ID_BASE;
  107. m_parkspace_type = (Common_data::Parkspace_type)( dispatch_request_msg.parkspace_info_ex(0).parkingspace_type() );
  108. //终点在运动过程中动态分配
  109. //目前不控制门, 所以出口有主控决定. 如果后续控制门, 那么出口可以由调度决定.
  110. //目前取车还是固定出口.
  111. m_dispatch_destination = dispatch_request_msg.terminal_id() + PASSAGEWAY_ID_BASE ;
  112. Common_data::copy_data(m_parkspace_information_optimal, dispatch_request_msg.parkspace_info_ex(0));
  113. Common_data::scaling(m_parkspace_information_optimal, 1000);
  114. m_wheel_base = m_parkspace_information_optimal.car_information.car_wheel_base;
  115. }
  116. else
  117. {
  118. m_dispatch_process_type = Common_data::Dispatch_process_type::DISPATCH_PROCESS_TYPE_UNKNOW;
  119. return Error_manager(Error_code::DISPATCH_PROCESS_INIT_ERROR, Error_level::MINOR_ERROR,
  120. " Dispatch_process::Dispatch_process_init ERROR ");
  121. }
  122. //轮距
  123. if ( m_wheel_base < Dispatch_coordinates::get_instance_references().m_car_wheel_base_min ||
  124. m_wheel_base > Dispatch_coordinates::get_instance_references().m_car_wheel_base_max)
  125. {
  126. return Error_manager(Error_code::DISPATCH_PROCESS_INIT_ERROR, Error_level::MINOR_ERROR,
  127. " m_wheel_base < 1000 ERROR ");
  128. }
  129. m_car_type = (Common_data::Car_type)( dispatch_request_msg.car_type() );
  130. m_temporary_cache_flag = false;
  131. m_dispatch_request_msg = dispatch_request_msg;
  132. m_dispatch_process_status = DISPATCH_PROCESS_CREATED;
  133. return Error_code::SUCCESS;
  134. }
  135. //反初始化
  136. Error_manager Dispatch_process::Dispatch_process_uninit()
  137. {
  138. std::unique_lock<std::mutex> t_lock(m_lock);
  139. for (auto iter = m_dispatch_control_node_map.begin(); iter != m_dispatch_control_node_map.end(); ++iter)
  140. {
  141. if ( iter->second.mp_dispatch_task.get() != NULL )
  142. {
  143. iter->second.mp_dispatch_task->set_task_statu(Task_Base::Task_statu::TASK_WITHDRAW);
  144. iter->second.mp_dispatch_task.reset();
  145. iter->second.mp_dispatch_device.reset();
  146. }
  147. }
  148. return Error_code::SUCCESS;
  149. }
  150. //检查流程是否空闲待机
  151. Error_manager Dispatch_process::check_process_ready()
  152. {
  153. return Error_code::SUCCESS;
  154. if ( m_dispatch_process_status == DISPATCH_PROCESS_READY )
  155. {
  156. return Error_code::SUCCESS;
  157. }
  158. else
  159. {
  160. return Error_manager(Error_code::DISPATCH_PROCESS_IS_NOT_READY, Error_level::MINOR_ERROR,
  161. " Dispatch_process::check_process_ready() fun error ");
  162. }
  163. }
  164. //判断是否为待机,
  165. bool Dispatch_process::is_ready()
  166. {
  167. // std::unique_lock<std::mutex> t_lock(m_lock);
  168. if ( m_dispatch_process_status == DISPATCH_PROCESS_READY && m_dispatch_carrier_node.mp_main_carrier.get() == NULL)
  169. {
  170. return true;
  171. }
  172. else
  173. {
  174. return false;
  175. }
  176. }
  177. //能否在左侧路径存车
  178. bool Dispatch_process::is_able_store_left_path()
  179. {
  180. if ( m_parkspace_information_left.parkingspace_index_id !=0 )
  181. {
  182. return true;
  183. }
  184. return false;
  185. }
  186. //能否在右侧路径存车
  187. bool Dispatch_process::is_able_store_right_path()
  188. {
  189. if ( m_parkspace_information_right.parkingspace_index_id !=0 )
  190. {
  191. return true;
  192. }
  193. return false;
  194. }
  195. //能否在3楼路径存车
  196. bool Dispatch_process::is_able_store_temporary_cache_path()
  197. {
  198. if ( m_parkspace_information_temporary.parkingspace_index_id !=0 )
  199. {
  200. return true;
  201. }
  202. return false;
  203. }
  204. //能否在临时缓存位存车
  205. bool Dispatch_process::is_able_store_temporary_cache_path_2nd_floor()
  206. {
  207. if ( m_parkspace_information_temporary.parkingspace_index_id >= 4 && m_parkspace_information_temporary.parkingspace_index_id <= 12 )
  208. {
  209. return true;
  210. }
  211. return false;
  212. }
  213. //能否在临时缓存位存车
  214. bool Dispatch_process::is_able_store_temporary_cache_path_3rd_floor()
  215. {
  216. if ( m_parkspace_information_temporary.parkingspace_index_id >= 19 && m_parkspace_information_temporary.parkingspace_index_id <= 27 )
  217. {
  218. return true;
  219. }
  220. return false;
  221. }
  222. void Dispatch_process::set_main_carrier(std::shared_ptr<Dispatch_device_base> p_carrier)
  223. {
  224. std::unique_lock<std::mutex> t_lock(m_lock);
  225. m_dispatch_carrier_node.mp_main_carrier = p_carrier;
  226. }
  227. std::string Dispatch_process::get_dispatch_control_command_key(Dispatch_catcher_node & dispatch_catcher_node)
  228. {
  229. char t_key[50] = {0};
  230. sprintf(t_key, "%s+%d+%d", m_command_key.c_str(), m_dispatch_process_type, dispatch_catcher_node.m_dispatch_control_status);
  231. std::string t_str = t_key;
  232. return t_str;
  233. }
  234. std::string Dispatch_process::get_dispatch_control_command_key(Dispatch_carrier_node & dispatch_carrier_node)
  235. {
  236. char t_key[50] = {0};
  237. sprintf(t_key, "%s+%d+%d", m_command_key.c_str(), m_dispatch_process_type, dispatch_carrier_node.m_dispatch_control_status);
  238. std::string t_str = t_key;
  239. return t_str;
  240. }
  241. void Dispatch_process::Main()
  242. {
  243. Error_manager t_error;
  244. //主流程, 循环执行
  245. while ( std::chrono::system_clock::now() - m_start_time < std::chrono::milliseconds(m_timeout_ms) )
  246. {
  247. std::this_thread::sleep_for(std::chrono::microseconds(1));
  248. std::this_thread::sleep_for(std::chrono::milliseconds(1));
  249. // std::this_thread::sleep_for(std::chrono::milliseconds(100));
  250. #ifdef TIME_TEST
  251. if ( mcarrier == m_dispatch_carrier_node.m_dispatch_control_status && mcatcher == m_dispatch_catcher_node.m_dispatch_control_status )
  252. {
  253. std::this_thread::sleep_for(std::chrono::milliseconds(100));
  254. // std::this_thread::sleep_for(std::chrono::seconds(1));
  255. Dispatch_coordinates::get_instance_references().cout_space_lock();
  256. }
  257. else
  258. {
  259. mcarrier = m_dispatch_carrier_node.m_dispatch_control_status;
  260. mcatcher = m_dispatch_catcher_node.m_dispatch_control_status;
  261. }
  262. #endif
  263. std::cout << " huli test ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: " << " m_dispatch_process_status = " << m_dispatch_process_status << " , m_command_key = " << m_command_key << std::endl;
  264. // std::cout << " huli test :::: " << " Dispatch_manager::get_instance_references().m_carrier_map[2]->m_device_one_level_command_key = " << Dispatch_manager::get_instance_references().m_carrier_map[2]->m_device_one_level_command_key << std::endl;
  265. // std::cout << " huli test :::: " << " Dispatch_manager::get_instance_references().m_carrier_map[2]->m_device_two_level_command_key = " << Dispatch_manager::get_instance_references().m_carrier_map[2]->m_device_two_level_command_key << std::endl;
  266. // std::cout << " huli test :::: " << " Dispatch_manager::get_instance_references().m_carrier_map[2]->m_device_three_level_command_key = " << Dispatch_manager::get_instance_references().m_carrier_map[2]->m_device_three_level_command_key << std::endl;
  267. switch ( (Dispatch_process_status)m_dispatch_process_status )
  268. {
  269. case DISPATCH_PROCESS_CREATED://流程创建,
  270. {
  271. //检查调度请求
  272. m_result = check_dispatch_request_msg();
  273. if ( m_result !=Error_code::SUCCESS)
  274. {
  275. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  276. break;
  277. }
  278. //发送调度总计划
  279. // m_result = send_dispatch_plan_request_msg();
  280. // if ( m_result !=Error_code::SUCCESS)
  281. // {
  282. // m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  283. // break;
  284. // }
  285. //流程正常, 就进入等待状态, 等待调度控制发送动作指令
  286. m_dispatch_process_status = DISPATCH_PROCESS_READY;
  287. break;
  288. }
  289. case DISPATCH_PROCESS_READY://流程准备,待机
  290. {
  291. m_result = wait_resource_allocation();
  292. if ( m_result == Error_code::SUCCESS)
  293. {
  294. if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_PICKUP )
  295. {
  296. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_READY;
  297. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_READY;
  298. m_dispatch_process_status = DISPATCH_PROCESS_WORKING_PICKUP;
  299. }
  300. else if(m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_STORE)
  301. {
  302. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_READY;
  303. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_READY;
  304. m_dispatch_process_status = DISPATCH_PROCESS_WORKING_STORE;
  305. //根据设备选择, 来设置终点
  306. if ( m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 2 )
  307. {
  308. m_parkspace_information_optimal = m_parkspace_information_temporary;
  309. }
  310. else if ( m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 0 && m_temporary_cache_flag == false )
  311. {
  312. m_parkspace_information_optimal = m_parkspace_information_left;
  313. }
  314. else if ( m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 0 && m_temporary_cache_flag == true)
  315. {
  316. m_parkspace_information_optimal = m_parkspace_information_temporary;
  317. }
  318. else if ( m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 1 && m_temporary_cache_flag == false )
  319. {
  320. m_parkspace_information_optimal = m_parkspace_information_right;
  321. }
  322. else if ( m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 1 && m_temporary_cache_flag == true)
  323. {
  324. m_parkspace_information_optimal = m_parkspace_information_temporary;
  325. }
  326. }
  327. }
  328. //else 一直等待资源分配
  329. break;
  330. //调度控制, 并根据完成情况给答复
  331. // dispatch_control_motion();
  332. //
  333. // //等待调度总计划答复
  334. // m_result = wait_dispatch_plan_response_msg();
  335. // if ( m_result ==Error_code::SUCCESS)
  336. // {
  337. // //流程正常, 就进入完成状态,
  338. // m_dispatch_process_status = DISPATCH_PROCESS_OVER;
  339. // break;
  340. // }
  341. // else if ( m_result !=Error_code::NODATA )
  342. // {
  343. // m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  344. // break;
  345. // }
  346. //else nodata, 就表示没有新的指令, 那么什么都不做, 原地待命
  347. break;
  348. }
  349. case DISPATCH_PROCESS_WORKING_PICKUP://流程完成
  350. {
  351. //调度控制取车
  352. m_result = dispatch_control_motion_pickup();
  353. if ( m_result ==Error_code::SUCCESS)
  354. {
  355. //流程正常, 就进入完成状态,
  356. m_dispatch_process_status = DISPATCH_PROCESS_OVER;
  357. break;
  358. }
  359. else if ( m_result !=Error_code::NODATA )
  360. {
  361. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  362. break;
  363. }
  364. //else nodata, 就表示没有新的指令, 那么什么都不做, 原地待命
  365. break;
  366. }
  367. case DISPATCH_PROCESS_WORKING_STORE://流程完成
  368. {
  369. //调度控制存车
  370. m_result = dispatch_control_motion_store();
  371. if ( m_result ==Error_code::SUCCESS)
  372. {
  373. //流程正常, 就进入完成状态,
  374. m_dispatch_process_status = DISPATCH_PROCESS_OVER;
  375. break;
  376. }
  377. else if ( m_result !=Error_code::NODATA )
  378. {
  379. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  380. break;
  381. }
  382. //else nodata, 就表示没有新的指令, 那么什么都不做, 原地待命
  383. break;
  384. }
  385. case DISPATCH_PROCESS_OVER://流程完成
  386. {
  387. //发送调度答复, 发给主控的
  388. m_result = send_dispatch_response_msg();
  389. if ( m_result !=Error_code::SUCCESS)
  390. {
  391. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  392. break;
  393. }
  394. //流程正常, 就进入等待状态, 等待调度控制发送动作指令
  395. m_dispatch_process_status = DISPATCH_PROCESS_RELEASE;
  396. break;
  397. }
  398. case DISPATCH_PROCESS_RELEASE://流程释放
  399. {
  400. //通知调度管理, 释放资源,
  401. m_result = release_resource();
  402. if ( m_result !=Error_code::SUCCESS)
  403. {
  404. m_dispatch_process_status = DISPATCH_PROCESS_FAULT;
  405. break;
  406. }
  407. //在这里, 整个流程彻底结束, 之后线程池会自动回收 这个流程对象的资源
  408. return;
  409. break;
  410. }
  411. case DISPATCH_PROCESS_FAULT://故障
  412. {
  413. LOG(INFO) << " m_result = "<< m_result << " " << this;
  414. release_resource();
  415. Exception_handling();
  416. //在这里, 整个流程彻底结束, 之后线程池会自动回收 这个流程对象的资源
  417. return;
  418. break;
  419. }
  420. default:
  421. {
  422. break;
  423. }
  424. }
  425. }
  426. //任务超时
  427. LOG(INFO) << " Dispatch_process::Main() time out "<< this;
  428. return;
  429. }
  430. //检查调度请求
  431. Error_manager Dispatch_process::check_dispatch_request_msg()
  432. {
  433. // std::unique_lock<std::mutex> t_lock(m_lock);
  434. return Error_code::SUCCESS;
  435. }
  436. //等待资源分配
  437. Error_manager Dispatch_process::wait_resource_allocation()
  438. {
  439. //只判断搬运器的指针是否有效.
  440. if ( m_dispatch_carrier_node.mp_main_carrier.get() == NULL )
  441. {
  442. return Error_code::NODATA;
  443. }
  444. else
  445. {
  446. return Error_code::SUCCESS;
  447. }
  448. }
  449. //调度控制取车
  450. Error_manager Dispatch_process::dispatch_control_motion_pickup()
  451. {
  452. std::unique_lock<std::mutex> t_lock(m_lock);
  453. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  454. Error_manager t_carrier_error;
  455. Carrier * tp_main_carrier = NULL;
  456. Carrier_task * tp_main_carrier_task = NULL;
  457. if ( m_dispatch_carrier_node.mp_main_carrier.get() != NULL && m_dispatch_carrier_node.mp_main_carrier_task.get() != NULL )
  458. {
  459. tp_main_carrier = (Carrier *)m_dispatch_carrier_node.mp_main_carrier.get();
  460. tp_main_carrier_task = (Carrier_task *)m_dispatch_carrier_node.mp_main_carrier_task.get();
  461. //一级任务被打断后, 重新执行
  462. if ( tp_main_carrier->get_break_flag() )
  463. {
  464. if ( m_dispatch_carrier_node.m_main_carrier_task_level == Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL )
  465. {
  466. m_dispatch_carrier_node.m_dispatch_control_status = DISPATCH_CARRIER_PICKUP_START;
  467. }
  468. tp_main_carrier->set_break_flag(false);
  469. }
  470. }
  471. Catcher * tp_avoid_catcher = NULL;
  472. Catcher_task * tp_avoid_catcher_task = NULL;
  473. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL && m_dispatch_carrier_node.mp_avoid_catcher_task.get() != NULL )
  474. {
  475. tp_avoid_catcher = (Catcher *)m_dispatch_carrier_node.mp_avoid_catcher.get();
  476. tp_avoid_catcher_task = (Catcher_task *)m_dispatch_carrier_node.mp_avoid_catcher_task.get();
  477. }
  478. Carrier * tp_avoid_carrier = NULL;
  479. Carrier_task * tp_avoid_carrier_task = NULL;
  480. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() != NULL && m_dispatch_carrier_node.mp_avoid_carrier_task.get() != NULL )
  481. {
  482. tp_avoid_carrier = (Carrier *)m_dispatch_carrier_node.mp_avoid_carrier.get();
  483. tp_avoid_carrier_task = (Carrier_task *)m_dispatch_carrier_node.mp_avoid_carrier_task.get();
  484. }
  485. std::cout << " huli test :::: " << " ===================================================================================================================== = " << "carrier start" << std::endl;
  486. std::cout << " huli test :::: " << " m_dispatch_carrier_node.m_dispatch_control_status = " << m_dispatch_carrier_node.m_dispatch_control_status << std::endl;
  487. if ( m_dispatch_carrier_node.mp_main_carrier.get() != NULL )
  488. {
  489. std::cout << " huli test :::: " << " tp_main_carrier->get_device_id() = " << m_dispatch_carrier_node.mp_main_carrier->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_main_carrier->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_main_carrier->get_dispatch_device_status() << std::endl;
  490. }
  491. else
  492. {
  493. std::cout << " huli test :::: " << " tp_main_carrier->get_device_id() = " << -8888 << std::endl;
  494. }
  495. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL )
  496. {
  497. std::cout << " huli test :::: " << " tp_avoid_catcher->get_device_id() = " << m_dispatch_carrier_node.mp_avoid_catcher->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_avoid_catcher->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_avoid_catcher->get_dispatch_device_status() << std::endl;
  498. }
  499. else
  500. {
  501. std::cout << " huli test :::: " << " tp_avoid_catcher->get_device_id() = " << -8888 << std::endl;
  502. }
  503. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() != NULL )
  504. {
  505. std::cout << " huli test :::: " << " tp_avoid_carrier->get_device_id() = " << m_dispatch_carrier_node.mp_avoid_carrier->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_avoid_carrier->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_avoid_carrier->get_dispatch_device_status() << std::endl;
  506. }
  507. else
  508. {
  509. std::cout << " huli test :::: " << " tp_avoid_carrier->get_device_id() = " << -8888 << std::endl;
  510. }
  511. //搬运器的控制动作
  512. switch ( m_dispatch_carrier_node.m_dispatch_control_status )
  513. {
  514. case DISPATCH_CONTROL_CREATED:
  515. case DISPATCH_CONTROL_READY://等待调度管理进行资源分配
  516. {
  517. m_dispatch_carrier_node.m_error = check_main_carrier(m_dispatch_carrier_node);
  518. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  519. {
  520. if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_PICKUP )
  521. {
  522. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_START;
  523. }
  524. else if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_STORE )
  525. {
  526. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_START;
  527. }
  528. }
  529. //else 原地等待
  530. break;
  531. }
  532. case DISPATCH_CARRIER_PICKUP_START://连接搬运器, 创建新的任务单 与设备建立连接
  533. {
  534. //注意了:3楼搬运器必须要和机器人联动, 所以先通知机器人连接
  535. if ( m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 2 )
  536. {
  537. //通知机器人提前开始
  538. m_dispatch_catcher_node.m_dispatch_control_start_flag = true;
  539. m_dispatch_catcher_node.m_following_flag = false;
  540. //等待机器人正常连接之后, 搬运器才正式开始
  541. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_2 )
  542. {
  543. if ( m_dispatch_carrier_node.mp_main_carrier_task.get() == NULL )
  544. {
  545. //连接搬运器, 创建新的任务单 与设备建立连接, 只能成功, 失败就要进入故障处理
  546. m_dispatch_carrier_node.m_error = m_dispatch_carrier_node.mp_main_carrier->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  547. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  548. {
  549. m_dispatch_carrier_node.m_error = connect_dispatch_carrier(m_dispatch_carrier_node.mp_main_carrier, m_dispatch_carrier_node.mp_main_carrier_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  550. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  551. {
  552. m_dispatch_carrier_node.m_main_carrier_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL;
  553. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  554. }
  555. else
  556. {
  557. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  558. }
  559. }
  560. else
  561. {
  562. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  563. }
  564. }
  565. else
  566. {
  567. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  568. }
  569. }
  570. //else 无限等待
  571. }
  572. else
  573. {
  574. if ( m_dispatch_carrier_node.mp_main_carrier_task.get() == NULL )
  575. {
  576. //连接搬运器, 创建新的任务单 与设备建立连接, 只能成功, 失败就要进入故障处理
  577. m_dispatch_carrier_node.m_error = m_dispatch_carrier_node.mp_main_carrier->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  578. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  579. {
  580. m_dispatch_carrier_node.m_error = connect_dispatch_carrier(m_dispatch_carrier_node.mp_main_carrier, m_dispatch_carrier_node.mp_main_carrier_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  581. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  582. {
  583. m_dispatch_carrier_node.m_main_carrier_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL;
  584. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  585. }
  586. else
  587. {
  588. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  589. }
  590. }
  591. else
  592. {
  593. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  594. }
  595. }
  596. else
  597. {
  598. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  599. }
  600. }
  601. break;
  602. }
  603. case DISPATCH_CARRIER_PICKUP_1:
  604. {
  605. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  606. break;
  607. }
  608. case DISPATCH_CARRIER_PICKUP_2://搬运器 准备开始, 需要同步任务单和设备真实数据
  609. {
  610. //注意了:3楼搬运器必须要和机器人联动, 所以必须等机器人连接上之后,搬运器才开始启动
  611. if ( m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 2 )
  612. {
  613. //等待机器人正常连接之后, 搬运器才正式开始
  614. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_2 )
  615. {
  616. //搬运器 准备开始, 需要同步任务单和设备真实数据.//注意了:连接设备只是预约, 设备不一定立刻执行.所以需要在连接成功之后进行数据同步
  617. carrier_ready_to_start(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates);
  618. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  619. }
  620. //else 无限等待
  621. }
  622. else
  623. {
  624. //搬运器 准备开始, 需要同步任务单和设备真实数据.//注意了:连接设备只是预约, 设备不一定立刻执行.所以需要在连接成功之后进行数据同步
  625. carrier_ready_to_start(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates);
  626. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  627. }
  628. break;
  629. }
  630. case DISPATCH_CARRIER_PICKUP_3:
  631. {
  632. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  633. //注意了:同步失败,需要重新同步.
  634. if ( m_dispatch_carrier_node.m_error != Error_code::SUCCESS )
  635. {
  636. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_2);
  637. }
  638. break;
  639. }
  640. case DISPATCH_CARRIER_PICKUP_4://搬运器检查姿态 //搬运器调整到 正常待机的姿态(调节夹杆和轴距)
  641. {
  642. if ( tp_main_carrier->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  643. {
  644. if ( tp_main_carrier_task->m_request_clamp_motion == Carrier_task::Clamp_motion::E_CLAMP_LOOSE &&
  645. Common_data::approximate_difference(m_wheel_base, tp_main_carrier->m_actual_y1-tp_main_carrier->m_actual_y2, DISPATCH_DEFAULT_DIFFERENCE))
  646. {
  647. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  648. }
  649. else
  650. {
  651. //搬运器调整到 正常待机的姿态(调节夹杆和轴距)
  652. carrier_adjust_to_ready(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates);
  653. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  654. }
  655. }
  656. else
  657. {
  658. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  659. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  660. "DISPATCH_CARRIER_PICKUP_4 tp_carrier->m_actual_load_status != Dispatch_device_base::Load_status::NO_CAR fun error ");
  661. }
  662. break;
  663. }
  664. case DISPATCH_CARRIER_PICKUP_5:
  665. {
  666. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  667. break;
  668. }
  669. case DISPATCH_CARRIER_PICKUP_6://让小跑车回到中跑车上, y轴移动
  670. {
  671. if ( Common_data::approximate_difference(tp_main_carrier->m_actual_y, tp_dispatch_coordinates->m_carrier_default_y_back, DISPATCH_DEFAULT_DIFFERENCE) )
  672. {
  673. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  674. }
  675. else
  676. {
  677. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  678. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  679. }
  680. break;
  681. }
  682. case DISPATCH_CARRIER_PICKUP_7:
  683. {
  684. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  685. break;
  686. }
  687. case DISPATCH_CARRIER_PICKUP_8://让中跑车回到电梯井, 进行x轴路径检查
  688. {
  689. float t_z = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].z;
  690. if ( Common_data::approximate_difference(tp_main_carrier->m_actual_z, t_z, DISPATCH_DEFAULT_DIFFERENCE) )
  691. {
  692. //直接到 20步 , 准备同层移动到车位
  693. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_20);
  694. if ( tp_main_carrier->get_device_id() == 2 )
  695. {
  696. //3楼的搬运器直接到 22步
  697. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_22);
  698. }
  699. }
  700. else
  701. {
  702. //如果是3楼, 直接报错, 因为3楼搬运器只能在3楼移动, z轴真实值和目标值 一定是相同的
  703. if ( tp_main_carrier->get_device_id() !=0 && tp_main_carrier->get_device_id() !=1 )
  704. {
  705. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  706. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  707. "DISPATCH_CARRIER_PICKUP_8 tp_main_carrier->get_device_id() PARAMRTER ERROR ");
  708. }
  709. else
  710. {
  711. int t_avoid_catcher_id = -1; //需要避让的机器人
  712. //空间锁判断, 是否需要机器人避让
  713. if ( tp_main_carrier->get_device_id() == 0 )
  714. {
  715. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, 0,
  716. tp_main_carrier->m_actual_coordinates_rows, tp_main_carrier->m_actual_coordinates_columns,
  717. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  718. }
  719. else if ( tp_main_carrier->get_device_id() == 1 )
  720. {
  721. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, tp_main_carrier->m_actual_coordinates_columns,
  722. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns-1,
  723. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  724. }
  725. //判断结果
  726. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  727. {
  728. //成功则直接跳转, 不用避让, 直接控制搬运器直到电梯井
  729. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_14);
  730. }
  731. else if(t_avoid_catcher_id != -1)
  732. {
  733. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() == NULL )
  734. {
  735. m_dispatch_carrier_node.mp_avoid_catcher = Dispatch_manager::get_instance_references().m_catcher_map[t_avoid_catcher_id];
  736. }
  737. if ( m_dispatch_carrier_node.mp_avoid_catcher_task.get() == NULL )
  738. {
  739. //连接避让设备 使得避让机器人进行避让
  740. m_dispatch_carrier_node.m_error = m_dispatch_carrier_node.mp_avoid_catcher->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  741. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  742. {
  743. m_dispatch_carrier_node.m_error = connect_dispatch_catcher(m_dispatch_carrier_node.mp_avoid_catcher, m_dispatch_carrier_node.mp_avoid_catcher_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  744. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  745. {
  746. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  747. }
  748. }
  749. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  750. }
  751. else
  752. {
  753. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  754. }
  755. }
  756. else
  757. {
  758. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  759. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  760. "DISPATCH_CARRIER_PICKUP_8 carrier_try_space_lock fun ERROR ");
  761. }
  762. }
  763. }
  764. break;
  765. }
  766. case DISPATCH_CARRIER_PICKUP_9:
  767. {
  768. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_avoid_catcher_task, m_dispatch_carrier_node.m_dispatch_control_status);
  769. break;
  770. }
  771. case DISPATCH_CARRIER_PICKUP_10://机器人避让到最高点, 机器人上升不需要判断空间锁
  772. {
  773. catcher_move_z(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_catcher, tp_avoid_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  774. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  775. break;
  776. }
  777. case DISPATCH_CARRIER_PICKUP_11://机器人释放 空间锁
  778. {
  779. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_avoid_catcher_task, m_dispatch_carrier_node.m_dispatch_control_status);
  780. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  781. {
  782. tp_dispatch_coordinates->catcher_space_unlock(tp_avoid_catcher->m_actual_coordinates_id, tp_avoid_catcher->get_device_id());
  783. }
  784. break;
  785. }
  786. case DISPATCH_CARRIER_PICKUP_12://搬运器空间锁判断, 必须成功
  787. {
  788. int t_avoid_catcher_id = -1; //需要避让的机器人
  789. if ( tp_main_carrier->get_device_id() == 0 )
  790. {
  791. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, 0,
  792. tp_main_carrier->m_actual_coordinates_rows, tp_main_carrier->m_actual_coordinates_columns,
  793. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  794. }
  795. else if ( tp_main_carrier->get_device_id() == 1 )
  796. {
  797. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, tp_main_carrier->m_actual_coordinates_columns,
  798. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns-1,
  799. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  800. }
  801. //判断结果
  802. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  803. {
  804. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  805. }
  806. else
  807. {
  808. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  809. }
  810. break;
  811. }
  812. case DISPATCH_CARRIER_PICKUP_13://避让机器人 断连
  813. {
  814. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL && m_dispatch_carrier_node.mp_avoid_catcher_task.get() != NULL )
  815. {
  816. disconnect_dispatch_device(m_dispatch_carrier_node.mp_avoid_catcher, m_dispatch_carrier_node.mp_avoid_catcher_task);
  817. }
  818. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  819. break;
  820. }
  821. case DISPATCH_CARRIER_PICKUP_14://让中跑车回到电梯井, x轴移动
  822. {
  823. if ( tp_main_carrier->get_device_id() == 0 )
  824. {
  825. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  826. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  827. }
  828. else if ( tp_main_carrier->get_device_id() == 1 )
  829. {
  830. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  831. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  832. }
  833. else
  834. {
  835. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  836. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  837. "DISPATCH_CARRIER_PICKUP_14 tp_main_carrier->get_device_id() PARAMRTER ERROR ");
  838. }
  839. break;
  840. }
  841. case DISPATCH_CARRIER_PICKUP_15://搬运器 释放空间锁
  842. {
  843. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  844. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  845. {
  846. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_space_unlock(tp_main_carrier->get_device_id());
  847. }
  848. break;
  849. }
  850. case DISPATCH_CARRIER_PICKUP_16://中跑车收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  851. {
  852. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  853. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  854. break;
  855. }
  856. case DISPATCH_CARRIER_PICKUP_17:
  857. {
  858. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  859. break;
  860. }
  861. case DISPATCH_CARRIER_PICKUP_18: //电梯移动到对应的楼层, 搬运器在电梯里面z轴移动, 不需要判断空间锁
  862. {
  863. float t_z = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].z;
  864. carrier_move_z(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_z);
  865. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  866. break;
  867. }
  868. case DISPATCH_CARRIER_PICKUP_19:
  869. {
  870. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  871. break;
  872. }
  873. case DISPATCH_CARRIER_PICKUP_20://伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  874. {
  875. if ( tp_main_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK )
  876. {
  877. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  878. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  879. }
  880. else
  881. {
  882. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  883. }
  884. break;
  885. }
  886. case DISPATCH_CARRIER_PICKUP_21:
  887. {
  888. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  889. break;
  890. }
  891. case DISPATCH_CARRIER_PICKUP_22://中跑车 x轴移动到车位, 进行x轴路径检查
  892. {
  893. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].x;
  894. int t_column = (m_parkspace_information_optimal.parkingspace_index_id-1) % tp_dispatch_coordinates->m_space_lock_columns;
  895. if ( Common_data::approximate_difference(tp_main_carrier->m_actual_x, t_x, DISPATCH_DEFAULT_DIFFERENCE) )
  896. {
  897. //搬运器不用x轴运动, 直接到29步, 去车位取车
  898. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_30);
  899. }
  900. else
  901. {
  902. int t_avoid_catcher_id = -1; //需要避让的机器人
  903. if ( tp_main_carrier->get_device_id() == 0 && t_column <13-1)
  904. {
  905. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, 0,
  906. tp_main_carrier->m_actual_coordinates_rows, t_column+1,
  907. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  908. }
  909. else if ( tp_main_carrier->get_device_id() == 1 && t_column >3-1)
  910. {
  911. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, t_column-1,
  912. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns-1,
  913. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  914. }
  915. else if ( tp_main_carrier->get_device_id() == 2 )
  916. {
  917. //3楼搬运器不用加锁, 直接x轴移动
  918. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_28);
  919. break;//切换流程
  920. }
  921. else
  922. {
  923. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  924. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  925. "DISPATCH_CARRIER_PICKUP_22 tp_main_carrier->get_device_id() and m_parkspace_information_optimal.parkingspace_index_id PARAMRTER ERROR ");
  926. break;//切换流程
  927. }
  928. //判断结果
  929. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  930. {
  931. //左右搬运器加锁成功, 直接x轴移动
  932. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_28);
  933. }
  934. else if(t_avoid_catcher_id != -1 &&
  935. (tp_main_carrier->m_actual_coordinates_rows == 2 || tp_main_carrier->m_actual_coordinates_rows == 1))//4楼取车, 机器人进行避让
  936. {
  937. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() == NULL )
  938. {
  939. m_dispatch_carrier_node.mp_avoid_catcher = Dispatch_manager::get_instance_references().m_catcher_map[t_avoid_catcher_id];
  940. }
  941. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() == NULL )
  942. {
  943. m_dispatch_carrier_node.mp_avoid_carrier = Dispatch_manager::get_instance_references().m_carrier_map[2];
  944. }
  945. //连接4楼机器人和3楼搬运器
  946. Error_manager t_catcher_error;
  947. Error_manager t_carrier_error;
  948. if ( m_dispatch_carrier_node.mp_avoid_catcher_task.get() == NULL && m_dispatch_carrier_node.mp_avoid_carrier_task.get() == NULL)
  949. {
  950. //连接避让设备 使得避让机器人进行避让
  951. t_catcher_error = m_dispatch_carrier_node.mp_avoid_catcher->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  952. t_carrier_error = m_dispatch_carrier_node.mp_avoid_carrier->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  953. if ( t_catcher_error == Error_code::SUCCESS && t_carrier_error == Error_code::SUCCESS)
  954. {
  955. t_catcher_error = connect_dispatch_catcher(m_dispatch_carrier_node.mp_avoid_catcher, m_dispatch_carrier_node.mp_avoid_catcher_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  956. if ( t_catcher_error == Error_code::SUCCESS )
  957. {
  958. t_carrier_error = connect_dispatch_carrier(m_dispatch_carrier_node.mp_avoid_carrier, m_dispatch_carrier_node.mp_avoid_carrier_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  959. if ( t_carrier_error == Error_code::SUCCESS )
  960. {
  961. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  962. }
  963. else
  964. {
  965. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  966. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  967. "DISPATCH_CARRIER_PICKUP_22 connect_dispatch_carrier ERROR ");
  968. break;//切换流程
  969. }
  970. }
  971. }
  972. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  973. }
  974. else if ( m_dispatch_carrier_node.mp_avoid_catcher_task.get() != NULL && m_dispatch_carrier_node.mp_avoid_carrier_task.get() != NULL )
  975. {
  976. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  977. }
  978. else
  979. {
  980. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  981. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  982. "DISPATCH_CARRIER_PICKUP_22 m_dispatch_carrier_node.mp_avoid_catcher_task.get() m_dispatch_carrier_node.mp_avoid_carrier_task.get() ERROR ");
  983. break;//切换流程
  984. }
  985. }
  986. //else 无限等待
  987. }
  988. break;
  989. }
  990. case DISPATCH_CARRIER_PICKUP_23:
  991. {
  992. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_avoid_catcher_task, m_dispatch_carrier_node.m_dispatch_control_status);
  993. break;
  994. }
  995. case DISPATCH_CARRIER_PICKUP_24://让4楼机器人进行避让, 先加锁, 在避让
  996. {
  997. //机器人避让距离, 4楼避让4个车位, 3楼避让2个车位
  998. int m_avoid_distance = 0;
  999. int t_row = (m_parkspace_information_optimal.parkingspace_index_id-1) / tp_dispatch_coordinates->m_space_lock_columns;
  1000. if ( t_row == 1 )
  1001. {
  1002. m_avoid_distance = 3;
  1003. }
  1004. else
  1005. {
  1006. m_avoid_distance = 3;
  1007. }
  1008. int t_column = (m_parkspace_information_optimal.parkingspace_index_id-1) % tp_dispatch_coordinates->m_space_lock_columns;
  1009. //4楼搬运器需要避让4个车位
  1010. if ( tp_main_carrier->get_device_id() == 0 && tp_avoid_catcher->m_actual_coordinates_columns < t_column+m_avoid_distance )
  1011. {
  1012. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, tp_avoid_catcher->m_actual_coordinates_columns,
  1013. 2, t_column+m_avoid_distance+1,
  1014. tp_avoid_catcher->get_device_id());
  1015. //判断结果
  1016. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1017. {
  1018. //机器人移到42号口
  1019. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id+m_avoid_distance].x;
  1020. catcher_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_catcher, tp_avoid_catcher_task, tp_dispatch_coordinates, t_x);
  1021. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_carrier, tp_avoid_carrier_task, tp_dispatch_coordinates, t_x);
  1022. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1023. }
  1024. //else 无限等待
  1025. }
  1026. else if ( tp_main_carrier->get_device_id() == 1 && tp_avoid_catcher->m_actual_coordinates_columns > t_column-m_avoid_distance)
  1027. {
  1028. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, t_column-m_avoid_distance-1,
  1029. 2, tp_avoid_catcher->m_actual_coordinates_columns,
  1030. tp_avoid_catcher->get_device_id());
  1031. //判断结果
  1032. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1033. {
  1034. //机器人移到34号口
  1035. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id-m_avoid_distance].x;
  1036. catcher_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_catcher, tp_avoid_catcher_task, tp_dispatch_coordinates, t_x);
  1037. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_carrier, tp_avoid_carrier_task, tp_dispatch_coordinates, t_x);
  1038. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1039. }
  1040. //else 无限等待
  1041. }
  1042. else
  1043. {
  1044. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1045. }
  1046. break;
  1047. }
  1048. case DISPATCH_CARRIER_PICKUP_25://机器人释放 空间锁
  1049. {
  1050. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_avoid_catcher_task);
  1051. m_dispatch_carrier_node.m_error.compare_and_cover_error(check_task_status(m_dispatch_carrier_node.mp_avoid_carrier_task));
  1052. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1053. {
  1054. tp_dispatch_coordinates->catcher_space_unlock(tp_avoid_catcher->m_actual_coordinates_id, tp_avoid_catcher->get_device_id());
  1055. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1056. }
  1057. break;
  1058. }
  1059. case DISPATCH_CARRIER_PICKUP_26://搬运器空间锁判断, 必须成功
  1060. {
  1061. int t_column = (m_parkspace_information_optimal.parkingspace_index_id-1) % tp_dispatch_coordinates->m_space_lock_columns;
  1062. int t_avoid_catcher_id = -1; //需要避让的机器人
  1063. if ( tp_main_carrier->get_device_id() == 0 && t_column <13-1)
  1064. {
  1065. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, 0,
  1066. tp_main_carrier->m_actual_coordinates_rows, t_column+1,
  1067. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  1068. }
  1069. else if ( tp_main_carrier->get_device_id() == 1 && t_column >3-1)
  1070. {
  1071. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, t_column-1,
  1072. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns-1,
  1073. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  1074. }
  1075. //判断结果
  1076. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1077. {
  1078. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1079. }
  1080. else
  1081. {
  1082. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  1083. }
  1084. break;
  1085. }
  1086. case DISPATCH_CARRIER_PICKUP_27://避让机器人 断连
  1087. {
  1088. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL && m_dispatch_carrier_node.mp_avoid_catcher_task.get() != NULL )
  1089. {
  1090. //避让机器人 断开连接
  1091. disconnect_dispatch_device(m_dispatch_carrier_node.mp_avoid_catcher, m_dispatch_carrier_node.mp_avoid_catcher_task);
  1092. }
  1093. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() != NULL && m_dispatch_carrier_node.mp_avoid_carrier_task.get() != NULL )
  1094. {
  1095. //避让机器人 断开连接
  1096. disconnect_dispatch_device(m_dispatch_carrier_node.mp_avoid_carrier, m_dispatch_carrier_node.mp_avoid_carrier_task);
  1097. }
  1098. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1099. break;
  1100. }
  1101. case DISPATCH_CARRIER_PICKUP_28://搬运器x轴移动到车位
  1102. {
  1103. //3楼交接时, 机器人和3楼搬运器一起运动
  1104. if ( tp_main_carrier->get_device_id() == 2 )
  1105. {
  1106. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_13 )
  1107. {
  1108. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].x;
  1109. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  1110. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1111. }
  1112. //else 无限等待
  1113. }
  1114. else
  1115. {
  1116. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].x;
  1117. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  1118. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1119. }
  1120. break;
  1121. }
  1122. case DISPATCH_CARRIER_PICKUP_29:
  1123. {
  1124. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1125. break;
  1126. }
  1127. case DISPATCH_CARRIER_PICKUP_30://把任务从一级升到三级, 准备取车
  1128. {
  1129. //3楼交接时, 机器人先升级, 搬运器再升级
  1130. if ( tp_main_carrier->get_device_id() == 2 )
  1131. {
  1132. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_16 )
  1133. {
  1134. m_dispatch_carrier_node.m_error = m_dispatch_carrier_node.mp_main_carrier->change_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL);
  1135. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1136. {
  1137. m_dispatch_carrier_node.m_main_carrier_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL;
  1138. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1139. if ( m_dispatch_destination != 1107 && m_dispatch_destination != 1100 )
  1140. {
  1141. //如不是7号出口, 那么开启 抓取机器人
  1142. //注意了, 取车流程只有在这里, 抓取机器人的流程才开始
  1143. m_dispatch_catcher_node.m_dispatch_control_start_flag = true;
  1144. if ( tp_main_carrier->get_device_id() != 2 )
  1145. {
  1146. m_dispatch_catcher_node.m_following_flag = true;
  1147. }
  1148. else
  1149. {
  1150. m_dispatch_catcher_node.m_following_flag = false;
  1151. }
  1152. }
  1153. }
  1154. else
  1155. {
  1156. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  1157. }
  1158. }
  1159. //else 无限等待
  1160. }
  1161. else
  1162. {
  1163. m_dispatch_carrier_node.m_error = m_dispatch_carrier_node.mp_main_carrier->change_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL);
  1164. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1165. {
  1166. m_dispatch_carrier_node.m_main_carrier_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL;
  1167. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1168. if ( m_dispatch_destination != 1107 && m_dispatch_destination != 1100 )
  1169. {
  1170. //如不是7号出口, 那么开启 抓取机器人
  1171. //注意了, 取车流程只有在这里, 抓取机器人的流程才开始
  1172. m_dispatch_catcher_node.m_dispatch_control_start_flag = true;
  1173. if ( tp_main_carrier->get_device_id() != 2 )
  1174. {
  1175. m_dispatch_catcher_node.m_following_flag = true;
  1176. }
  1177. else
  1178. {
  1179. m_dispatch_catcher_node.m_following_flag = false;
  1180. }
  1181. }
  1182. }
  1183. else
  1184. {
  1185. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  1186. }
  1187. }
  1188. break;
  1189. }
  1190. case DISPATCH_CARRIER_PICKUP_31://小跑车 进入车位
  1191. {
  1192. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_leave);
  1193. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1194. break;
  1195. }
  1196. case DISPATCH_CARRIER_PICKUP_32:
  1197. {
  1198. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1199. break;
  1200. }
  1201. case DISPATCH_CARRIER_PICKUP_33://小跑车 夹车
  1202. {
  1203. carrier_move_c(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_TIGHT);
  1204. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1205. break;
  1206. }
  1207. case DISPATCH_CARRIER_PICKUP_34:
  1208. {
  1209. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1210. break;
  1211. }
  1212. case DISPATCH_CARRIER_PICKUP_35://小跑车 回到中跑车
  1213. {
  1214. //注意了, 3楼的搬运器取车时, 机器人的位置必须在搬运器的上方.
  1215. if ( tp_main_carrier->get_device_id() == 2 )
  1216. {
  1217. //等待机器人调整到3楼搬运器的上方位置
  1218. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_16 )
  1219. {
  1220. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  1221. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1222. }
  1223. //else 无限等待
  1224. }
  1225. else
  1226. {
  1227. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  1228. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1229. }
  1230. break;
  1231. }
  1232. case DISPATCH_CARRIER_PICKUP_36:
  1233. {
  1234. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1235. break;
  1236. }
  1237. case DISPATCH_CARRIER_PICKUP_37://让中跑车回到电梯井
  1238. {
  1239. //如果不在2楼, 那么就要退回电梯井
  1240. if ( tp_main_carrier->get_device_id() == 0 && (tp_main_carrier->m_actual_coordinates_rows != 0 || m_dispatch_destination == 1100))
  1241. {
  1242. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  1243. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1244. }
  1245. else if ( tp_main_carrier->get_device_id() == 1 && (tp_main_carrier->m_actual_coordinates_rows != 0 || m_dispatch_destination == 1107))
  1246. {
  1247. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  1248. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1249. }
  1250. else if ( tp_main_carrier->get_device_id() == 2 )
  1251. {
  1252. //3楼搬运器取车后, 不用x轴移动, 直接准备交接
  1253. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_51);
  1254. }
  1255. else
  1256. {
  1257. //不用回电梯井, 直接准备x轴移动到出口上方
  1258. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_43);
  1259. }
  1260. break;
  1261. }
  1262. case DISPATCH_CARRIER_PICKUP_38://搬运器 释放空间锁
  1263. {
  1264. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1265. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1266. {
  1267. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_space_unlock(tp_main_carrier->get_device_id());
  1268. }
  1269. break;
  1270. }
  1271. case DISPATCH_CARRIER_PICKUP_39://收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  1272. {
  1273. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  1274. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1275. break;
  1276. }
  1277. case DISPATCH_CARRIER_PICKUP_40:
  1278. {
  1279. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1280. break;
  1281. }
  1282. case DISPATCH_CARRIER_PICKUP_41://电梯移动到2楼, (7号出口移动到1楼), 搬运器在电梯里面z轴移动, 不需要判断空间锁
  1283. {
  1284. float t_z =0;
  1285. if ( (m_dispatch_destination == 1107 && tp_main_carrier->get_device_id() == 1) ||
  1286. (m_dispatch_destination == 1100 && tp_main_carrier->get_device_id() == 0) )//1楼出口
  1287. {
  1288. t_z = tp_dispatch_coordinates->m_carrier_1th_floor_z;
  1289. }
  1290. else if ( m_dispatch_destination >1100 && m_dispatch_destination<1107 )
  1291. {
  1292. t_z = tp_dispatch_coordinates->m_carrier_2th_floor_z;
  1293. }
  1294. else
  1295. {
  1296. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  1297. break;//直接跳转到故障
  1298. }
  1299. carrier_move_z(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_z);
  1300. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1301. break;
  1302. }
  1303. case DISPATCH_CARRIER_PICKUP_42:
  1304. {
  1305. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1306. break;
  1307. }
  1308. case DISPATCH_CARRIER_PICKUP_43://伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  1309. {
  1310. if ( tp_main_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK )
  1311. {
  1312. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  1313. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1314. }
  1315. else
  1316. {
  1317. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  1318. }
  1319. break;
  1320. }
  1321. case DISPATCH_CARRIER_PICKUP_44:
  1322. {
  1323. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1324. break;
  1325. }
  1326. case DISPATCH_CARRIER_PICKUP_45://中跑车 x轴移动, 进行x轴路径检查, 加空间锁失败就进入待机位
  1327. {
  1328. //7号出口, 就不用判断空间锁了, 直接x轴移动
  1329. if ( m_dispatch_destination == 1100 || m_dispatch_destination == 1107 )
  1330. {
  1331. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_80);
  1332. }
  1333. else
  1334. {
  1335. //等待机器人开始流程任务
  1336. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_2 )
  1337. {
  1338. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  1339. int t_terminal = m_dispatch_destination - PASSAGEWAY_ID_BASE;
  1340. int t_parity_flag = (t_terminal-1)%2;
  1341. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  1342. if ( Common_data::approximate_difference(tp_main_carrier->m_actual_x, t_x, DISPATCH_DEFAULT_DIFFERENCE) )
  1343. {
  1344. //搬运器不用x轴运动, 直接到50步, 准备交接
  1345. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_51);
  1346. }
  1347. else
  1348. {
  1349. int t_avoid_catcher_id = -1; //需要避让的机器人
  1350. if ( tp_main_carrier->get_device_id() == 0 && t_column <13-1)
  1351. {
  1352. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, 0,
  1353. tp_main_carrier->m_actual_coordinates_rows, t_column+1-t_parity_flag,
  1354. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  1355. }
  1356. else if ( tp_main_carrier->get_device_id() == 1 && t_column >3-1)
  1357. {
  1358. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, t_column-t_parity_flag,
  1359. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns-1,
  1360. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  1361. }
  1362. else if ( tp_main_carrier->get_device_id() == 2 )
  1363. {
  1364. //3楼搬运器不用加锁, 直接交接
  1365. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_51);
  1366. break;//切换流程
  1367. }
  1368. else
  1369. {
  1370. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  1371. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  1372. "DISPATCH_CARRIER_PICKUP_45 tp_main_carrier->get_device_id() and m_parkspace_information_optimal.parkingspace_index_id PARAMRTER ERROR ");
  1373. break;//切换流程
  1374. }
  1375. //判断结果
  1376. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1377. {
  1378. //左右搬运器加锁成功, 直接x轴移动
  1379. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_49);
  1380. }
  1381. else
  1382. {
  1383. //加锁失败, 就移动到待机位.
  1384. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1385. }
  1386. }
  1387. }
  1388. //没有抢到机器人的资源, 也要进入待机位
  1389. else
  1390. {
  1391. //移动到待机位.
  1392. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1393. }
  1394. }
  1395. break;
  1396. }
  1397. case DISPATCH_CARRIER_PICKUP_46://中跑车 x轴移动, 移动到待机位
  1398. {
  1399. if ( tp_main_carrier->get_device_id() == 0 )
  1400. {
  1401. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[2].x;
  1402. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  1403. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1404. }
  1405. else if ( tp_main_carrier->get_device_id() == 1 )
  1406. {
  1407. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[14].x;
  1408. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  1409. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1410. }
  1411. break;
  1412. }
  1413. case DISPATCH_CARRIER_PICKUP_47:
  1414. {
  1415. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1416. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1417. {
  1418. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_space_unlock(tp_main_carrier->get_device_id());
  1419. }
  1420. break;
  1421. }
  1422. case DISPATCH_CARRIER_PICKUP_48://中跑车 x轴移动, 进行x轴路径检查, 加空间锁失败就 只能无限等待
  1423. {
  1424. //等待机器人开始流程任务
  1425. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_2 )
  1426. {
  1427. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  1428. int t_terminal = m_dispatch_destination - PASSAGEWAY_ID_BASE;
  1429. int t_parity_flag = (t_terminal - 1) % 2;
  1430. int t_column = 4 + ((t_terminal - 1) / 2) * 3 + t_parity_flag * 2 - 1;
  1431. if (Common_data::approximate_difference(tp_main_carrier->m_actual_x, t_x, DISPATCH_DEFAULT_DIFFERENCE))
  1432. {
  1433. //搬运器不用x轴运动, 准备交接
  1434. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_51);
  1435. }
  1436. else
  1437. {
  1438. int t_avoid_catcher_id = -1; //需要避让的机器人
  1439. if (tp_main_carrier->get_device_id() == 0 && t_column < 13 - 1)
  1440. {
  1441. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(
  1442. tp_main_carrier->m_actual_coordinates_rows, 0,
  1443. tp_main_carrier->m_actual_coordinates_rows, t_column + 1 -t_parity_flag,
  1444. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  1445. }
  1446. else if (tp_main_carrier->get_device_id() == 1 && t_column > 3 - 1)
  1447. {
  1448. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(
  1449. tp_main_carrier->m_actual_coordinates_rows, t_column - t_parity_flag,
  1450. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns - 1,
  1451. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  1452. }
  1453. else if (tp_main_carrier->get_device_id() == 2)
  1454. {
  1455. //3楼搬运器不用加锁, 直接交接
  1456. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_51);
  1457. break;//切换流程
  1458. }
  1459. else
  1460. {
  1461. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  1462. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR,
  1463. Error_level::MINOR_ERROR,
  1464. "DISPATCH_CARRIER_PICKUP_48 tp_main_carrier->get_device_id() and m_parkspace_information_optimal.parkingspace_index_id PARAMRTER ERROR ");
  1465. break;//切换流程
  1466. }
  1467. //判断结果
  1468. if (m_dispatch_carrier_node.m_error == Error_code::SUCCESS)
  1469. {
  1470. //左右搬运器加锁成功, 直接x轴移动
  1471. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (
  1472. m_dispatch_carrier_node.m_dispatch_control_status + 1);
  1473. }
  1474. //else 无限等待
  1475. }
  1476. }
  1477. break;
  1478. }
  1479. case DISPATCH_CARRIER_PICKUP_49://中跑车 x轴移动, 移动到取车口的上方2楼处
  1480. {
  1481. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  1482. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  1483. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1484. break;
  1485. }
  1486. case DISPATCH_CARRIER_PICKUP_50:
  1487. {
  1488. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1489. break;
  1490. }
  1491. case DISPATCH_CARRIER_PICKUP_51://小跑车 松开夹杆
  1492. {
  1493. carrier_move_c(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_LOOSE);
  1494. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1495. break;
  1496. }
  1497. case DISPATCH_CARRIER_PICKUP_52:
  1498. {
  1499. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1500. break;
  1501. }
  1502. case DISPATCH_CARRIER_PICKUP_53://等待机器人把车从搬运器上面取走
  1503. {
  1504. // 等待机器人把车从搬运器上面取走
  1505. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_25 )
  1506. {
  1507. if ( tp_main_carrier->get_device_id() == 2 )
  1508. {
  1509. //进入3楼搬运器取车的特殊流程, 跟随和避让
  1510. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_70;
  1511. }
  1512. else
  1513. {
  1514. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1515. }
  1516. }
  1517. //else 无限等待
  1518. break;
  1519. }
  1520. case DISPATCH_CARRIER_PICKUP_54://搬运器退回电梯井
  1521. {
  1522. if ( tp_main_carrier->get_device_id() == 0 )
  1523. {
  1524. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  1525. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1526. }
  1527. else if ( tp_main_carrier->get_device_id() == 1 )
  1528. {
  1529. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  1530. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1531. }
  1532. else
  1533. {
  1534. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  1535. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  1536. "DISPATCH_CARRIER_PICKUP_54 tp_main_carrier->get_device_id() PARAMRTER ERROR ");
  1537. }
  1538. break;
  1539. }
  1540. case DISPATCH_CARRIER_PICKUP_55://搬运器 释放空间锁
  1541. {
  1542. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1543. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  1544. {
  1545. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_space_unlock(tp_main_carrier->get_device_id());
  1546. }
  1547. break;
  1548. }
  1549. case DISPATCH_CARRIER_PICKUP_56://收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  1550. {
  1551. //7号出口, 必须收回对接
  1552. if ( m_dispatch_destination == 1100 || m_dispatch_destination == 1107 )
  1553. {
  1554. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  1555. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1556. }
  1557. //如果后面有一级存车任务, 那么就跳过
  1558. else if ( tp_main_carrier->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL) ||
  1559. tp_main_carrier->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL))
  1560. {
  1561. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  1562. }
  1563. else
  1564. {
  1565. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  1566. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1567. }
  1568. break;
  1569. }
  1570. case DISPATCH_CARRIER_PICKUP_57:
  1571. {
  1572. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1573. break;
  1574. }
  1575. case DISPATCH_CARRIER_PICKUP_58://主搬运器 断连
  1576. {
  1577. disconnect_dispatch_device(m_dispatch_carrier_node.mp_main_carrier, m_dispatch_carrier_node.mp_main_carrier_task);
  1578. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_END);
  1579. break;
  1580. }
  1581. case DISPATCH_CARRIER_PICKUP_70://3楼搬运器跟随, 到机器人旁边一个车位
  1582. {
  1583. // 3楼搬运器 最好和机器人一起移动
  1584. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_26 )
  1585. {
  1586. //3楼搬运器跟随, 到机器人旁边一个车位
  1587. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  1588. float t_following_x = 0;
  1589. if ( m_dispatch_destination == 1101 )
  1590. {
  1591. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[1102].x;
  1592. }
  1593. else if ( m_dispatch_destination == 1106 )
  1594. {
  1595. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[1105].x;
  1596. }
  1597. else if ( tp_main_carrier->m_actual_x < t_x)
  1598. {
  1599. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination-1].x;
  1600. }
  1601. else
  1602. {
  1603. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination+1].x;
  1604. }
  1605. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_following_x);
  1606. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1607. }
  1608. break;
  1609. }
  1610. case DISPATCH_CARRIER_PICKUP_71:
  1611. {
  1612. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1613. break;
  1614. }
  1615. case DISPATCH_CARRIER_PICKUP_72://3楼搬运器移到机器人下方
  1616. {
  1617. //如果后面有一级存车任务, 那么就跳过
  1618. //注意了:如果主搬运器是3楼的, 那么也要判断机器人
  1619. if ( tp_main_carrier->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL) ||
  1620. tp_main_carrier->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL) ||
  1621. m_dispatch_catcher_node.mp_main_catcher->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL) ||
  1622. m_dispatch_catcher_node.mp_main_catcher->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL) )
  1623. {
  1624. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  1625. }
  1626. else
  1627. {
  1628. if ( m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_PICKUP_38 )
  1629. {
  1630. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  1631. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  1632. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1633. }
  1634. //else 无限等待
  1635. }
  1636. break;
  1637. }
  1638. case DISPATCH_CARRIER_PICKUP_73:
  1639. {
  1640. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1641. break;
  1642. }
  1643. case DISPATCH_CARRIER_PICKUP_74://主搬运器 断连
  1644. {
  1645. disconnect_dispatch_device(m_dispatch_carrier_node.mp_main_carrier, m_dispatch_carrier_node.mp_main_carrier_task);
  1646. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_END);
  1647. break;
  1648. }
  1649. case DISPATCH_CARRIER_PICKUP_80://中跑车 x轴移动, 移动到7号取车口
  1650. {
  1651. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  1652. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  1653. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1654. break;
  1655. }
  1656. case DISPATCH_CARRIER_PICKUP_81:
  1657. {
  1658. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1659. break;
  1660. }
  1661. case DISPATCH_CARRIER_PICKUP_82://小跑车 进入车位
  1662. {
  1663. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_leave);
  1664. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1665. break;
  1666. }
  1667. case DISPATCH_CARRIER_PICKUP_83:
  1668. {
  1669. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1670. break;
  1671. }
  1672. case DISPATCH_CARRIER_PICKUP_84://小跑车 松开车
  1673. {
  1674. carrier_move_c(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_LOOSE);
  1675. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1676. break;
  1677. }
  1678. case DISPATCH_CARRIER_PICKUP_85:
  1679. {
  1680. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1681. break;
  1682. }
  1683. case DISPATCH_CARRIER_PICKUP_86://小跑车 回到中跑车
  1684. {
  1685. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  1686. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  1687. break;
  1688. }
  1689. case DISPATCH_CARRIER_PICKUP_87:
  1690. {
  1691. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  1692. break;
  1693. }
  1694. case DISPATCH_CARRIER_PICKUP_88:
  1695. {
  1696. //回到正常流程
  1697. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_54);
  1698. break;
  1699. }
  1700. case DISPATCH_CARRIER_PICKUP_END:
  1701. {
  1702. m_dispatch_carrier_node.m_error = Error_code::SUCCESS;
  1703. break;
  1704. }
  1705. default:
  1706. {
  1707. break;
  1708. }
  1709. }
  1710. std::cout << " huli test :::: " << " ======================================================================================== = " << "carrier end" << std::endl;
  1711. std::cout << " huli test :::: " << " m_dispatch_carrier_node.m_dispatch_control_status = " << m_dispatch_carrier_node.m_dispatch_control_status << std::endl;
  1712. if ( m_dispatch_carrier_node.mp_main_carrier.get() != NULL )
  1713. {
  1714. std::cout << " huli test :::: " << " tp_main_carrier->get_device_id() = " << m_dispatch_carrier_node.mp_main_carrier->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_main_carrier->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_main_carrier->get_dispatch_device_status() << std::endl;
  1715. }
  1716. else
  1717. {
  1718. std::cout << " huli test :::: " << " tp_main_carrier->get_device_id() = " << -8888 << std::endl;
  1719. }
  1720. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL )
  1721. {
  1722. std::cout << " huli test :::: " << " tp_avoid_catcher->get_device_id() = " << m_dispatch_carrier_node.mp_avoid_catcher->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_avoid_catcher->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_avoid_catcher->get_dispatch_device_status() << std::endl;
  1723. }
  1724. else
  1725. {
  1726. std::cout << " huli test :::: " << " tp_avoid_catcher->get_device_id() = " << -8888 << std::endl;
  1727. }
  1728. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() != NULL )
  1729. {
  1730. std::cout << " huli test :::: " << " tp_avoid_carrier->get_device_id() = " << m_dispatch_carrier_node.mp_avoid_carrier->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_avoid_carrier->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_avoid_carrier->get_dispatch_device_status() << std::endl;
  1731. }
  1732. else
  1733. {
  1734. std::cout << " huli test :::: " << " tp_avoid_carrier->get_device_id() = " << -8888 << std::endl;
  1735. }
  1736. #ifdef PROCESS_TEST
  1737. char cr;
  1738. std::cin >> cr ;
  1739. #endif
  1740. std::cout << " huli test :::: " << " ----------------------------------------------------------------------------------------- = " << "catcher start" << std::endl;
  1741. std::cout << " huli test :::: " << " m_dispatch_catcher_node.m_dispatch_control_status = " << m_dispatch_catcher_node.m_dispatch_control_status << std::endl;
  1742. if ( m_dispatch_catcher_node.mp_main_catcher.get() != NULL )
  1743. {
  1744. std::cout << " huli test :::: " << " tp_main_catcher->get_device_id() = " << m_dispatch_catcher_node.mp_main_catcher->get_device_id() <<" + "<< m_dispatch_catcher_node.mp_main_catcher->get_current_command_key() <<" + "<< m_dispatch_catcher_node.mp_main_catcher->get_dispatch_device_status() << std::endl;
  1745. }
  1746. else
  1747. {
  1748. std::cout << " huli test :::: " << " tp_main_catcher->get_device_id() = " << -8888 << std::endl;
  1749. }
  1750. if ( m_dispatch_catcher_node.mp_following_carrier.get() != NULL )
  1751. {
  1752. std::cout << " huli test :::: " << " tp_following_carrier->get_device_id() = " << m_dispatch_catcher_node.mp_following_carrier->get_device_id() <<" + " << m_dispatch_catcher_node.mp_following_carrier->get_current_command_key()<<" + "<< m_dispatch_catcher_node.mp_following_carrier->get_dispatch_device_status() << std::endl;
  1753. }
  1754. else
  1755. {
  1756. std::cout << " huli test :::: " << " tp_following_carrier->get_device_id() = " << -8888 << std::endl;
  1757. }
  1758. Error_manager t_catcher_error;
  1759. Catcher * tp_main_catcher = NULL;
  1760. Catcher_task * tp_main_catcher_task = NULL;
  1761. if ( m_dispatch_catcher_node.mp_main_catcher.get() != NULL && m_dispatch_catcher_node.mp_main_catcher_task.get() != NULL )
  1762. {
  1763. tp_main_catcher = (Catcher *)m_dispatch_catcher_node.mp_main_catcher.get();
  1764. tp_main_catcher_task = (Catcher_task *)m_dispatch_catcher_node.mp_main_catcher_task.get();
  1765. //一级任务被打断后, 重新执行
  1766. if ( tp_main_catcher->get_break_flag() )
  1767. {
  1768. if ( m_dispatch_catcher_node.m_main_catcher_task_level == Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL )
  1769. {
  1770. m_dispatch_catcher_node.m_dispatch_control_status = DISPATCH_CATCHER_PICKUP_START;
  1771. }
  1772. tp_main_catcher->set_break_flag(false);
  1773. }
  1774. }
  1775. Carrier * tp_following_carrier = NULL;
  1776. Carrier_task * tp_following_carrier_task = NULL;
  1777. if ( m_dispatch_catcher_node.mp_following_carrier.get() != NULL && m_dispatch_catcher_node.mp_following_carrier_task.get() != NULL )
  1778. {
  1779. tp_following_carrier = (Carrier *)m_dispatch_catcher_node.mp_following_carrier.get();
  1780. tp_following_carrier_task = (Carrier_task *)m_dispatch_catcher_node.mp_following_carrier_task.get();
  1781. }
  1782. //抓取器的控制动作
  1783. switch ( m_dispatch_catcher_node.m_dispatch_control_status )
  1784. {
  1785. case DISPATCH_CONTROL_CREATED:
  1786. case DISPATCH_CONTROL_READY:
  1787. {
  1788. m_dispatch_catcher_node.m_error = check_main_catcher(m_dispatch_catcher_node);
  1789. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  1790. {
  1791. if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_PICKUP )
  1792. {
  1793. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_PICKUP_START;
  1794. }
  1795. else if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_STORE )
  1796. {
  1797. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_START;
  1798. }
  1799. }
  1800. //else 原地等待
  1801. break;
  1802. }
  1803. case DISPATCH_CATCHER_PICKUP_START://连接机器人, 创建新的任务单 与设备建立连接
  1804. {
  1805. if ( m_dispatch_catcher_node.mp_main_catcher.get() == NULL )
  1806. {
  1807. m_dispatch_catcher_node.mp_main_catcher = Dispatch_manager::get_instance_references().m_catcher_map[1];
  1808. }
  1809. if ( m_dispatch_catcher_node.mp_main_catcher_task.get() == NULL )
  1810. {
  1811. m_dispatch_catcher_node.m_error = m_dispatch_catcher_node.mp_main_catcher->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  1812. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  1813. {
  1814. m_dispatch_catcher_node.m_error = connect_dispatch_catcher(m_dispatch_catcher_node.mp_main_catcher, m_dispatch_catcher_node.mp_main_catcher_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  1815. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  1816. {
  1817. m_dispatch_catcher_node.m_main_catcher_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL;
  1818. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  1819. }
  1820. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  1821. }
  1822. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  1823. }
  1824. else
  1825. {
  1826. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  1827. }
  1828. break;
  1829. }
  1830. case DISPATCH_CATCHER_PICKUP_1:
  1831. {
  1832. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  1833. break;
  1834. }
  1835. case DISPATCH_CATCHER_PICKUP_2://机器人 准备开始, 需要同步任务单和设备真实数据
  1836. {
  1837. //机器人 准备开始, 需要同步任务单和设备真实数据.//注意了:连接设备只是预约, 设备不一定立刻执行.所以需要在连接成功之后进行数据同步
  1838. catcher_ready_to_start(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  1839. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  1840. break;
  1841. }
  1842. case DISPATCH_CATCHER_PICKUP_3:
  1843. {
  1844. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  1845. //注意了:同步失败,需要重新同步.
  1846. if ( m_dispatch_catcher_node.m_error != Error_code::SUCCESS )
  1847. {
  1848. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_PICKUP_2);
  1849. }
  1850. break;
  1851. }
  1852. case DISPATCH_CATCHER_PICKUP_4://机器手调整到 正常待机的姿态(调节夹杆和轴距)
  1853. {
  1854. if ( tp_main_catcher->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  1855. {
  1856. if ( tp_main_catcher->m_actual_clamp_motion1 != Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE ||
  1857. tp_main_catcher->m_actual_d1 + tp_main_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance >
  1858. tp_dispatch_coordinates->m_catcher_wheel_base_limit ||
  1859. tp_main_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_UNKNOW )
  1860. {
  1861. catcher_adjust_to_ready(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  1862. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  1863. }
  1864. else
  1865. {
  1866. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  1867. }
  1868. }
  1869. else
  1870. {
  1871. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  1872. m_dispatch_catcher_node.m_error = Error_manager(Error_code::CATCHER_POSE_ERROR, Error_level::MINOR_ERROR,
  1873. "DISPATCH_CATCHER_PICKUP_4 Dispatch_process::excute_robot_catch_car_from_carrier() fun error ");
  1874. }
  1875. break;
  1876. }
  1877. case DISPATCH_CATCHER_PICKUP_5:
  1878. {
  1879. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  1880. break;
  1881. }
  1882. case DISPATCH_CATCHER_PICKUP_6://机器手 调整z轴, (z轴上升到4楼. 不需要判断空间锁)
  1883. {
  1884. if ( tp_main_catcher->m_actual_z*1.02 >= tp_dispatch_coordinates->m_catcher_4th_floor_z )
  1885. {
  1886. //检测正常, 直接跳过即可
  1887. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  1888. }
  1889. else
  1890. {
  1891. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  1892. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  1893. }
  1894. break;
  1895. }
  1896. case DISPATCH_CATCHER_PICKUP_7://机器人释放 空间锁
  1897. {
  1898. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  1899. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  1900. {
  1901. tp_dispatch_coordinates->catcher_space_unlock(tp_main_catcher->m_actual_coordinates_id, tp_main_catcher->get_device_id());
  1902. }
  1903. break;
  1904. }
  1905. case DISPATCH_CATCHER_PICKUP_8://连接3楼的跟随机器人
  1906. {
  1907. if ( m_dispatch_catcher_node.m_following_flag )
  1908. {
  1909. if ( m_dispatch_catcher_node.mp_following_carrier.get() == NULL )
  1910. {
  1911. m_dispatch_catcher_node.mp_following_carrier = Dispatch_manager::get_instance_references().m_carrier_map[2];
  1912. }
  1913. if ( m_dispatch_catcher_node.mp_following_carrier_task.get() == NULL )
  1914. {
  1915. m_dispatch_catcher_node.m_error = m_dispatch_catcher_node.mp_following_carrier->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  1916. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  1917. {
  1918. m_dispatch_catcher_node.m_error = connect_dispatch_carrier(m_dispatch_catcher_node.mp_following_carrier, m_dispatch_catcher_node.mp_following_carrier_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  1919. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  1920. {
  1921. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  1922. }
  1923. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  1924. }
  1925. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  1926. }
  1927. else
  1928. {
  1929. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  1930. }
  1931. }
  1932. else
  1933. {
  1934. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  1935. }
  1936. break;
  1937. }
  1938. case DISPATCH_CATCHER_PICKUP_9:
  1939. {
  1940. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_following_carrier_task, m_dispatch_catcher_node.m_dispatch_control_status);
  1941. break;
  1942. }
  1943. case DISPATCH_CATCHER_PICKUP_10://搬运器 准备开始, 需要同步任务单和设备真实数据
  1944. {
  1945. if ( m_dispatch_catcher_node.m_following_flag )
  1946. {
  1947. //搬运器 准备开始, 需要同步任务单和设备真实数据.//注意了:连接设备只是预约, 设备不一定立刻执行.所以需要在连接成功之后进行数据同步
  1948. carrier_ready_to_start(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_following_carrier, tp_following_carrier_task, tp_dispatch_coordinates);
  1949. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  1950. }
  1951. else
  1952. {
  1953. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  1954. }
  1955. break;
  1956. }
  1957. case DISPATCH_CATCHER_PICKUP_11:
  1958. {
  1959. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_following_carrier_task, m_dispatch_catcher_node.m_dispatch_control_status);
  1960. //注意了:同步失败,需要重新同步.
  1961. if ( m_dispatch_catcher_node.m_error != Error_code::SUCCESS )
  1962. {
  1963. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_PICKUP_10);
  1964. }
  1965. break;
  1966. }
  1967. case DISPATCH_CATCHER_PICKUP_12://机器人 x轴移动之前, 判断空间锁.
  1968. {
  1969. int t_column = 0;
  1970. // 2楼交接, 在出口终点x交接 3楼交接, 在取车车位起点x交接,
  1971. if ( m_dispatch_catcher_node.m_following_flag )
  1972. {
  1973. int t_terminal = m_dispatch_destination - 1100;
  1974. int t_parity_flag = (t_terminal-1)%2;
  1975. t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  1976. }
  1977. else
  1978. {
  1979. t_column = (m_parkspace_information_optimal.parkingspace_index_id -1) % tp_dispatch_coordinates->m_space_lock_columns;
  1980. }
  1981. if ( tp_main_catcher->m_actual_coordinates_columns < t_column )
  1982. {
  1983. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, tp_main_catcher->m_actual_coordinates_columns,
  1984. 2, t_column+1,
  1985. tp_main_catcher->get_device_id());
  1986. }
  1987. else
  1988. {
  1989. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, t_column-1,
  1990. 2, tp_main_catcher->m_actual_coordinates_columns,
  1991. tp_main_catcher->get_device_id());
  1992. }
  1993. //判断结果
  1994. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  1995. {
  1996. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  1997. }
  1998. //else 无限等待
  1999. break;
  2000. }
  2001. case DISPATCH_CATCHER_PICKUP_13://机器手调整到 对接搬运器的姿态
  2002. {
  2003. float t_x = 0;
  2004. if ( m_dispatch_catcher_node.m_following_flag )
  2005. {
  2006. // 2楼交接, 在出口终点x交接
  2007. t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  2008. float t_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  2009. //机器手调整到 对接搬运器的姿态
  2010. catcher_adjust_from_carrier(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_x);
  2011. //3楼搬运器跟随, 到机器人旁边一个车位
  2012. float t_following_x = 0;
  2013. if ( m_dispatch_destination == 1101 )
  2014. {
  2015. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[1102].x;
  2016. }
  2017. else if ( m_dispatch_destination == 1106 )
  2018. {
  2019. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[1105].x;
  2020. }
  2021. else if ( tp_following_carrier->m_actual_x < t_x)
  2022. {
  2023. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination-1].x;
  2024. }
  2025. else
  2026. {
  2027. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination+1].x;
  2028. }
  2029. carrier_move_x(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_following_carrier, tp_following_carrier_task, tp_dispatch_coordinates, t_following_x);
  2030. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2031. }
  2032. else
  2033. {
  2034. if ( m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_28 )
  2035. {
  2036. //3楼交接, 在取车车位起点x交接,
  2037. t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].x;
  2038. float t_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  2039. //机器手调整到 对接搬运器的姿态
  2040. catcher_adjust_from_carrier(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_x);
  2041. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2042. }
  2043. //else 无限等待
  2044. }
  2045. break;
  2046. }
  2047. case DISPATCH_CATCHER_PICKUP_14://机器人释放 空间锁
  2048. {
  2049. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task);
  2050. if ( m_dispatch_catcher_node.m_following_flag )
  2051. {
  2052. m_dispatch_catcher_node.m_error.compare_and_cover_error(check_task_status(m_dispatch_catcher_node.mp_following_carrier_task));
  2053. }
  2054. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  2055. {
  2056. tp_dispatch_coordinates->catcher_space_unlock(tp_main_catcher->m_actual_coordinates_id, tp_main_catcher->get_device_id());
  2057. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2058. }
  2059. break;
  2060. }
  2061. case DISPATCH_CATCHER_PICKUP_15://机器手 准备下降抓车之前, 等待搬运器就位, 然后把一级任务升到三级
  2062. {
  2063. //2楼交接时, 机器人先等待, 再升级, 3楼交接时, 机器人先升级, 再等待,
  2064. if ( m_dispatch_catcher_node.m_following_flag )
  2065. {
  2066. // 2楼交接, 等待搬运器准备好, 机器人再升级
  2067. //等待搬运器就位, 把一级任务升到三级
  2068. if ( m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_51 )
  2069. {
  2070. m_dispatch_catcher_node.m_error = m_dispatch_catcher_node.mp_main_catcher->change_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL);
  2071. m_dispatch_catcher_node.m_error.compare_and_cover_error(m_dispatch_catcher_node.mp_following_carrier->change_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL));
  2072. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  2073. {
  2074. m_dispatch_catcher_node.m_main_catcher_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL;
  2075. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2076. }
  2077. else
  2078. {
  2079. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2080. }
  2081. }
  2082. //else 无限等待
  2083. }
  2084. else
  2085. {
  2086. //3楼交接, 机器人直接升级, 需要锁定位置, 不能为其他流程避让
  2087. m_dispatch_catcher_node.m_error = m_dispatch_catcher_node.mp_main_catcher->change_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL);
  2088. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  2089. {
  2090. m_dispatch_catcher_node.m_main_catcher_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL;
  2091. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2092. }
  2093. else
  2094. {
  2095. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2096. }
  2097. }
  2098. break;
  2099. }
  2100. case DISPATCH_CATCHER_PICKUP_16://机器手 z轴下降, 空间加锁
  2101. {
  2102. //2楼交接时, 机器人先等待, 再升级, 3楼交接时, 机器人先升级, 再等待,
  2103. if ( m_dispatch_catcher_node.m_following_flag )
  2104. {
  2105. //2楼交接的空间已经由搬运器加锁, 机器人下降时就不判断了, 强制加锁即可.
  2106. if ( m_dispatch_catcher_node.m_following_flag )//去3楼取车不用加锁
  2107. {
  2108. int t_terminal = m_dispatch_destination - 1100;
  2109. int t_parity_flag = (t_terminal-1)%2;
  2110. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  2111. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_force_space_lock(0, t_column-t_parity_flag,
  2112. 2, t_column+1-t_parity_flag,
  2113. tp_main_catcher->get_device_id());
  2114. }
  2115. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2116. }
  2117. else
  2118. {
  2119. if ( m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_51 )
  2120. {
  2121. //2楼交接的空间已经由搬运器加锁, 机器人下降时就不判断了, 强制加锁即可.
  2122. if ( m_dispatch_catcher_node.m_following_flag )//去3楼取车不用加锁
  2123. {
  2124. int t_terminal = m_dispatch_destination - 1100;
  2125. int t_parity_flag = (t_terminal-1)%2;
  2126. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  2127. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_force_space_lock(0, t_column-t_parity_flag,
  2128. 2, t_column+1-t_parity_flag,
  2129. tp_main_catcher->get_device_id());
  2130. }
  2131. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2132. }
  2133. //else 无限等待
  2134. }
  2135. break;
  2136. }
  2137. case DISPATCH_CATCHER_PICKUP_17://机器手 z轴下降
  2138. {
  2139. float t_z = 0;
  2140. if ( m_dispatch_catcher_node.m_following_flag )
  2141. {
  2142. //下降到2楼抓车
  2143. t_z = tp_dispatch_coordinates->m_catcher_2th_floor_z;
  2144. }
  2145. else
  2146. {
  2147. //下降到3楼抓车
  2148. t_z = tp_dispatch_coordinates->m_catcher_3th_floor_z;
  2149. }
  2150. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_z);
  2151. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2152. break;
  2153. }
  2154. case DISPATCH_CATCHER_PICKUP_18:
  2155. {
  2156. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2157. break;
  2158. }
  2159. case DISPATCH_CATCHER_PICKUP_19://交接车辆检查//修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  2160. {
  2161. //检查姿态(注注注注注意了, 调试阶段是无车, 真实环境是有车的)
  2162. if ( tp_main_catcher->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR &&
  2163. tp_main_catcher->m_actual_clamp_motion1 == Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE)
  2164. {
  2165. float temp_wheel_base = tp_main_catcher->m_actual_d1 + tp_main_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance;
  2166. //修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  2167. if ( Common_data::approximate_difference(m_wheel_base, temp_wheel_base, DISPATCH_DEFAULT_DIFFERENCE) )
  2168. {
  2169. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  2170. }
  2171. else
  2172. {
  2173. catcher_adjust_wheel_base(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  2174. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2175. }
  2176. }
  2177. else
  2178. {
  2179. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2180. m_dispatch_catcher_node.m_error = Error_manager(Error_code::CATCHER_POSE_ERROR, Error_level::MINOR_ERROR,
  2181. "DISPATCH_CATCHER_PICKUP_19 Dispatch_process:: tp_main_catcher->m_actual_load_status error ");
  2182. }
  2183. break;
  2184. }
  2185. case DISPATCH_CATCHER_PICKUP_20:
  2186. {
  2187. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2188. break;
  2189. }
  2190. case DISPATCH_CATCHER_PICKUP_21://机器手 夹车
  2191. {
  2192. //等待小跑车松开夹车杆
  2193. if ( m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_53 )
  2194. {
  2195. catcher_move_c(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, Catcher_task::Clamp_motion::E_CLAMP_TIGHT);
  2196. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2197. }
  2198. //else 无限等待
  2199. break;
  2200. }
  2201. case DISPATCH_CATCHER_PICKUP_22:
  2202. {
  2203. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2204. break;
  2205. }
  2206. case DISPATCH_CATCHER_PICKUP_23://机器手 z轴上升, 上升190mm就足以
  2207. {
  2208. // float t_z = 0;
  2209. // if ( m_dispatch_catcher_node.m_following_flag )
  2210. // {
  2211. // t_z = tp_dispatch_coordinates->m_catcher_2th_floor_z + tp_dispatch_coordinates->m_separated_distance_z;
  2212. // }
  2213. // else
  2214. // {
  2215. // t_z = tp_dispatch_coordinates->m_catcher_3th_floor_z + tp_dispatch_coordinates->m_separated_distance_z;
  2216. // }
  2217. //只能在最高处交接
  2218. float t_z = tp_dispatch_coordinates->m_catcher_4th_floor_z;
  2219. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_z);
  2220. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2221. break;
  2222. }
  2223. case DISPATCH_CATCHER_PICKUP_24:
  2224. {
  2225. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2226. break;
  2227. }
  2228. case DISPATCH_CATCHER_PICKUP_25://3楼机器人移动前加锁
  2229. {
  2230. int t_terminal = m_dispatch_destination - 1100;
  2231. int t_parity_flag = (t_terminal-1)%2;
  2232. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  2233. if ( tp_main_catcher->m_actual_coordinates_columns < t_column )
  2234. {
  2235. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, tp_main_catcher->m_actual_coordinates_columns,
  2236. 2, t_column+1,
  2237. tp_main_catcher->get_device_id());
  2238. }
  2239. else
  2240. {
  2241. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, t_column-1,
  2242. 2, tp_main_catcher->m_actual_coordinates_columns,
  2243. tp_main_catcher->get_device_id());
  2244. }
  2245. //判断结果
  2246. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  2247. {
  2248. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2249. }
  2250. //else 无限等待
  2251. break;
  2252. }
  2253. case DISPATCH_CATCHER_PICKUP_26://机器手调整到 准备把车放到地面的姿态
  2254. {
  2255. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  2256. float t_y = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].y;
  2257. if ( Common_data::approximate_difference(tp_main_catcher->m_actual_x, t_x, DISPATCH_DEFAULT_DIFFERENCE) &&
  2258. Common_data::approximate_difference(tp_main_catcher->m_actual_y, t_y, DISPATCH_DEFAULT_DIFFERENCE))
  2259. {
  2260. //检测正常, 直接跳过即可
  2261. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  2262. }
  2263. else
  2264. {
  2265. catcher_adjust_to_ground(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_x, t_y);
  2266. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2267. }
  2268. break;
  2269. }
  2270. case DISPATCH_CATCHER_PICKUP_27://机器人 释放空间锁
  2271. {
  2272. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2273. //注:只有3楼取车, 才会进行x轴移动, 需要解锁. 其他时候机器人在2楼, 不要释放空间锁
  2274. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS && m_dispatch_catcher_node.m_following_flag == false)
  2275. {
  2276. tp_dispatch_coordinates->catcher_space_unlock(tp_main_catcher->m_actual_coordinates_id, tp_main_catcher->get_device_id());
  2277. }
  2278. break;
  2279. }
  2280. case DISPATCH_CATCHER_PICKUP_28://等待搬运器离开后, 机器人就可以下降了
  2281. {
  2282. //等待搬运器离开后, 机器人就可以下降了
  2283. if ( (m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_56 &&
  2284. m_dispatch_carrier_node.m_dispatch_control_status <= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_58)
  2285. || (m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_72 &&
  2286. m_dispatch_carrier_node.m_dispatch_control_status <= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_74)
  2287. || (m_dispatch_carrier_node.m_dispatch_control_status == Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_END) )
  2288. {
  2289. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2290. }
  2291. else if(m_dispatch_carrier_node.m_dispatch_control_status == Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_55 &&
  2292. (Common_data::approximate_difference(tp_main_carrier->m_actual_x, tp_main_catcher->m_actual_x, tp_dispatch_coordinates->m_separated_distance_x) == false) )
  2293. {
  2294. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2295. }
  2296. //else 无限等待
  2297. break;
  2298. }
  2299. case DISPATCH_CATCHER_PICKUP_29://机器人z轴下降, 判断空间锁
  2300. {
  2301. //2楼交接这里就不加锁了, 因为前面已经加了, 但是3楼前面没有提前加锁, 这里就要加锁了
  2302. if ( m_dispatch_catcher_node.m_following_flag )
  2303. {
  2304. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2305. }
  2306. else
  2307. {
  2308. int t_terminal = m_dispatch_destination - 1100;
  2309. int t_parity_flag = (t_terminal-1)%2;
  2310. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  2311. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(0, t_column-t_parity_flag,
  2312. 2, t_column+1-t_parity_flag,
  2313. tp_main_catcher->get_device_id());
  2314. //判断结果
  2315. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  2316. {
  2317. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2318. }
  2319. //else 无限等待
  2320. }
  2321. break;
  2322. }
  2323. case DISPATCH_CATCHER_PICKUP_30://机器人下降到地面放车
  2324. {
  2325. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_1th_floor_z);
  2326. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2327. break;
  2328. }
  2329. case DISPATCH_CATCHER_PICKUP_31:
  2330. {
  2331. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2332. break;
  2333. }
  2334. case DISPATCH_CATCHER_PICKUP_32://机器手 松开夹杆
  2335. {
  2336. catcher_move_c(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, Catcher_task::Clamp_motion::E_CLAMP_LOOSE);
  2337. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2338. break;
  2339. }
  2340. case DISPATCH_CATCHER_PICKUP_33:
  2341. {
  2342. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2343. break;
  2344. }
  2345. case DISPATCH_CATCHER_PICKUP_34://机器手调整到 正常待机的姿态(调节夹杆和轴距)
  2346. {
  2347. if ( tp_main_catcher->m_actual_clamp_motion1 != Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE ||
  2348. tp_main_catcher->m_actual_d1 + tp_main_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance >
  2349. tp_dispatch_coordinates->m_catcher_wheel_base_limit ||
  2350. tp_main_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_UNKNOW )
  2351. {
  2352. catcher_adjust_to_ready(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  2353. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2354. }
  2355. else
  2356. {
  2357. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  2358. }
  2359. break;
  2360. }
  2361. case DISPATCH_CATCHER_PICKUP_35:
  2362. {
  2363. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2364. break;
  2365. }
  2366. case DISPATCH_CATCHER_PICKUP_36://机器手 调整z轴, z轴上升到4楼
  2367. {
  2368. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  2369. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2370. break;
  2371. }
  2372. case DISPATCH_CATCHER_PICKUP_37://机器人释放 空间锁
  2373. {
  2374. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2375. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  2376. {
  2377. tp_dispatch_coordinates->catcher_space_unlock(tp_main_catcher->m_actual_coordinates_id, tp_main_catcher->get_device_id());
  2378. }
  2379. break;
  2380. }
  2381. case DISPATCH_CATCHER_PICKUP_38://3楼的搬运器跟随到机器人下方
  2382. {
  2383. //如果后面有一级存车任务, 那么就跳过
  2384. if ( m_dispatch_catcher_node.m_following_flag &&
  2385. tp_main_catcher->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL) == false &&
  2386. tp_main_catcher->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL) == false)
  2387. {
  2388. float t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_destination].x;
  2389. carrier_move_x(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_following_carrier, tp_following_carrier_task, tp_dispatch_coordinates, t_following_x);
  2390. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  2391. }
  2392. else
  2393. {
  2394. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  2395. }
  2396. break;
  2397. }
  2398. case DISPATCH_CATCHER_PICKUP_39:
  2399. {
  2400. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_following_carrier_task, m_dispatch_catcher_node.m_dispatch_control_status);
  2401. break;
  2402. }
  2403. case DISPATCH_CATCHER_PICKUP_40://主机器人 断连
  2404. {
  2405. disconnect_dispatch_device(m_dispatch_catcher_node.mp_main_catcher, m_dispatch_catcher_node.mp_main_catcher_task);
  2406. if ( m_dispatch_catcher_node.m_following_flag )
  2407. {
  2408. disconnect_dispatch_device(m_dispatch_catcher_node.mp_following_carrier, m_dispatch_catcher_node.mp_following_carrier_task);
  2409. }
  2410. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_PICKUP_END);
  2411. break;
  2412. }
  2413. case DISPATCH_CATCHER_PICKUP_END:
  2414. {
  2415. m_dispatch_catcher_node.m_error = Error_code::SUCCESS;
  2416. break;
  2417. }
  2418. default:
  2419. {
  2420. break;
  2421. }
  2422. }
  2423. std::cout << " huli test :::: " << " ---------------------------------------------------------------------------------------------------------------------------- = " << "catcher end" << std::endl;
  2424. std::cout << " huli test :::: " << " m_dispatch_catcher_node.m_dispatch_control_status = " << m_dispatch_catcher_node.m_dispatch_control_status << std::endl;
  2425. if ( m_dispatch_catcher_node.mp_main_catcher.get() != NULL )
  2426. {
  2427. std::cout << " huli test :::: " << " tp_main_catcher->get_device_id() = " << m_dispatch_catcher_node.mp_main_catcher->get_device_id() <<" + "<< m_dispatch_catcher_node.mp_main_catcher->get_current_command_key() <<" + "<< m_dispatch_catcher_node.mp_main_catcher->get_dispatch_device_status() << std::endl;
  2428. }
  2429. else
  2430. {
  2431. std::cout << " huli test :::: " << " tp_main_catcher->get_device_id() = " << -8888 << std::endl;
  2432. }
  2433. if ( m_dispatch_catcher_node.mp_following_carrier.get() != NULL )
  2434. {
  2435. std::cout << " huli test :::: " << " tp_following_carrier->get_device_id() = " << m_dispatch_catcher_node.mp_following_carrier->get_device_id() <<" + " << m_dispatch_catcher_node.mp_following_carrier->get_current_command_key()<<" + "<< m_dispatch_catcher_node.mp_following_carrier->get_dispatch_device_status() << std::endl;
  2436. }
  2437. else
  2438. {
  2439. std::cout << " huli test :::: " << " tp_following_carrier->get_device_id() = " << -8888 << std::endl;
  2440. }
  2441. std::cout << " huli test :::: " << " +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ = " << 3 << std::endl;
  2442. std::cout << " huli test :::: " << " m_parkspace_information_optimal.parkingspace_index_id = " << m_parkspace_information_optimal.parkingspace_index_id << std::endl;
  2443. std::cout << " huli test :::: " << " m_dispatch_destination = " << m_dispatch_destination << std::endl;
  2444. #ifdef PROCESS_TEST
  2445. char ch;
  2446. std::cin >> ch ;
  2447. #endif
  2448. //结果汇总
  2449. if ( m_dispatch_carrier_node.m_dispatch_control_status == DISPATCH_CARRIER_PICKUP_END &&
  2450. (m_dispatch_catcher_node.m_dispatch_control_status == DISPATCH_CATCHER_PICKUP_END || m_dispatch_catcher_node.m_dispatch_control_status == DISPATCH_CONTROL_READY) )
  2451. {
  2452. return Error_code::SUCCESS;
  2453. }
  2454. else if ( m_dispatch_carrier_node.m_dispatch_control_status == DISPATCH_CONTROL_FAULT )
  2455. {
  2456. return m_dispatch_carrier_node.m_error;
  2457. }
  2458. else if(m_dispatch_catcher_node.m_dispatch_control_status == DISPATCH_CONTROL_FAULT)
  2459. {
  2460. return m_dispatch_catcher_node.m_error;
  2461. }
  2462. else
  2463. {
  2464. return Error_code::NODATA;
  2465. }
  2466. }
  2467. //调度控制存车
  2468. Error_manager Dispatch_process::dispatch_control_motion_store()
  2469. {
  2470. std::unique_lock<std::mutex> t_lock(m_lock);
  2471. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  2472. Error_manager t_carrier_error;
  2473. Carrier * tp_main_carrier = NULL;
  2474. Carrier_task * tp_main_carrier_task = NULL;
  2475. if ( m_dispatch_carrier_node.mp_main_carrier.get() != NULL && m_dispatch_carrier_node.mp_main_carrier_task.get() != NULL )
  2476. {
  2477. tp_main_carrier = (Carrier *)m_dispatch_carrier_node.mp_main_carrier.get();
  2478. tp_main_carrier_task = (Carrier_task *)m_dispatch_carrier_node.mp_main_carrier_task.get();
  2479. //一级任务被打断后, 重新执行
  2480. if ( tp_main_carrier->get_break_flag() )
  2481. {
  2482. if ( m_dispatch_carrier_node.m_main_carrier_task_level == Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL )
  2483. {
  2484. m_dispatch_carrier_node.m_dispatch_control_status = DISPATCH_CARRIER_STORE_START;
  2485. }
  2486. tp_main_carrier->set_break_flag(false);
  2487. }
  2488. }
  2489. Catcher * tp_avoid_catcher = NULL;
  2490. Catcher_task * tp_avoid_catcher_task = NULL;
  2491. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL && m_dispatch_carrier_node.mp_avoid_catcher_task.get() != NULL )
  2492. {
  2493. tp_avoid_catcher = (Catcher *)m_dispatch_carrier_node.mp_avoid_catcher.get();
  2494. tp_avoid_catcher_task = (Catcher_task *)m_dispatch_carrier_node.mp_avoid_catcher_task.get();
  2495. }
  2496. Carrier * tp_avoid_carrier = NULL;
  2497. Carrier_task * tp_avoid_carrier_task = NULL;
  2498. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() != NULL && m_dispatch_carrier_node.mp_avoid_carrier_task.get() != NULL )
  2499. {
  2500. tp_avoid_carrier = (Carrier *)m_dispatch_carrier_node.mp_avoid_carrier.get();
  2501. tp_avoid_carrier_task = (Carrier_task *)m_dispatch_carrier_node.mp_avoid_carrier_task.get();
  2502. }
  2503. std::cout << " huli test :::: " << " ===================================================================================================================== = " << "carrier start" << std::endl;
  2504. std::cout << " huli test :::: " << " m_dispatch_carrier_node.m_dispatch_control_status = " << m_dispatch_carrier_node.m_dispatch_control_status << std::endl;
  2505. if ( m_dispatch_carrier_node.mp_main_carrier.get() != NULL )
  2506. {
  2507. std::cout << " huli test :::: " << " tp_main_carrier->get_device_id() = " << m_dispatch_carrier_node.mp_main_carrier->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_main_carrier->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_main_carrier->get_dispatch_device_status() << std::endl;
  2508. }
  2509. else
  2510. {
  2511. std::cout << " huli test :::: " << " tp_main_carrier->get_device_id() = " << -8888 << std::endl;
  2512. }
  2513. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL )
  2514. {
  2515. std::cout << " huli test :::: " << " tp_avoid_catcher->get_device_id() = " << m_dispatch_carrier_node.mp_avoid_catcher->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_avoid_catcher->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_avoid_catcher->get_dispatch_device_status() << std::endl;
  2516. }
  2517. else
  2518. {
  2519. std::cout << " huli test :::: " << " tp_avoid_catcher->get_device_id() = " << -8888 << std::endl;
  2520. }
  2521. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() != NULL )
  2522. {
  2523. std::cout << " huli test :::: " << " tp_avoid_carrier->get_device_id() = " << m_dispatch_carrier_node.mp_avoid_carrier->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_avoid_carrier->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_avoid_carrier->get_dispatch_device_status() << std::endl;
  2524. }
  2525. else
  2526. {
  2527. std::cout << " huli test :::: " << " tp_avoid_carrier->get_device_id() = " << -8888 << std::endl;
  2528. }
  2529. //搬运器的控制动作
  2530. switch ( m_dispatch_carrier_node.m_dispatch_control_status )
  2531. {
  2532. case DISPATCH_CONTROL_CREATED:
  2533. case DISPATCH_CONTROL_READY://等待调度管理进行资源分配
  2534. {
  2535. m_dispatch_carrier_node.m_error = check_main_carrier(m_dispatch_carrier_node);
  2536. if (m_dispatch_carrier_node.m_error == Error_code::SUCCESS)
  2537. {
  2538. if (m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_PICKUP)
  2539. {
  2540. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_START;
  2541. }
  2542. else if (m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_STORE)
  2543. {
  2544. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_START;
  2545. }
  2546. }
  2547. //else 原地等待
  2548. break;
  2549. }
  2550. case DISPATCH_CARRIER_STORE_START://连接搬运器, 创建新的任务单 与设备建立连接
  2551. {
  2552. //注意了:3楼的存车流程, 需要机器人提前启动
  2553. if (m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 2)
  2554. {
  2555. //通知机器人提前开始
  2556. m_dispatch_catcher_node.m_dispatch_control_start_flag = true;
  2557. m_dispatch_catcher_node.m_following_flag = false;
  2558. //等待机器人正常连接之后, 搬运器才正式开始
  2559. if (m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_STORE_2)
  2560. {
  2561. if ( m_dispatch_carrier_node.mp_main_carrier_task.get() == NULL )
  2562. {
  2563. //连接搬运器, 创建新的任务单 与设备建立连接, 只能成功, 失败就要进入故障处理
  2564. m_dispatch_carrier_node.m_error = m_dispatch_carrier_node.mp_main_carrier->check_task_level(
  2565. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  2566. if (m_dispatch_carrier_node.m_error == Error_code::SUCCESS)
  2567. {
  2568. m_dispatch_carrier_node.m_error = connect_dispatch_carrier(m_dispatch_carrier_node.mp_main_carrier,
  2569. m_dispatch_carrier_node.mp_main_carrier_task,
  2570. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  2571. if (m_dispatch_carrier_node.m_error == Error_code::SUCCESS)
  2572. {
  2573. m_dispatch_carrier_node.m_main_carrier_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL;
  2574. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (
  2575. m_dispatch_carrier_node.m_dispatch_control_status + 1);
  2576. }
  2577. else
  2578. {
  2579. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2580. }
  2581. }
  2582. else
  2583. {
  2584. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2585. }
  2586. }
  2587. else
  2588. {
  2589. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (m_dispatch_carrier_node.m_dispatch_control_status + 2);
  2590. }
  2591. }
  2592. //else 无限等待
  2593. }
  2594. else
  2595. {
  2596. if ( m_dispatch_carrier_node.mp_main_carrier_task.get() == NULL )
  2597. {
  2598. //连接搬运器, 创建新的任务单 与设备建立连接, 只能成功, 失败就要进入故障处理
  2599. m_dispatch_carrier_node.m_error = m_dispatch_carrier_node.mp_main_carrier->check_task_level(
  2600. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  2601. if (m_dispatch_carrier_node.m_error == Error_code::SUCCESS)
  2602. {
  2603. m_dispatch_carrier_node.m_error = connect_dispatch_carrier(m_dispatch_carrier_node.mp_main_carrier,
  2604. m_dispatch_carrier_node.mp_main_carrier_task,
  2605. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  2606. if (m_dispatch_carrier_node.m_error == Error_code::SUCCESS)
  2607. {
  2608. m_dispatch_carrier_node.m_main_carrier_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL;
  2609. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (
  2610. m_dispatch_carrier_node.m_dispatch_control_status + 1);
  2611. }
  2612. else
  2613. {
  2614. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2615. }
  2616. }
  2617. else
  2618. {
  2619. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2620. }
  2621. }
  2622. else
  2623. {
  2624. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (m_dispatch_carrier_node.m_dispatch_control_status + 2);
  2625. }
  2626. }
  2627. break;
  2628. }
  2629. case DISPATCH_CARRIER_STORE_1:
  2630. {
  2631. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task,
  2632. m_dispatch_carrier_node.m_dispatch_control_status);
  2633. break;
  2634. }
  2635. case DISPATCH_CARRIER_STORE_2://搬运器 准备开始, 需要同步任务单和设备真实数据
  2636. {
  2637. //注意了:3楼搬运器必须要和机器人联动, 所以必须等机器人连接上之后,搬运器才开始启动
  2638. if (m_dispatch_carrier_node.mp_main_carrier->get_device_id() == 2)
  2639. {
  2640. //等待机器人正常连接之后, 搬运器才正式开始
  2641. if (m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_STORE_2)
  2642. {
  2643. //搬运器 准备开始, 需要同步任务单和设备真实数据.//注意了:连接设备只是预约, 设备不一定立刻执行.所以需要在连接成功之后进行数据同步
  2644. carrier_ready_to_start(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier,
  2645. tp_main_carrier_task, tp_dispatch_coordinates);
  2646. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (m_dispatch_carrier_node.m_dispatch_control_status + 1);
  2647. }
  2648. //else 无限等待
  2649. }
  2650. else
  2651. {
  2652. //通知机器人提前开始
  2653. m_dispatch_catcher_node.m_dispatch_control_start_flag = true;
  2654. m_dispatch_catcher_node.m_following_flag = true;
  2655. //搬运器 准备开始, 需要同步任务单和设备真实数据.//注意了:连接设备只是预约, 设备不一定立刻执行.所以需要在连接成功之后进行数据同步
  2656. carrier_ready_to_start(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier,
  2657. tp_main_carrier_task, tp_dispatch_coordinates);
  2658. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (m_dispatch_carrier_node.m_dispatch_control_status + 1);
  2659. }
  2660. break;
  2661. }
  2662. case DISPATCH_CARRIER_STORE_3:
  2663. {
  2664. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task,
  2665. m_dispatch_carrier_node.m_dispatch_control_status);
  2666. //注意了:同步失败,需要重新同步.
  2667. if ( m_dispatch_carrier_node.m_error != Error_code::SUCCESS )
  2668. {
  2669. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_2);
  2670. }
  2671. break;
  2672. }
  2673. case DISPATCH_CARRIER_STORE_4://搬运器检查姿态 //搬运器调整到 正常待机的姿态(调节夹杆和轴距)
  2674. {
  2675. if ( tp_main_carrier->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  2676. {
  2677. if ( tp_main_carrier_task->m_request_clamp_motion == Carrier_task::Clamp_motion::E_CLAMP_LOOSE &&
  2678. Common_data::approximate_difference(m_wheel_base, tp_main_carrier->m_actual_y1-tp_main_carrier->m_actual_y2, DISPATCH_DEFAULT_DIFFERENCE))
  2679. {
  2680. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  2681. }
  2682. else
  2683. {
  2684. //搬运器调整到 正常待机的姿态(调节夹杆和轴距)
  2685. carrier_adjust_to_ready(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates);
  2686. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2687. }
  2688. }
  2689. else
  2690. {
  2691. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2692. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  2693. "DISPATCH_CARRIER_STORE_4 tp_carrier->m_actual_load_status != Dispatch_device_base::Load_status::NO_CAR fun error ");
  2694. }
  2695. break;
  2696. }
  2697. case DISPATCH_CARRIER_STORE_5:
  2698. {
  2699. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  2700. break;
  2701. }
  2702. case DISPATCH_CARRIER_STORE_6://让小跑车回到中跑车上, y轴移动
  2703. {
  2704. if ( Common_data::approximate_difference(tp_main_carrier->m_actual_y, tp_dispatch_coordinates->m_carrier_default_y_back, DISPATCH_DEFAULT_DIFFERENCE) )
  2705. {
  2706. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  2707. }
  2708. else
  2709. {
  2710. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  2711. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2712. }
  2713. break;
  2714. }
  2715. case DISPATCH_CARRIER_STORE_7:
  2716. {
  2717. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  2718. break;
  2719. }
  2720. case DISPATCH_CARRIER_STORE_8://让中跑车回到电梯井, 进行x轴路径检查
  2721. {
  2722. if ( tp_main_carrier->get_device_id() == 2 )
  2723. {
  2724. //3楼的搬运器直接到 入口旁边一个车位
  2725. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_17);
  2726. }
  2727. else
  2728. {
  2729. //其他搬运器到2楼入口去接车
  2730. float t_z = tp_dispatch_coordinates->m_carrier_2th_floor_z;
  2731. if ( Common_data::approximate_difference(tp_main_carrier->m_actual_z, t_z, DISPATCH_DEFAULT_DIFFERENCE) )
  2732. {
  2733. //就在2楼, 那么准备同层移动到入口接车
  2734. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_15);
  2735. }
  2736. else
  2737. {
  2738. //搬运器不在2楼或者3楼, 搬运器在4楼及以上, 那么直接返回电梯井即可.
  2739. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2740. }
  2741. }
  2742. break;
  2743. }
  2744. case DISPATCH_CARRIER_STORE_9://让中跑车回到电梯井, x轴移动
  2745. {
  2746. if ( tp_main_carrier->get_device_id() == 0 )
  2747. {
  2748. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  2749. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2750. }
  2751. else if ( tp_main_carrier->get_device_id() == 1 )
  2752. {
  2753. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  2754. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2755. }
  2756. else
  2757. {
  2758. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2759. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  2760. "DISPATCH_CARRIER_STORE_9 tp_main_carrier->get_device_id() PARAMRTER ERROR ");
  2761. }
  2762. break;
  2763. }
  2764. case DISPATCH_CARRIER_STORE_10://搬运器 释放空间锁
  2765. {
  2766. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  2767. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  2768. {
  2769. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_space_unlock(tp_main_carrier->get_device_id());
  2770. }
  2771. break;
  2772. }
  2773. case DISPATCH_CARRIER_STORE_11://中跑车收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  2774. {
  2775. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  2776. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2777. break;
  2778. }
  2779. case DISPATCH_CARRIER_STORE_12:
  2780. {
  2781. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  2782. break;
  2783. }
  2784. case DISPATCH_CARRIER_STORE_13: //电梯移动到对应的楼层, 搬运器在电梯里面z轴移动, 不需要判断空间锁
  2785. {
  2786. //其他搬运器到2楼入口去接车
  2787. float t_z = tp_dispatch_coordinates->m_carrier_2th_floor_z;
  2788. carrier_move_z(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_z);
  2789. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2790. break;
  2791. }
  2792. case DISPATCH_CARRIER_STORE_14:
  2793. {
  2794. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  2795. break;
  2796. }
  2797. case DISPATCH_CARRIER_STORE_15://伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  2798. {
  2799. if ( tp_main_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK )
  2800. {
  2801. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  2802. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2803. }
  2804. else
  2805. {
  2806. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  2807. }
  2808. break;
  2809. }
  2810. case DISPATCH_CARRIER_STORE_16:
  2811. {
  2812. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  2813. break;
  2814. }
  2815. case DISPATCH_CARRIER_STORE_17://中跑车 x轴移动到入口, 进行x轴路径检查
  2816. {
  2817. //如果机器人已经把车抓起来了, 那么搬运器直接去入口接车即可
  2818. if ( m_dispatch_catcher_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_25 )
  2819. {
  2820. // 搬运器直接去入口接车即可
  2821. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_20);
  2822. }
  2823. if ( tp_main_carrier->get_device_id() == 2 )
  2824. {
  2825. if ( m_dispatch_catcher_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_8 )
  2826. {
  2827. //3楼搬运器不用加锁, 直接去待机位即可
  2828. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2829. break;//切换流程
  2830. }
  2831. //else 无限等待
  2832. }
  2833. else
  2834. {
  2835. //等待机器人升到三级任务, 搬运器移到待机位, (机器人到一楼抓车还需要一段时间.)
  2836. if ( m_dispatch_catcher_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_16 )
  2837. {
  2838. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x;
  2839. int t_terminal = m_dispatch_source - PASSAGEWAY_ID_BASE;
  2840. int t_parity_flag = (t_terminal-1)%2;
  2841. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  2842. //注意了:待机点在入口旁边一个大车位, 空间锁判断时, 距离2个小车位即可.
  2843. int t_avoid_catcher_id = -1; //需要避让的机器人
  2844. if ( tp_main_carrier->get_device_id() == 0 )
  2845. {
  2846. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, 0,
  2847. tp_main_carrier->m_actual_coordinates_rows, t_column-2,
  2848. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  2849. }
  2850. else if ( tp_main_carrier->get_device_id() == 1 )
  2851. {
  2852. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, t_column+2,
  2853. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns-1,
  2854. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  2855. }
  2856. else if ( tp_main_carrier->get_device_id() == 2 )
  2857. {
  2858. //3楼搬运器不用加锁, 直接去待机位即可
  2859. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2860. break;//切换流程
  2861. }
  2862. else
  2863. {
  2864. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2865. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  2866. "DISPATCH_CARRIER_STORE_17 tp_main_carrier->get_device_id() and m_parkspace_information_optimal.parkingspace_index_id PARAMRTER ERROR ");
  2867. break;//切换流程
  2868. }
  2869. //判断结果
  2870. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  2871. {
  2872. //左右搬运器加锁成功, 直接x轴移动到待机位
  2873. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2874. }
  2875. //else 在电梯井 无限等待
  2876. }
  2877. //else 在电梯井 无限等待
  2878. }
  2879. break;
  2880. }
  2881. case DISPATCH_CARRIER_STORE_18://中跑车 x轴移动, 移动到待机位, (待机点在入口旁边一个大车位)
  2882. {
  2883. //3楼搬运器跟随, 到机器人旁边一个车位
  2884. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x;
  2885. float t_following_x = 0;
  2886. //3楼搬运器特殊处理,
  2887. // 注意了: 机器人必须等待3楼搬运器执行完这一步后, 才能到一楼抓车
  2888. if ( tp_main_carrier->get_device_id() == 2 )
  2889. {
  2890. if ( m_dispatch_catcher_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_13 )
  2891. {
  2892. if ( m_dispatch_source == 1101 )
  2893. {
  2894. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[1102].x;
  2895. }
  2896. else if ( m_dispatch_source == 1106 )
  2897. {
  2898. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[1105].x;
  2899. }
  2900. else if ( tp_main_carrier->m_actual_x < t_x)
  2901. {
  2902. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source-1].x;
  2903. }
  2904. else
  2905. {
  2906. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source+1].x;
  2907. }
  2908. }
  2909. else //无限等待
  2910. {
  2911. break;
  2912. }
  2913. }
  2914. else if ( tp_main_carrier->get_device_id() == 0 )
  2915. {
  2916. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x - tp_dispatch_coordinates->m_separated_distance_x;
  2917. }
  2918. else if ( tp_main_carrier->get_device_id() == 1 )
  2919. {
  2920. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x + tp_dispatch_coordinates->m_separated_distance_x;
  2921. }
  2922. else
  2923. {
  2924. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2925. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  2926. "DISPATCH_CARRIER_STORE_18 tp_main_carrier->get_device_id() and m_parkspace_information_optimal.parkingspace_index_id PARAMRTER ERROR ");
  2927. break;//切换流程
  2928. }
  2929. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_following_x);
  2930. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2931. break;
  2932. }
  2933. case DISPATCH_CARRIER_STORE_19:
  2934. {
  2935. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  2936. break;
  2937. }
  2938. case DISPATCH_CARRIER_STORE_20://搬运器 准备接车之前, 等待机器人就位, 然后把一级任务升到三级
  2939. {
  2940. //等待机器人把车抓起来, 如果机器人已经把车抓起来了, 那么搬运器把一级任务升到三级
  2941. if ( m_dispatch_catcher_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_25 )
  2942. {
  2943. m_dispatch_carrier_node.m_error = m_dispatch_carrier_node.mp_main_carrier->change_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL);
  2944. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  2945. {
  2946. m_dispatch_carrier_node.m_main_carrier_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL;
  2947. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2948. }
  2949. else
  2950. {
  2951. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  2952. }
  2953. }
  2954. //else 无限等待
  2955. break;
  2956. }
  2957. case DISPATCH_CARRIER_STORE_21://搬运器移到入口接车, 对路径强制加锁, (机器人已经加空间锁了)
  2958. {
  2959. //2楼交接的空间已经由机器人加锁, 搬运器移到入口接车就不判断了, 强制加锁即可.
  2960. if ( tp_main_carrier->get_device_id() == 0 )
  2961. {
  2962. int t_terminal = m_dispatch_source - 1100;
  2963. int t_parity_flag = (t_terminal-1)%2;
  2964. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  2965. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_force_space_lock(0, 0,
  2966. 0, t_column+1-t_parity_flag,
  2967. tp_main_carrier->get_device_id());
  2968. }
  2969. else if ( tp_main_carrier->get_device_id() == 1 )
  2970. {
  2971. int t_terminal = m_dispatch_source - 1100;
  2972. int t_parity_flag = (t_terminal-1)%2;
  2973. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  2974. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_force_space_lock(0, t_column-t_parity_flag,
  2975. 0, tp_dispatch_coordinates->m_space_lock_columns-1,
  2976. tp_main_carrier->get_device_id());
  2977. }
  2978. //去3楼取车不用加锁
  2979. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2980. break;
  2981. }
  2982. case DISPATCH_CARRIER_STORE_22://中跑车 x轴移动, 移动到存车入口上方准备接车
  2983. {
  2984. //注意了: 3楼搬运器在停车位交接, 2楼搬运器在入口上方交接
  2985. float t_x = 0;
  2986. if ( tp_main_carrier->get_device_id() == 2 )
  2987. {
  2988. //3楼搬运器 最好和机器人一起运动
  2989. if ( m_dispatch_catcher_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_26 )
  2990. {
  2991. //need program , 这里设计到机器人和3楼搬运器的同步问题, 以后在写
  2992. t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].x;
  2993. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  2994. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  2995. }
  2996. //else 无限等待
  2997. }
  2998. else
  2999. {
  3000. t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x;
  3001. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  3002. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3003. }
  3004. break;
  3005. }
  3006. case DISPATCH_CARRIER_STORE_23:
  3007. {
  3008. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3009. break;
  3010. }
  3011. case DISPATCH_CARRIER_STORE_24://检查汽车交接//修正轴距
  3012. {
  3013. //检查姿态(注注注注注意了, 调试阶段是无车, 真实环境是有车的)
  3014. if ( tp_main_carrier->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR &&
  3015. tp_main_carrier->m_actual_clamp_motion1 == Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE)
  3016. {
  3017. float temp_wheel_base = tp_main_carrier->m_actual_y1 - tp_main_carrier->m_actual_y2;
  3018. if ( Common_data::approximate_difference(m_wheel_base, temp_wheel_base, DISPATCH_DEFAULT_DIFFERENCE) )
  3019. {
  3020. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  3021. }
  3022. else
  3023. {
  3024. carrier_adjust_wheel_base(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates);
  3025. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3026. }
  3027. }
  3028. else
  3029. {
  3030. return Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  3031. "DISPATCH_CARRIER_STORE_24 Dispatch_process:: tp_main_carrier->m_actual_load_status() fun error ");
  3032. }
  3033. break;
  3034. }
  3035. case DISPATCH_CARRIER_STORE_25:
  3036. {
  3037. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3038. break;
  3039. }
  3040. case DISPATCH_CARRIER_STORE_26://让小跑车 夹车
  3041. {
  3042. //等待机器人把车放到搬运器上面
  3043. if (m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_STORE_34)
  3044. {
  3045. carrier_move_c(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_TIGHT);
  3046. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3047. }
  3048. //else 无限等待
  3049. break;
  3050. }
  3051. case DISPATCH_CARRIER_STORE_27:
  3052. {
  3053. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3054. break;
  3055. }
  3056. case DISPATCH_CARRIER_STORE_28://让中跑车回到电梯井
  3057. {
  3058. //等待机器人离开
  3059. if (m_dispatch_catcher_node.m_dispatch_control_status >= DISPATCH_CATCHER_STORE_38)
  3060. {
  3061. //判断z轴 是否同层
  3062. float t_z = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].z;
  3063. if ( Common_data::approximate_difference(tp_main_carrier->m_actual_z, t_z, DISPATCH_DEFAULT_DIFFERENCE) )
  3064. {
  3065. //存车到2楼或3楼, 那么直接去停车位
  3066. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_36);
  3067. }
  3068. else
  3069. {
  3070. if ( tp_main_carrier->get_device_id() == 0 )
  3071. {
  3072. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  3073. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3074. }
  3075. else if ( tp_main_carrier->get_device_id() == 1 )
  3076. {
  3077. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  3078. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3079. }
  3080. else
  3081. {
  3082. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3083. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  3084. "DISPATCH_CARRIER_STORE_28 tp_main_carrier->get_device_id() PARAMRTER ERROR ");
  3085. }
  3086. }
  3087. }
  3088. //else 无限等待
  3089. break;
  3090. }
  3091. case DISPATCH_CARRIER_STORE_29://搬运器 释放空间锁
  3092. {
  3093. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3094. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  3095. {
  3096. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_space_unlock(tp_main_carrier->get_device_id());
  3097. }
  3098. break;
  3099. }
  3100. case DISPATCH_CARRIER_STORE_30://中跑车收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  3101. {
  3102. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  3103. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3104. break;
  3105. }
  3106. case DISPATCH_CARRIER_STORE_31:
  3107. {
  3108. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3109. break;
  3110. }
  3111. case DISPATCH_CARRIER_STORE_32: //电梯移动到对应的楼层, 搬运器在电梯里面z轴移动, 不需要判断空间锁
  3112. {
  3113. float t_z = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].z;
  3114. carrier_move_z(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_z);
  3115. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3116. break;
  3117. }
  3118. case DISPATCH_CARRIER_STORE_33:
  3119. {
  3120. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3121. break;
  3122. }
  3123. case DISPATCH_CARRIER_STORE_34://伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  3124. {
  3125. if ( tp_main_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK )
  3126. {
  3127. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  3128. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3129. }
  3130. else
  3131. {
  3132. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  3133. }
  3134. break;
  3135. }
  3136. case DISPATCH_CARRIER_STORE_35:
  3137. {
  3138. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3139. break;
  3140. }
  3141. case DISPATCH_CARRIER_STORE_36://中跑车 x轴移动到车位, 进行x轴路径检查
  3142. {
  3143. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].x;
  3144. int t_column = (m_parkspace_information_optimal.parkingspace_index_id-1) % tp_dispatch_coordinates->m_space_lock_columns;
  3145. if ( Common_data::approximate_difference(tp_main_carrier->m_actual_x, t_x, DISPATCH_DEFAULT_DIFFERENCE) )
  3146. {
  3147. //搬运器不用x轴运动, 直接去车位存车, (注:3楼的搬运器已经提前去停车位了, x值一定相同)
  3148. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_44);
  3149. }
  3150. else
  3151. {
  3152. int t_avoid_catcher_id = -1; //需要避让的机器人
  3153. if ( tp_main_carrier->get_device_id() == 0 && t_column <13-1)
  3154. {
  3155. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, 0,
  3156. tp_main_carrier->m_actual_coordinates_rows, t_column+1,
  3157. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  3158. }
  3159. else if ( tp_main_carrier->get_device_id() == 1 && t_column >3-1)
  3160. {
  3161. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, t_column-1,
  3162. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns-1,
  3163. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  3164. }
  3165. else
  3166. {
  3167. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3168. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  3169. "DISPATCH_CARRIER_STORE_36 tp_main_carrier->get_device_id() and m_parkspace_information_optimal.parkingspace_index_id PARAMRTER ERROR ");
  3170. break;//切换流程
  3171. }
  3172. //判断结果
  3173. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  3174. {
  3175. //左右搬运器加锁成功, 直接x轴移动
  3176. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_42);
  3177. }
  3178. else if(t_avoid_catcher_id != -1 &&
  3179. (tp_main_carrier->m_actual_coordinates_rows == 2 || tp_main_carrier->m_actual_coordinates_rows == 1))//4楼取车, 机器人进行避让
  3180. {
  3181. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() == NULL )
  3182. {
  3183. m_dispatch_carrier_node.mp_avoid_catcher = Dispatch_manager::get_instance_references().m_catcher_map[t_avoid_catcher_id];
  3184. }
  3185. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() == NULL )
  3186. {
  3187. m_dispatch_carrier_node.mp_avoid_carrier = Dispatch_manager::get_instance_references().m_carrier_map[2];
  3188. }
  3189. //连接4楼机器人和3楼搬运器
  3190. Error_manager t_catcher_error;
  3191. Error_manager t_carrier_error;
  3192. if ( m_dispatch_carrier_node.mp_avoid_catcher_task.get() == NULL && m_dispatch_carrier_node.mp_avoid_carrier_task.get() == NULL)
  3193. {
  3194. //连接避让设备 使得避让机器人进行避让
  3195. t_catcher_error = m_dispatch_carrier_node.mp_avoid_catcher->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  3196. t_carrier_error = m_dispatch_carrier_node.mp_avoid_carrier->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  3197. if ( t_catcher_error == Error_code::SUCCESS && t_carrier_error == Error_code::SUCCESS)
  3198. {
  3199. t_catcher_error = connect_dispatch_catcher(m_dispatch_carrier_node.mp_avoid_catcher, m_dispatch_carrier_node.mp_avoid_catcher_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  3200. if ( t_catcher_error == Error_code::SUCCESS )
  3201. {
  3202. t_carrier_error = connect_dispatch_carrier(m_dispatch_carrier_node.mp_avoid_carrier, m_dispatch_carrier_node.mp_avoid_carrier_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL);
  3203. if ( t_carrier_error == Error_code::SUCCESS )
  3204. {
  3205. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3206. }
  3207. else
  3208. {
  3209. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3210. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  3211. "DISPATCH_CARRIER_STORE_36 connect_dispatch_carrier ERROR ");
  3212. break;//切换流程
  3213. }
  3214. }
  3215. }
  3216. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  3217. }
  3218. else if ( m_dispatch_carrier_node.mp_avoid_catcher_task.get() != NULL && m_dispatch_carrier_node.mp_avoid_carrier_task.get() != NULL )
  3219. {
  3220. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+2);
  3221. }
  3222. else
  3223. {
  3224. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3225. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  3226. "DISPATCH_CARRIER_STORE_36 m_dispatch_carrier_node.mp_avoid_catcher_task.get() m_dispatch_carrier_node.mp_avoid_carrier_task.get() ERROR ");
  3227. break;//切换流程
  3228. }
  3229. }
  3230. //else 无限等待
  3231. }
  3232. break;
  3233. }
  3234. case DISPATCH_CARRIER_STORE_37:
  3235. {
  3236. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_avoid_catcher_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3237. break;
  3238. }
  3239. case DISPATCH_CARRIER_STORE_38://让4楼机器人进行避让, 先加锁, 在避让
  3240. {
  3241. //机器人避让距离, 4楼避让4个车位, 3楼避让2个车位
  3242. int m_avoid_distance = 0;
  3243. int t_row = (m_parkspace_information_optimal.parkingspace_index_id-1) / tp_dispatch_coordinates->m_space_lock_columns;
  3244. if ( t_row == 1 )
  3245. {
  3246. m_avoid_distance = 3;
  3247. }
  3248. else
  3249. {
  3250. m_avoid_distance = 3;
  3251. }
  3252. int t_column = (m_parkspace_information_optimal.parkingspace_index_id-1) % tp_dispatch_coordinates->m_space_lock_columns;
  3253. //4楼搬运器需要避让4个车位
  3254. if ( tp_main_carrier->get_device_id() == 0 && tp_avoid_catcher->m_actual_coordinates_columns < t_column+m_avoid_distance )
  3255. {
  3256. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, tp_avoid_catcher->m_actual_coordinates_columns,
  3257. 2, t_column+m_avoid_distance+1,
  3258. tp_avoid_catcher->get_device_id());
  3259. //判断结果
  3260. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  3261. {
  3262. //机器人移到42号口
  3263. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id+m_avoid_distance].x;
  3264. catcher_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_catcher, tp_avoid_catcher_task, tp_dispatch_coordinates, t_x);
  3265. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_carrier, tp_avoid_carrier_task, tp_dispatch_coordinates, t_x);
  3266. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3267. }
  3268. //else 无限等待
  3269. }
  3270. else if ( tp_main_carrier->get_device_id() == 1 && tp_avoid_catcher->m_actual_coordinates_columns > t_column-m_avoid_distance)
  3271. {
  3272. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, t_column-m_avoid_distance-1,
  3273. 2, tp_avoid_catcher->m_actual_coordinates_columns,
  3274. tp_avoid_catcher->get_device_id());
  3275. //判断结果
  3276. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  3277. {
  3278. //机器人移到34号口
  3279. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id-m_avoid_distance].x;
  3280. catcher_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_catcher, tp_avoid_catcher_task, tp_dispatch_coordinates, t_x);
  3281. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_avoid_carrier, tp_avoid_carrier_task, tp_dispatch_coordinates, t_x);
  3282. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3283. }
  3284. //else 无限等待
  3285. }
  3286. else
  3287. {
  3288. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3289. }
  3290. break;
  3291. }
  3292. case DISPATCH_CARRIER_STORE_39://机器人释放 空间锁
  3293. {
  3294. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_avoid_catcher_task);
  3295. m_dispatch_carrier_node.m_error.compare_and_cover_error(check_task_status(m_dispatch_carrier_node.mp_avoid_carrier_task));
  3296. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  3297. {
  3298. tp_dispatch_coordinates->catcher_space_unlock(tp_avoid_catcher->m_actual_coordinates_id, tp_avoid_catcher->get_device_id());
  3299. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3300. }
  3301. break;
  3302. }
  3303. case DISPATCH_CARRIER_STORE_40://搬运器空间锁判断, 必须成功
  3304. {
  3305. int t_column = (m_parkspace_information_optimal.parkingspace_index_id-1) % tp_dispatch_coordinates->m_space_lock_columns;
  3306. int t_avoid_catcher_id = -1; //需要避让的机器人
  3307. if ( tp_main_carrier->get_device_id() == 0 && t_column <13-1)
  3308. {
  3309. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, 0,
  3310. tp_main_carrier->m_actual_coordinates_rows, t_column+1,
  3311. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  3312. }
  3313. else if ( tp_main_carrier->get_device_id() == 1 && t_column >3-1)
  3314. {
  3315. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_try_space_lock(tp_main_carrier->m_actual_coordinates_rows, t_column-1,
  3316. tp_main_carrier->m_actual_coordinates_rows, tp_dispatch_coordinates->m_space_lock_columns-1,
  3317. tp_main_carrier->get_device_id(), t_avoid_catcher_id);
  3318. }
  3319. //判断结果
  3320. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  3321. {
  3322. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3323. }
  3324. else
  3325. {
  3326. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3327. }
  3328. break;
  3329. }
  3330. case DISPATCH_CARRIER_STORE_41://避让机器人 断连
  3331. {
  3332. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL && m_dispatch_carrier_node.mp_avoid_catcher_task.get() != NULL )
  3333. {
  3334. //避让机器人 断开连接
  3335. disconnect_dispatch_device(m_dispatch_carrier_node.mp_avoid_catcher, m_dispatch_carrier_node.mp_avoid_catcher_task);
  3336. }
  3337. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() != NULL && m_dispatch_carrier_node.mp_avoid_carrier_task.get() != NULL )
  3338. {
  3339. //避让机器人 断开连接
  3340. disconnect_dispatch_device(m_dispatch_carrier_node.mp_avoid_carrier, m_dispatch_carrier_node.mp_avoid_carrier_task);
  3341. }
  3342. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3343. break;
  3344. }
  3345. case DISPATCH_CARRIER_STORE_42://搬运器x轴移动到车位
  3346. {
  3347. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].x;
  3348. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, t_x);
  3349. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3350. break;
  3351. }
  3352. case DISPATCH_CARRIER_STORE_43:
  3353. {
  3354. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3355. break;
  3356. }
  3357. case DISPATCH_CARRIER_STORE_44://小跑车 进入车位
  3358. {
  3359. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_leave);
  3360. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3361. break;
  3362. }
  3363. case DISPATCH_CARRIER_STORE_45:
  3364. {
  3365. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3366. break;
  3367. }
  3368. case DISPATCH_CARRIER_STORE_46://小跑车 松开
  3369. {
  3370. carrier_move_c(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_LOOSE);
  3371. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3372. break;
  3373. }
  3374. case DISPATCH_CARRIER_STORE_47:
  3375. {
  3376. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3377. break;
  3378. }
  3379. case DISPATCH_CARRIER_STORE_48://小跑车 回到中跑车
  3380. {
  3381. carrier_move_y(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  3382. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3383. break;
  3384. }
  3385. case DISPATCH_CARRIER_STORE_49:
  3386. {
  3387. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3388. break;
  3389. }
  3390. case DISPATCH_CARRIER_STORE_50://让中跑车回到电梯井
  3391. {
  3392. if ( tp_main_carrier->get_device_id() == 2 )
  3393. {
  3394. //3楼的流程 到此结束了
  3395. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_54);
  3396. }
  3397. //2楼和4楼 必须回电梯井
  3398. else if ( tp_main_carrier->m_actual_coordinates_rows == 0 || tp_main_carrier->m_actual_coordinates_rows == 2 )
  3399. {
  3400. if ( tp_main_carrier->get_device_id() == 0 )
  3401. {
  3402. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  3403. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3404. }
  3405. else if ( tp_main_carrier->get_device_id() == 1 )
  3406. {
  3407. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  3408. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3409. }
  3410. else
  3411. {
  3412. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3413. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  3414. "DISPATCH_CARRIER_STORE_50 tp_main_carrier->get_device_id() PARAMRTER ERROR ");
  3415. }
  3416. }
  3417. //如果后面有一级存车任务, 那么就跳过, 否则让中跑车回到电梯井
  3418. else if ( tp_main_carrier->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL) ||
  3419. tp_main_carrier->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL))
  3420. {
  3421. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_54);
  3422. }
  3423. else
  3424. {
  3425. if ( tp_main_carrier->get_device_id() == 0 )
  3426. {
  3427. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  3428. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3429. }
  3430. else if ( tp_main_carrier->get_device_id() == 1 )
  3431. {
  3432. carrier_move_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  3433. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3434. }
  3435. else
  3436. {
  3437. m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3438. m_dispatch_carrier_node.m_error = Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  3439. "DISPATCH_CARRIER_STORE_50 tp_main_carrier->get_device_id() PARAMRTER ERROR ");
  3440. }
  3441. }
  3442. break;
  3443. }
  3444. case DISPATCH_CARRIER_STORE_51://搬运器 释放空间锁
  3445. {
  3446. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3447. if ( m_dispatch_carrier_node.m_error == Error_code::SUCCESS )
  3448. {
  3449. m_dispatch_carrier_node.m_error = tp_dispatch_coordinates->carrier_space_unlock(tp_main_carrier->get_device_id());
  3450. }
  3451. break;
  3452. }
  3453. case DISPATCH_CARRIER_STORE_52://收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  3454. {
  3455. carrier_joint_x(get_dispatch_control_command_key(m_dispatch_carrier_node), tp_main_carrier, tp_main_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  3456. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_carrier_node.m_dispatch_control_status+1);
  3457. break;
  3458. }
  3459. case DISPATCH_CARRIER_STORE_53:
  3460. {
  3461. m_dispatch_carrier_node.m_error = check_task_status(m_dispatch_carrier_node.mp_main_carrier_task, m_dispatch_carrier_node.m_dispatch_control_status);
  3462. break;
  3463. }
  3464. case DISPATCH_CARRIER_STORE_54://主搬运器 断连
  3465. {
  3466. disconnect_dispatch_device(m_dispatch_carrier_node.mp_main_carrier, m_dispatch_carrier_node.mp_main_carrier_task);
  3467. m_dispatch_carrier_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_END);
  3468. break;
  3469. }
  3470. }
  3471. std::cout << " huli test :::: " << " ======================================================================================== = " << "carrier end" << std::endl;
  3472. std::cout << " huli test :::: " << " m_dispatch_carrier_node.m_dispatch_control_status = " << m_dispatch_carrier_node.m_dispatch_control_status << std::endl;
  3473. if ( m_dispatch_carrier_node.mp_main_carrier.get() != NULL )
  3474. {
  3475. std::cout << " huli test :::: " << " tp_main_carrier->get_device_id() = " << m_dispatch_carrier_node.mp_main_carrier->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_main_carrier->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_main_carrier->get_dispatch_device_status() << std::endl;
  3476. }
  3477. else
  3478. {
  3479. std::cout << " huli test :::: " << " tp_main_carrier->get_device_id() = " << -8888 << std::endl;
  3480. }
  3481. if ( m_dispatch_carrier_node.mp_avoid_catcher.get() != NULL )
  3482. {
  3483. std::cout << " huli test :::: " << " tp_avoid_catcher->get_device_id() = " << m_dispatch_carrier_node.mp_avoid_catcher->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_avoid_catcher->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_avoid_catcher->get_dispatch_device_status() << std::endl;
  3484. }
  3485. else
  3486. {
  3487. std::cout << " huli test :::: " << " tp_avoid_catcher->get_device_id() = " << -8888 << std::endl;
  3488. }
  3489. if ( m_dispatch_carrier_node.mp_avoid_carrier.get() != NULL )
  3490. {
  3491. std::cout << " huli test :::: " << " tp_avoid_carrier->get_device_id() = " << m_dispatch_carrier_node.mp_avoid_carrier->get_device_id() <<" + "<< m_dispatch_carrier_node.mp_avoid_carrier->get_current_command_key() <<" + "<< m_dispatch_carrier_node.mp_avoid_carrier->get_dispatch_device_status() << std::endl;
  3492. }
  3493. else
  3494. {
  3495. std::cout << " huli test :::: " << " tp_avoid_carrier->get_device_id() = " << -8888 << std::endl;
  3496. }
  3497. #ifdef PROCESS_TEST
  3498. char cr;
  3499. std::cin >> cr ;
  3500. #endif
  3501. std::cout << " huli test :::: " << " ----------------------------------------------------------------------------------------- = " << "catcher start" << std::endl;
  3502. std::cout << " huli test :::: " << " m_dispatch_catcher_node.m_dispatch_control_status = " << m_dispatch_catcher_node.m_dispatch_control_status << std::endl;
  3503. if ( m_dispatch_catcher_node.mp_main_catcher.get() != NULL )
  3504. {
  3505. std::cout << " huli test :::: " << " tp_main_catcher->get_device_id() = " << m_dispatch_catcher_node.mp_main_catcher->get_device_id() <<" + "<< m_dispatch_catcher_node.mp_main_catcher->get_current_command_key() <<" + "<< m_dispatch_catcher_node.mp_main_catcher->get_dispatch_device_status() << std::endl;
  3506. }
  3507. else
  3508. {
  3509. std::cout << " huli test :::: " << " tp_main_catcher->get_device_id() = " << -8888 << std::endl;
  3510. }
  3511. if ( m_dispatch_catcher_node.mp_following_carrier.get() != NULL )
  3512. {
  3513. std::cout << " huli test :::: " << " tp_following_carrier->get_device_id() = " << m_dispatch_catcher_node.mp_following_carrier->get_device_id() <<" + " << m_dispatch_catcher_node.mp_following_carrier->get_current_command_key()<<" + "<< m_dispatch_catcher_node.mp_following_carrier->get_dispatch_device_status() << std::endl;
  3514. }
  3515. else
  3516. {
  3517. std::cout << " huli test :::: " << " tp_following_carrier->get_device_id() = " << -8888 << std::endl;
  3518. }
  3519. Error_manager t_catcher_error;
  3520. Catcher * tp_main_catcher = NULL;
  3521. Catcher_task * tp_main_catcher_task = NULL;
  3522. if ( m_dispatch_catcher_node.mp_main_catcher.get() != NULL && m_dispatch_catcher_node.mp_main_catcher_task.get() != NULL )
  3523. {
  3524. tp_main_catcher = (Catcher *)m_dispatch_catcher_node.mp_main_catcher.get();
  3525. tp_main_catcher_task = (Catcher_task *)m_dispatch_catcher_node.mp_main_catcher_task.get();
  3526. //一级任务被打断后, 重新执行
  3527. if ( tp_main_catcher->get_break_flag() )
  3528. {
  3529. if ( m_dispatch_catcher_node.m_main_catcher_task_level == Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL )
  3530. {
  3531. m_dispatch_catcher_node.m_dispatch_control_status = DISPATCH_CATCHER_STORE_START;
  3532. }
  3533. tp_main_catcher->set_break_flag(false);
  3534. }
  3535. }
  3536. Carrier * tp_following_carrier = NULL;
  3537. Carrier_task * tp_following_carrier_task = NULL;
  3538. if ( m_dispatch_catcher_node.mp_following_carrier.get() != NULL && m_dispatch_catcher_node.mp_following_carrier_task.get() != NULL )
  3539. {
  3540. tp_following_carrier = (Carrier *)m_dispatch_catcher_node.mp_following_carrier.get();
  3541. tp_following_carrier_task = (Carrier_task *)m_dispatch_catcher_node.mp_following_carrier_task.get();
  3542. }
  3543. //抓取器的控制动作
  3544. switch ( m_dispatch_catcher_node.m_dispatch_control_status )
  3545. {
  3546. case DISPATCH_CONTROL_CREATED:
  3547. case DISPATCH_CONTROL_READY:
  3548. {
  3549. m_dispatch_catcher_node.m_error = check_main_catcher(m_dispatch_catcher_node);
  3550. if (m_dispatch_catcher_node.m_error == Error_code::SUCCESS)
  3551. {
  3552. if (m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_PICKUP)
  3553. {
  3554. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_PICKUP_START;
  3555. }
  3556. else if (m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_STORE)
  3557. {
  3558. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_START;
  3559. }
  3560. }
  3561. //else 原地等待
  3562. break;
  3563. }
  3564. case DISPATCH_CATCHER_STORE_START://连接机器人, 创建新的任务单 与设备建立连接
  3565. {
  3566. if (m_dispatch_catcher_node.mp_main_catcher.get() == NULL)
  3567. {
  3568. m_dispatch_catcher_node.mp_main_catcher = Dispatch_manager::get_instance_references().m_catcher_map[1];
  3569. }
  3570. if ( m_dispatch_catcher_node.mp_main_catcher_task.get() == NULL )
  3571. {
  3572. m_dispatch_catcher_node.m_error = m_dispatch_catcher_node.mp_main_catcher->check_task_level(
  3573. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  3574. if (m_dispatch_catcher_node.m_error == Error_code::SUCCESS)
  3575. {
  3576. m_dispatch_catcher_node.m_error = connect_dispatch_catcher(m_dispatch_catcher_node.mp_main_catcher,
  3577. m_dispatch_catcher_node.mp_main_catcher_task,
  3578. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  3579. if (m_dispatch_catcher_node.m_error == Error_code::SUCCESS)
  3580. {
  3581. m_dispatch_catcher_node.m_main_catcher_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL;
  3582. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (m_dispatch_catcher_node.m_dispatch_control_status + 1);
  3583. }
  3584. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  3585. }
  3586. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  3587. }
  3588. else
  3589. {
  3590. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (m_dispatch_catcher_node.m_dispatch_control_status + 2);
  3591. }
  3592. break;
  3593. }
  3594. case DISPATCH_CATCHER_STORE_1:
  3595. {
  3596. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task,
  3597. m_dispatch_catcher_node.m_dispatch_control_status);
  3598. break;
  3599. }
  3600. case DISPATCH_CATCHER_STORE_2://机器人 准备开始, 需要同步任务单和设备真实数据
  3601. {
  3602. //机器人 准备开始, 需要同步任务单和设备真实数据.//注意了:连接设备只是预约, 设备不一定立刻执行.所以需要在连接成功之后进行数据同步
  3603. catcher_ready_to_start(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher,
  3604. tp_main_catcher_task, tp_dispatch_coordinates);
  3605. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (m_dispatch_catcher_node.m_dispatch_control_status + 1);
  3606. break;
  3607. }
  3608. case DISPATCH_CATCHER_STORE_3:
  3609. {
  3610. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task,
  3611. m_dispatch_catcher_node.m_dispatch_control_status);
  3612. //注意了:同步失败,需要重新同步.
  3613. if ( m_dispatch_catcher_node.m_error != Error_code::SUCCESS )
  3614. {
  3615. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_2);
  3616. }
  3617. break;
  3618. }
  3619. case DISPATCH_CATCHER_STORE_4://机器手调整到 正常待机的姿态(调节夹杆和轴距)
  3620. {
  3621. if ( tp_main_catcher->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  3622. {
  3623. if ( tp_main_catcher->m_actual_clamp_motion1 != Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE ||
  3624. tp_main_catcher->m_actual_d1 + tp_main_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance >
  3625. tp_dispatch_coordinates->m_catcher_wheel_base_limit ||
  3626. tp_main_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_UNKNOW )
  3627. {
  3628. catcher_adjust_to_ready(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  3629. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3630. }
  3631. else
  3632. {
  3633. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  3634. }
  3635. }
  3636. else
  3637. {
  3638. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3639. m_dispatch_catcher_node.m_error = Error_manager(Error_code::CATCHER_POSE_ERROR, Error_level::MINOR_ERROR,
  3640. "DISPATCH_CATCHER_STORE_4 Dispatch_process::excute_robot_catch_car_from_carrier() fun error ");
  3641. }
  3642. break;
  3643. }
  3644. case DISPATCH_CATCHER_STORE_5:
  3645. {
  3646. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  3647. break;
  3648. }
  3649. case DISPATCH_CATCHER_STORE_6://机器手 调整z轴, (z轴上升到4楼. 不需要判断空间锁)
  3650. {
  3651. if ( tp_main_catcher->m_actual_z*1.02 >= tp_dispatch_coordinates->m_catcher_4th_floor_z )
  3652. {
  3653. //检测正常, 直接跳过即可
  3654. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  3655. }
  3656. else
  3657. {
  3658. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  3659. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3660. }
  3661. break;
  3662. }
  3663. case DISPATCH_CATCHER_STORE_7://机器人释放 空间锁
  3664. {
  3665. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  3666. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  3667. {
  3668. tp_dispatch_coordinates->catcher_space_unlock(tp_main_catcher->m_actual_coordinates_id, tp_main_catcher->get_device_id());
  3669. }
  3670. break;
  3671. }
  3672. case DISPATCH_CATCHER_STORE_8://连接3楼的跟随机器人
  3673. {
  3674. if ( m_dispatch_catcher_node.m_following_flag )
  3675. {
  3676. if ( m_dispatch_catcher_node.mp_following_carrier.get() == NULL )
  3677. {
  3678. m_dispatch_catcher_node.mp_following_carrier = Dispatch_manager::get_instance_references().m_carrier_map[2];
  3679. }
  3680. if ( m_dispatch_catcher_node.mp_following_carrier_task.get() == NULL )
  3681. {
  3682. m_dispatch_catcher_node.m_error = m_dispatch_catcher_node.mp_following_carrier->check_task_level(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  3683. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  3684. {
  3685. m_dispatch_catcher_node.m_error = connect_dispatch_carrier(m_dispatch_catcher_node.mp_following_carrier, m_dispatch_catcher_node.mp_following_carrier_task, Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL);
  3686. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  3687. {
  3688. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3689. }
  3690. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  3691. }
  3692. //else 抓取器的资源自由争抢, 如果没有抢到, 那么重复连接
  3693. }
  3694. else
  3695. {
  3696. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  3697. }
  3698. }
  3699. else
  3700. {
  3701. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  3702. }
  3703. break;
  3704. }
  3705. case DISPATCH_CATCHER_STORE_9:
  3706. {
  3707. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_following_carrier_task, m_dispatch_catcher_node.m_dispatch_control_status);
  3708. break;
  3709. }
  3710. case DISPATCH_CATCHER_STORE_10://搬运器 准备开始, 需要同步任务单和设备真实数据
  3711. {
  3712. if ( m_dispatch_catcher_node.m_following_flag )
  3713. {
  3714. //搬运器 准备开始, 需要同步任务单和设备真实数据.//注意了:连接设备只是预约, 设备不一定立刻执行.所以需要在连接成功之后进行数据同步
  3715. carrier_ready_to_start(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_following_carrier, tp_following_carrier_task, tp_dispatch_coordinates);
  3716. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3717. }
  3718. else
  3719. {
  3720. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  3721. }
  3722. break;
  3723. }
  3724. case DISPATCH_CATCHER_STORE_11:
  3725. {
  3726. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_following_carrier_task, m_dispatch_catcher_node.m_dispatch_control_status);
  3727. //注意了:同步失败,需要重新同步.
  3728. if ( m_dispatch_catcher_node.m_error != Error_code::SUCCESS )
  3729. {
  3730. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_10);
  3731. }
  3732. break;
  3733. }
  3734. case DISPATCH_CATCHER_STORE_12://机器人 x轴移动之前, 判断空间锁.
  3735. {
  3736. int t_terminal = m_dispatch_source - 1100;
  3737. int t_parity_flag = (t_terminal-1)%2;
  3738. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  3739. if ( tp_main_catcher->m_actual_coordinates_columns < t_column )
  3740. {
  3741. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, tp_main_catcher->m_actual_coordinates_columns,
  3742. 2, t_column+1,
  3743. tp_main_catcher->get_device_id());
  3744. }
  3745. else
  3746. {
  3747. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, t_column-1,
  3748. 2, tp_main_catcher->m_actual_coordinates_columns,
  3749. tp_main_catcher->get_device_id());
  3750. }
  3751. //判断结果
  3752. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  3753. {
  3754. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3755. }
  3756. //else 无限等待
  3757. break;
  3758. }
  3759. case DISPATCH_CATCHER_STORE_13://机器手调整到 对接地面的姿态
  3760. {
  3761. if ( m_dispatch_catcher_node.m_following_flag )
  3762. {
  3763. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x;
  3764. float t_y = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].y;
  3765. //机器手调整到 对接地面的姿态
  3766. catcher_adjust_from_ground(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  3767. //3楼搬运器跟随, 到机器人旁边一个车位
  3768. float t_following_x = 0;
  3769. if ( m_dispatch_source == 1101 )
  3770. {
  3771. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[1102].x;
  3772. }
  3773. else if ( m_dispatch_source == 1106 )
  3774. {
  3775. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[1105].x;
  3776. }
  3777. else if ( tp_following_carrier->m_actual_x < t_x)
  3778. {
  3779. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source-1].x;
  3780. }
  3781. else
  3782. {
  3783. t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source+1].x;
  3784. }
  3785. carrier_move_x(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_following_carrier, tp_following_carrier_task, tp_dispatch_coordinates, t_following_x);
  3786. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3787. }
  3788. else
  3789. {
  3790. if ( m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_18 )
  3791. {
  3792. float t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x;
  3793. float t_y = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].y;
  3794. //机器手调整到 对接地面的姿态
  3795. catcher_adjust_from_ground(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  3796. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3797. }
  3798. //else 无限等待
  3799. }
  3800. break;
  3801. }
  3802. case DISPATCH_CATCHER_STORE_14://机器人释放 空间锁
  3803. {
  3804. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task);
  3805. if ( m_dispatch_catcher_node.m_following_flag )
  3806. {
  3807. m_dispatch_catcher_node.m_error.compare_and_cover_error(check_task_status(m_dispatch_catcher_node.mp_following_carrier_task));
  3808. }
  3809. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  3810. {
  3811. tp_dispatch_coordinates->catcher_space_unlock(tp_main_catcher->m_actual_coordinates_id, tp_main_catcher->get_device_id());
  3812. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3813. }
  3814. break;
  3815. }
  3816. case DISPATCH_CATCHER_STORE_15://机器手 准备下降抓车之前, 把一级任务升到三级
  3817. {
  3818. //2楼交接则直接下降抓车, 3楼交接,就需要等待3楼搬运器进入待机位,
  3819. if ( m_dispatch_catcher_node.m_following_flag )
  3820. {
  3821. m_dispatch_catcher_node.m_error = m_dispatch_catcher_node.mp_main_catcher->change_task_level(
  3822. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL,
  3823. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL);
  3824. m_dispatch_catcher_node.m_error.compare_and_cover_error(m_dispatch_catcher_node.mp_following_carrier->change_task_level(
  3825. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL,
  3826. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL));
  3827. if (m_dispatch_catcher_node.m_error == Error_code::SUCCESS)
  3828. {
  3829. m_dispatch_catcher_node.m_main_catcher_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL;
  3830. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (
  3831. m_dispatch_catcher_node.m_dispatch_control_status + 1);
  3832. }
  3833. else if(m_dispatch_catcher_node.m_error == Error_code::NODATA)
  3834. {
  3835. //无限等待
  3836. }
  3837. else
  3838. {
  3839. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3840. }
  3841. }
  3842. //等待搬运器就位, 把一级任务升到三级
  3843. else if ( m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_20 )
  3844. {
  3845. m_dispatch_catcher_node.m_error = m_dispatch_catcher_node.mp_main_catcher->change_task_level(
  3846. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL,
  3847. Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL);
  3848. if (m_dispatch_catcher_node.m_error == Error_code::SUCCESS)
  3849. {
  3850. m_dispatch_catcher_node.m_main_catcher_task_level = Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_THREE_LEVEL;
  3851. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status) (
  3852. m_dispatch_catcher_node.m_dispatch_control_status + 1);
  3853. }
  3854. else if(m_dispatch_catcher_node.m_error == Error_code::NODATA)
  3855. {
  3856. //无限等待
  3857. }
  3858. else
  3859. {
  3860. m_dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CONTROL_FAULT;
  3861. }
  3862. }
  3863. break;
  3864. }
  3865. case DISPATCH_CATCHER_STORE_16://机器手 z轴下降, 空间加锁
  3866. {
  3867. int t_terminal = m_dispatch_source - 1100;
  3868. int t_parity_flag = (t_terminal-1)%2;
  3869. int t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  3870. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(0, t_column-t_parity_flag,
  3871. 2, t_column+1-t_parity_flag,
  3872. tp_main_catcher->get_device_id());
  3873. //判断结果
  3874. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  3875. {
  3876. //左右搬运器加锁成功, 直接x轴移动
  3877. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3878. }
  3879. //else 无限等待
  3880. break;
  3881. }
  3882. case DISPATCH_CATCHER_STORE_17://机器手 z轴下降
  3883. {
  3884. float t_z = tp_dispatch_coordinates->m_catcher_1th_floor_z;
  3885. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_z);
  3886. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3887. break;
  3888. }
  3889. case DISPATCH_CATCHER_STORE_18:
  3890. {
  3891. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  3892. break;
  3893. }
  3894. case DISPATCH_CATCHER_STORE_19://修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  3895. {
  3896. float temp_wheel_base = tp_main_catcher->m_actual_d1 + tp_main_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance;
  3897. //修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  3898. if ( Common_data::approximate_difference(m_wheel_base, temp_wheel_base, DISPATCH_DEFAULT_DIFFERENCE) )
  3899. {
  3900. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  3901. }
  3902. else
  3903. {
  3904. catcher_adjust_wheel_base(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  3905. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3906. }
  3907. break;
  3908. }
  3909. case DISPATCH_CATCHER_STORE_20:
  3910. {
  3911. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  3912. break;
  3913. }
  3914. case DISPATCH_CATCHER_STORE_21://机器手 夹车
  3915. {
  3916. catcher_move_c(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, Catcher_task::Clamp_motion::E_CLAMP_TIGHT);
  3917. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3918. break;
  3919. }
  3920. case DISPATCH_CATCHER_STORE_22:
  3921. {
  3922. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  3923. break;
  3924. }
  3925. case DISPATCH_CATCHER_STORE_23://机器手 z轴上升, 上升到交接为上方190mm就足以
  3926. {
  3927. // float t_z = 0;
  3928. // if ( m_dispatch_catcher_node.m_following_flag )
  3929. // {
  3930. // t_z = tp_dispatch_coordinates->m_catcher_2th_floor_z + tp_dispatch_coordinates->m_separated_distance_z;
  3931. // }
  3932. // else
  3933. // {
  3934. // t_z = tp_dispatch_coordinates->m_catcher_3th_floor_z + tp_dispatch_coordinates->m_separated_distance_z;
  3935. // }
  3936. //只能在最高处交接
  3937. float t_z = tp_dispatch_coordinates->m_catcher_4th_floor_z;
  3938. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_z);
  3939. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3940. break;
  3941. }
  3942. case DISPATCH_CATCHER_STORE_24:
  3943. {
  3944. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  3945. break;
  3946. }
  3947. case DISPATCH_CATCHER_STORE_25://机器人 x轴移动之前, 判断空间锁.
  3948. {
  3949. int t_column = 0;
  3950. // 2楼交接, 在出口终点x交接 3楼交接, 在取车车位起点x交接,
  3951. if ( m_dispatch_catcher_node.m_following_flag )
  3952. {
  3953. int t_terminal = m_dispatch_source - 1100;
  3954. int t_parity_flag = (t_terminal-1)%2;
  3955. t_column = 4 + ((t_terminal-1)/2)*3 + t_parity_flag*2 -1;
  3956. }
  3957. else
  3958. {
  3959. t_column = (m_parkspace_information_optimal.parkingspace_index_id -1) % tp_dispatch_coordinates->m_space_lock_columns;
  3960. }
  3961. if ( tp_main_catcher->m_actual_coordinates_columns < t_column )
  3962. {
  3963. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, tp_main_catcher->m_actual_coordinates_columns,
  3964. 2, t_column+1,
  3965. tp_main_catcher->get_device_id());
  3966. }
  3967. else
  3968. {
  3969. m_dispatch_catcher_node.m_error = tp_dispatch_coordinates->catcher_try_space_lock(1, t_column-1,
  3970. 2, tp_main_catcher->m_actual_coordinates_columns,
  3971. tp_main_catcher->get_device_id());
  3972. }
  3973. //判断结果
  3974. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  3975. {
  3976. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3977. }
  3978. //else 无限等待
  3979. break;
  3980. }
  3981. case DISPATCH_CATCHER_STORE_26://机器手调整到 准备把车放到搬运器的姿态
  3982. {
  3983. float t_x = 0;
  3984. // 2楼交接, 在入口起点x交接 3楼交接, 在车位x交接,
  3985. if ( m_dispatch_catcher_node.m_following_flag )
  3986. {
  3987. t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x;
  3988. }
  3989. else
  3990. {
  3991. t_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_parkspace_information_optimal.parkingspace_index_id].x;
  3992. }
  3993. float t_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  3994. //注:3楼流程 可能会出现x平移的同时 进行旋转掉头
  3995. catcher_adjust_to_carrier(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_x, true);
  3996. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  3997. break;
  3998. }
  3999. case DISPATCH_CATCHER_STORE_27://机器人 释放空间锁
  4000. {
  4001. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  4002. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  4003. {
  4004. tp_dispatch_coordinates->catcher_space_unlock(tp_main_catcher->m_actual_coordinates_id, tp_main_catcher->get_device_id());
  4005. }
  4006. break;
  4007. }
  4008. case DISPATCH_CATCHER_STORE_28://等待搬运器过来接车后, 机器人就可以下降了
  4009. {
  4010. //等待搬运器过来接车后, 机器人就可以下降了
  4011. if ( m_dispatch_carrier_node.m_dispatch_control_status >= Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_24 )
  4012. {
  4013. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  4014. }
  4015. //else 无限等待
  4016. break;
  4017. }
  4018. case DISPATCH_CATCHER_STORE_29://机器人z轴下降, 判断空间锁
  4019. {
  4020. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  4021. break;
  4022. }
  4023. case DISPATCH_CATCHER_STORE_30://机器手 z轴下降 到搬运器放车
  4024. {
  4025. float t_z = 0;
  4026. if ( m_dispatch_catcher_node.m_following_flag )
  4027. {
  4028. //下降到2楼
  4029. t_z = tp_dispatch_coordinates->m_catcher_2th_floor_z;
  4030. }
  4031. else
  4032. {
  4033. //下降到3楼
  4034. t_z = tp_dispatch_coordinates->m_catcher_3th_floor_z;
  4035. }
  4036. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, t_z);
  4037. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  4038. break;
  4039. }
  4040. case DISPATCH_CATCHER_STORE_31:
  4041. {
  4042. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  4043. break;
  4044. }
  4045. case DISPATCH_CATCHER_STORE_32://机器手 松开夹杆
  4046. {
  4047. catcher_move_c(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, Catcher_task::Clamp_motion::E_CLAMP_LOOSE);
  4048. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  4049. break;
  4050. }
  4051. case DISPATCH_CATCHER_STORE_33:
  4052. {
  4053. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  4054. break;
  4055. }
  4056. case DISPATCH_CATCHER_STORE_34://机器手调整到 正常待机的姿态(调节夹杆和轴距)
  4057. {
  4058. if ( tp_main_catcher->m_actual_clamp_motion1 != Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE ||
  4059. tp_main_catcher->m_actual_d1 + tp_main_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance >
  4060. tp_dispatch_coordinates->m_catcher_wheel_base_limit ||
  4061. tp_main_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_UNKNOW )
  4062. {
  4063. catcher_adjust_to_ready(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates);
  4064. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  4065. }
  4066. else
  4067. {
  4068. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  4069. }
  4070. break;
  4071. }
  4072. case DISPATCH_CATCHER_STORE_35:
  4073. {
  4074. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  4075. break;
  4076. }
  4077. case DISPATCH_CATCHER_STORE_36://机器手 调整z轴, z轴上升到4楼
  4078. {
  4079. catcher_move_z(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_main_catcher, tp_main_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  4080. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  4081. break;
  4082. }
  4083. case DISPATCH_CATCHER_STORE_37://机器人释放 空间锁
  4084. {
  4085. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_main_catcher_task, m_dispatch_catcher_node.m_dispatch_control_status);
  4086. if ( m_dispatch_catcher_node.m_error == Error_code::SUCCESS )
  4087. {
  4088. tp_dispatch_coordinates->catcher_space_unlock(tp_main_catcher->m_actual_coordinates_id, tp_main_catcher->get_device_id());
  4089. }
  4090. break;
  4091. }
  4092. case DISPATCH_CATCHER_STORE_38://3楼的搬运器跟随到机器人下方
  4093. {
  4094. //如果后面有一级存车任务, 那么就跳过
  4095. if ( m_dispatch_catcher_node.m_following_flag &&
  4096. tp_main_catcher->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_ONE_LEVEL) == false &&
  4097. tp_main_catcher->is_has_appoint_task(Dispatch_device_base::Dispatch_task_level::DISPATCH_TASK_TWO_LEVEL) == false)
  4098. {
  4099. float t_following_x = tp_dispatch_coordinates->m_carrier_coordinates_map[m_dispatch_source].x;
  4100. carrier_move_x(get_dispatch_control_command_key(m_dispatch_catcher_node), tp_following_carrier, tp_following_carrier_task, tp_dispatch_coordinates, t_following_x);
  4101. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+1);
  4102. }
  4103. else
  4104. {
  4105. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status)(m_dispatch_catcher_node.m_dispatch_control_status+2);
  4106. }
  4107. break;
  4108. }
  4109. case DISPATCH_CATCHER_STORE_39:
  4110. {
  4111. m_dispatch_catcher_node.m_error = check_task_status(m_dispatch_catcher_node.mp_following_carrier_task, m_dispatch_catcher_node.m_dispatch_control_status);
  4112. break;
  4113. }
  4114. case DISPATCH_CATCHER_STORE_40://主机器人 断连
  4115. {
  4116. disconnect_dispatch_device(m_dispatch_catcher_node.mp_main_catcher, m_dispatch_catcher_node.mp_main_catcher_task);
  4117. if ( m_dispatch_catcher_node.m_following_flag )
  4118. {
  4119. disconnect_dispatch_device(m_dispatch_catcher_node.mp_following_carrier, m_dispatch_catcher_node.mp_following_carrier_task);
  4120. }
  4121. m_dispatch_catcher_node.m_dispatch_control_status = (Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_END);
  4122. break;
  4123. }
  4124. case DISPATCH_CATCHER_STORE_END:
  4125. {
  4126. m_dispatch_catcher_node.m_error = Error_code::SUCCESS;
  4127. break;
  4128. }
  4129. default:
  4130. {
  4131. break;
  4132. }
  4133. }
  4134. std::cout << " huli test :::: " << " ---------------------------------------------------------------------------------------------------------------------------- = " << "catcher end" << std::endl;
  4135. std::cout << " huli test :::: " << " m_dispatch_catcher_node.m_dispatch_control_status = " << m_dispatch_catcher_node.m_dispatch_control_status << std::endl;
  4136. if ( m_dispatch_catcher_node.mp_main_catcher.get() != NULL )
  4137. {
  4138. std::cout << " huli test :::: " << " tp_main_catcher->get_device_id() = " << m_dispatch_catcher_node.mp_main_catcher->get_device_id() <<" + "<< m_dispatch_catcher_node.mp_main_catcher->get_current_command_key() <<" + "<< m_dispatch_catcher_node.mp_main_catcher->get_dispatch_device_status() << std::endl;
  4139. }
  4140. else
  4141. {
  4142. std::cout << " huli test :::: " << " tp_main_catcher->get_device_id() = " << -8888 << std::endl;
  4143. }
  4144. if ( m_dispatch_catcher_node.mp_following_carrier.get() != NULL )
  4145. {
  4146. std::cout << " huli test :::: " << " tp_following_carrier->get_device_id() = " << m_dispatch_catcher_node.mp_following_carrier->get_device_id() <<" + " << m_dispatch_catcher_node.mp_following_carrier->get_current_command_key()<<" + "<< m_dispatch_catcher_node.mp_following_carrier->get_dispatch_device_status() << std::endl;
  4147. }
  4148. else
  4149. {
  4150. std::cout << " huli test :::: " << " tp_following_carrier->get_device_id() = " << -8888 << std::endl;
  4151. }
  4152. std::cout << " huli test :::: " << " +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ = " << 3 << std::endl;
  4153. std::cout << " huli test :::: " << " m_dispatch_source = " << m_dispatch_source << std::endl;
  4154. std::cout << " huli test :::: " << " m_parkspace_information_optimal.parkingspace_index_id = " << m_parkspace_information_optimal.parkingspace_index_id << std::endl;
  4155. #ifdef PROCESS_TEST
  4156. char ch;
  4157. std::cin >> ch ;
  4158. #endif
  4159. //结果汇总
  4160. if ( m_dispatch_carrier_node.m_dispatch_control_status == DISPATCH_CARRIER_STORE_END &&
  4161. m_dispatch_catcher_node.m_dispatch_control_status == DISPATCH_CATCHER_STORE_END )
  4162. {
  4163. return Error_code::SUCCESS;
  4164. }
  4165. else if ( m_dispatch_carrier_node.m_dispatch_control_status == DISPATCH_CONTROL_FAULT )
  4166. {
  4167. return m_dispatch_carrier_node.m_error;
  4168. }
  4169. else if(m_dispatch_catcher_node.m_dispatch_control_status == DISPATCH_CONTROL_FAULT)
  4170. {
  4171. return m_dispatch_catcher_node.m_error;
  4172. }
  4173. else
  4174. {
  4175. return Error_code::NODATA;
  4176. }
  4177. }
  4178. //检查核心搬运器
  4179. Error_manager Dispatch_process::check_main_carrier(Dispatch_carrier_node & dispatch_carrier_node)
  4180. {
  4181. //只判断搬运器的指针是否有效.
  4182. if ( dispatch_carrier_node.mp_main_carrier.get() != NULL )
  4183. {
  4184. // if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_PICKUP )
  4185. // {
  4186. // m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_PICKUP_START;
  4187. // }
  4188. // else if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_STORE )
  4189. // {
  4190. // m_dispatch_carrier_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CARRIER_STORE_START;
  4191. // }
  4192. return Error_code::SUCCESS;
  4193. }
  4194. else
  4195. {
  4196. return Error_code::NODATA;
  4197. }
  4198. }
  4199. //检查核心抓取器
  4200. Error_manager Dispatch_process::check_main_catcher(Dispatch_catcher_node & dispatch_catcher_node)
  4201. {
  4202. //只判断搬 调度设备机器人启动标志位
  4203. if ( dispatch_catcher_node.m_dispatch_control_start_flag )
  4204. {
  4205. //为抓取器分配对应的设备, 目前只有2号机器人
  4206. // if ( dispatch_catcher_node.mp_main_catcher.get() ==NULL )
  4207. // {
  4208. // dispatch_catcher_node.mp_main_catcher = Dispatch_manager::get_instance_references().m_catcher_map[1];
  4209. // }
  4210. //
  4211. // if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_PICKUP )
  4212. // {
  4213. // dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_PICKUP_START;
  4214. // }
  4215. // else if ( m_dispatch_process_type == Common_data::Dispatch_process_type::DISPATCH_PROCESS_STORE )
  4216. // {
  4217. // dispatch_catcher_node.m_dispatch_control_status = Dispatch_process::Dispatch_control_status::DISPATCH_CATCHER_STORE_START;
  4218. // }
  4219. return Error_code::SUCCESS;
  4220. }
  4221. else
  4222. {
  4223. return Error_code::NODATA;
  4224. }
  4225. }
  4226. //连接搬运器, 创建新的任务单 与设备建立连接, 只能成功, 失败就要进入故障处理
  4227. Error_manager Dispatch_process::connect_dispatch_carrier(std::shared_ptr<Dispatch_device_base> & p_carrier, std::shared_ptr<Task_Base> & p_carrier_task, Dispatch_device_base::Dispatch_task_level dispatch_task_level)
  4228. {
  4229. Error_manager t_error;
  4230. if ( p_carrier.get() != NULL )
  4231. {
  4232. Carrier* tp_carrier = (Carrier*)p_carrier.get();
  4233. //检查设备能否执行任务, 主搬运器是管理层分配好的, 一般是可以直接连接.
  4234. t_error = tp_carrier->check_task_level(dispatch_task_level);
  4235. if ( t_error == Error_code::SUCCESS )
  4236. {
  4237. //创建任务单
  4238. p_carrier_task = std::shared_ptr<Task_Base>(new Carrier_task);
  4239. p_carrier_task->task_init(NULL,std::chrono::milliseconds(15000));
  4240. Carrier_task * tp_carrier_task = (Carrier_task *)p_carrier_task.get();
  4241. //第一次发送 空的唯一码, 可以和设备建立联系
  4242. tp_carrier_task->m_request_key = "";
  4243. tp_carrier_task->m_request_x = tp_carrier->m_actual_x;
  4244. tp_carrier_task->m_request_y = tp_carrier->m_actual_y;
  4245. tp_carrier_task->m_request_z = tp_carrier->m_actual_z;
  4246. tp_carrier_task->m_request_y1 = tp_carrier->m_actual_y1;
  4247. tp_carrier_task->m_request_y2 = tp_carrier->m_actual_y2;
  4248. tp_carrier_task->m_request_clamp_motion = (Carrier_task::Clamp_motion)tp_carrier->m_actual_clamp_motion1;
  4249. tp_carrier_task->m_request_joint_motion_x = (Carrier_task::Joint_motion)tp_carrier->m_actual_joint_motion_x1;
  4250. tp_carrier_task->m_request_joint_motion_y = Carrier_task::Joint_motion::E_JOINT_NO_ACTION;
  4251. tp_carrier_task->m_request_space_id = 0;
  4252. tp_carrier_task->m_request_floor_id = 0;
  4253. tp_carrier_task->m_request_wheelbase = Dispatch_coordinates::get_instance_references().m_default_wheelbase;
  4254. t_error = tp_carrier->execute_task(p_carrier_task, dispatch_task_level, m_command_key, m_dispatch_process_type);
  4255. }
  4256. }
  4257. else
  4258. {
  4259. t_error.error_manager_reset(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  4260. " Dispatch_process::connect_dispatch_carrier() POINTER IS NULL ");
  4261. }
  4262. return t_error;
  4263. }
  4264. //连接抓取器, 创建新的任务单 与设备建立连接, 可以失败, 失败就重新执行
  4265. Error_manager Dispatch_process::connect_dispatch_catcher(std::shared_ptr<Dispatch_device_base> & p_catcher, std::shared_ptr<Task_Base> & p_catcher_task, Dispatch_device_base::Dispatch_task_level dispatch_task_level)
  4266. {
  4267. Error_manager t_error;
  4268. if ( p_catcher.get() != NULL )
  4269. {
  4270. Catcher* tp_catcher = (Catcher*)p_catcher.get();
  4271. //检查设备能否执行任务, 主抓取器是需要调度流程去争抢的.
  4272. t_error = tp_catcher->check_task_level(dispatch_task_level);
  4273. if ( t_error == Error_code::SUCCESS )
  4274. {
  4275. //创建任务单
  4276. p_catcher_task = std::shared_ptr<Task_Base>(new Catcher_task);
  4277. p_catcher_task->task_init(NULL,std::chrono::milliseconds(15000));
  4278. Catcher_task * tp_catcher_task = (Catcher_task *)p_catcher_task.get();
  4279. //第一次发送 空的唯一码, 可以和设备建立联系
  4280. tp_catcher_task->m_request_key = "";
  4281. tp_catcher_task->m_request_x = tp_catcher->m_actual_x;
  4282. tp_catcher_task->m_request_y = tp_catcher->m_actual_y;
  4283. tp_catcher_task->m_request_b = tp_catcher->m_actual_b;
  4284. tp_catcher_task->m_request_z = tp_catcher->m_actual_z;
  4285. tp_catcher_task->m_request_d1 = tp_catcher->m_actual_d1;
  4286. tp_catcher_task->m_request_d2 = tp_catcher->m_actual_d2;
  4287. tp_catcher_task->m_request_wheelbase = Dispatch_coordinates::get_instance_references().m_default_wheelbase;
  4288. tp_catcher_task->m_request_clamp_motion = (Catcher_task::Clamp_motion)tp_catcher->m_actual_clamp_motion1;
  4289. t_error = tp_catcher->execute_task(p_catcher_task, dispatch_task_level, m_command_key, m_dispatch_process_type);
  4290. }
  4291. }
  4292. else
  4293. {
  4294. t_error.error_manager_reset(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  4295. " Dispatch_process::connect_dispatch_catcher() POINTER IS NULL ");
  4296. }
  4297. return t_error;
  4298. }
  4299. //断开调度设备, 收回任务单, 释放任务单 与设备解除连接
  4300. Error_manager Dispatch_process::disconnect_dispatch_device(std::shared_ptr<Dispatch_device_base> & p_device, std::shared_ptr<Task_Base> & p_device_task)
  4301. {
  4302. if ( p_device.get() != NULL && p_device_task.get() != NULL )
  4303. {
  4304. p_device_task->set_task_statu(Task_Base::Task_statu::TASK_WITHDRAW);
  4305. p_device.reset();
  4306. p_device_task.reset();
  4307. return Error_code::SUCCESS;
  4308. }
  4309. else
  4310. {
  4311. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  4312. " POINTER IS NULL ");
  4313. }
  4314. }
  4315. //发送调度总计划
  4316. Error_manager Dispatch_process::send_dispatch_plan_request_msg()
  4317. {
  4318. std::unique_lock<std::mutex> t_lock(m_lock);
  4319. m_dispatch_plan_request_msg.mutable_base_info()->set_msg_type(message::Message_type::eDispatch_plan_request_msg);
  4320. m_dispatch_plan_request_msg.mutable_base_info()->set_timeout_ms(m_timeout_ms);
  4321. m_dispatch_plan_request_msg.mutable_base_info()->set_sender(message::Communicator::eDispatch_manager);
  4322. m_dispatch_plan_request_msg.mutable_base_info()->set_receiver(message::Communicator::eDispatch_control);
  4323. m_dispatch_plan_request_msg.set_command_key(m_dispatch_request_msg.command_key());
  4324. m_dispatch_plan_request_msg.set_dispatch_task_type((message::Dispatch_task_type)m_dispatch_process_type);
  4325. m_dispatch_plan_request_msg.set_dispatch_source(m_dispatch_source);
  4326. m_dispatch_plan_request_msg.set_dispatch_destination(m_dispatch_destination);
  4327. //这里不写错误码
  4328. std::string t_msg = m_dispatch_plan_request_msg.SerializeAsString();
  4329. System_communication::get_instance_references().encapsulate_msg(t_msg);
  4330. return Error_code::SUCCESS;
  4331. }
  4332. //执行调度控制指令, 并根据完成情况给答复
  4333. Error_manager Dispatch_process::dispatch_control_motion()
  4334. {
  4335. Error_manager t_error;
  4336. std::unique_lock<std::mutex> t_lock(m_lock);
  4337. // m_result.error_manager_clear_all();
  4338. for (auto iter = m_dispatch_control_node_map.begin(); iter != m_dispatch_control_node_map.end(); ++iter)
  4339. {
  4340. switch ( iter->second.m_dispatch_control_status )
  4341. {
  4342. case DISPATCH_CONTROL_STATUS_UNKNOW:
  4343. case DISPATCH_CONTROL_CREATED:
  4344. case DISPATCH_CONTROL_READY:
  4345. {
  4346. t_error = wait_dispatch_control_request_msg(iter->first, iter->second);
  4347. if ( t_error == Error_code::SUCCESS)
  4348. {
  4349. //流程正常, 就进入完成状态,
  4350. iter->second.m_dispatch_control_status = DISPATCH_CONTROL_CONNECT_DEVICE;
  4351. }
  4352. //else 原地待命
  4353. break;
  4354. }
  4355. case DISPATCH_CONTROL_CONNECT_DEVICE:
  4356. {
  4357. //连接调度设备
  4358. t_error = connect_dispatch_device(iter->first, iter->second);
  4359. if ( t_error !=Error_code::SUCCESS)
  4360. {
  4361. iter->second.m_error = t_error;
  4362. iter->second.m_dispatch_control_status = DISPATCH_CONTROL_RESPONSE;
  4363. }
  4364. else
  4365. {
  4366. //流程正常, 就进入工作状态,
  4367. iter->second.m_dispatch_control_status = DISPATCH_CONTROL_WORKING;
  4368. iter->second.m_time_to_send_control_response = std::chrono::system_clock::now();
  4369. }
  4370. break;
  4371. }
  4372. case DISPATCH_CONTROL_WORKING:
  4373. {
  4374. //执行调度控制指令, 并根据完成情况给答复
  4375. t_error = excute_dispatch_control(iter->first, iter->second);
  4376. if ( t_error == Error_code::NODATA )
  4377. {
  4378. //继续 长流程, 什么也不做
  4379. if ( std::chrono::system_clock::now() - iter->second.m_time_to_send_control_response >= std::chrono::seconds(1) )
  4380. {
  4381. //发送调度控制答复, 发给调度控制的
  4382. t_error = send_dispatch_control_response_msg(iter->first, iter->second, message::E_TASK_WORKING);
  4383. iter->second.m_time_to_send_control_response = std::chrono::system_clock::now();
  4384. }
  4385. }
  4386. else
  4387. {
  4388. //长流程结束, 就答复 control_response_msg
  4389. // 注:这里执行调度控制, 即使报错了 也要答复给调度控制, 交给调度控制来进行决策.
  4390. iter->second.m_error = t_error;
  4391. iter->second.m_dispatch_control_status = DISPATCH_CONTROL_TASK_WITHDRAW;
  4392. }
  4393. break;
  4394. }
  4395. case DISPATCH_CONTROL_TASK_WITHDRAW://流程 收回任务单
  4396. {
  4397. //发送调度控制答复, 发给调度控制的
  4398. t_error = dispatch_control_withdraw_task(iter->first, iter->second);
  4399. //流程正常, 就进入等待状态, 等待调度控制发送动作指令
  4400. iter->second.m_dispatch_control_status = DISPATCH_CONTROL_RESPONSE;
  4401. break;
  4402. }
  4403. case DISPATCH_CONTROL_RESPONSE://流程 给调度控制答复
  4404. {
  4405. //发送调度控制答复, 发给调度控制的
  4406. t_error = send_dispatch_control_response_msg(iter->first, iter->second, message::E_TASK_OVER);
  4407. //流程正常, 就进入等待状态, 等待调度控制发送动作指令
  4408. iter->second.m_dispatch_control_status = DISPATCH_CONTROL_DISCONNECT_DEVICE;
  4409. break;
  4410. }
  4411. case DISPATCH_CONTROL_DISCONNECT_DEVICE://流程 解除设备
  4412. {
  4413. //断开调度设备, 释放任务单 与设备解除连接
  4414. t_error = disconnect_dispatch_device(iter->first, iter->second);
  4415. if ( t_error == Error_code::SUCCESS )
  4416. {
  4417. //流程正常, 就回到 等待状态, 等待调度控制发送动作指令
  4418. iter->second.m_error.error_manager_clear_all();
  4419. iter->second.m_dispatch_control_status = DISPATCH_CONTROL_READY;
  4420. }
  4421. //else 保持不变继续等待
  4422. break;
  4423. }
  4424. default:
  4425. {
  4426. break;
  4427. }
  4428. }
  4429. }
  4430. return Error_code::SUCCESS;
  4431. }
  4432. //等待控制指令
  4433. Error_manager Dispatch_process::wait_dispatch_control_request_msg(int dispatch_device_type, Dispatch_control_node & dispatch_control_node)
  4434. {
  4435. //key不相等 就表示 收到了新的控制指令
  4436. if ( dispatch_control_node.m_dispatch_control_request_msg.command_key() != dispatch_control_node.m_dispatch_control_response_msg.command_key() )
  4437. {
  4438. return Error_code::SUCCESS;
  4439. }
  4440. else
  4441. {
  4442. return Error_code::NODATA;
  4443. }
  4444. return Error_code::SUCCESS;
  4445. }
  4446. //连接调度设备, 创建新的任务单 与设备建立连接
  4447. Error_manager Dispatch_process::connect_dispatch_device(int dispatch_device_type, Dispatch_control_node & dispatch_control_node)
  4448. {
  4449. Error_manager t_error;
  4450. if ( dispatch_device_type == message::Dispatch_device_type::ROBOT_1 ||
  4451. dispatch_device_type == message::Dispatch_device_type::ROBOT_2 )
  4452. {
  4453. //找到对应的设备
  4454. if ( dispatch_device_type == message::Dispatch_device_type::ROBOT_1 )
  4455. {
  4456. dispatch_control_node.mp_dispatch_device = Dispatch_manager::get_instance_references().m_catcher_map[0];
  4457. }
  4458. if ( dispatch_device_type == message::Dispatch_device_type::ROBOT_2 )
  4459. {
  4460. dispatch_control_node.mp_dispatch_device = Dispatch_manager::get_instance_references().m_catcher_map[1];
  4461. }
  4462. Catcher* tp_catcher = (Catcher*)dispatch_control_node.mp_dispatch_device.get();
  4463. //检查设备状态
  4464. if ( tp_catcher->check_status() == Error_code::SUCCESS &&
  4465. tp_catcher->m_actual_device_status == Dispatch_device_base::HARDWARE_DEVICE_READY )
  4466. {
  4467. //创建任务单
  4468. dispatch_control_node.mp_dispatch_task = std::shared_ptr<Task_Base>(new Catcher_task);
  4469. dispatch_control_node.mp_dispatch_task->task_init(NULL,std::chrono::milliseconds(15000));
  4470. Catcher_task * tp_catcher_task = (Catcher_task *)dispatch_control_node.mp_dispatch_task.get();
  4471. //第一次发送 空的唯一码, 可以和设备建立联系
  4472. tp_catcher_task->m_request_key = "";
  4473. tp_catcher_task->m_request_x = tp_catcher->m_actual_x;
  4474. tp_catcher_task->m_request_y = tp_catcher->m_actual_y;
  4475. tp_catcher_task->m_request_b = tp_catcher->m_actual_b;
  4476. tp_catcher_task->m_request_z = tp_catcher->m_actual_z;
  4477. tp_catcher_task->m_request_d1 = tp_catcher->m_actual_d1;
  4478. tp_catcher_task->m_request_d2 = tp_catcher->m_actual_d2;
  4479. tp_catcher_task->m_request_wheelbase = Dispatch_coordinates::get_instance_references().m_default_wheelbase;
  4480. tp_catcher_task->m_request_clamp_motion = (Catcher_task::Clamp_motion)tp_catcher->m_actual_clamp_motion1;
  4481. t_error = tp_catcher->execute_task(dispatch_control_node.mp_dispatch_task, Dispatch_device_base::DISPATCH_TASK_ONE_LEVEL);
  4482. if ( t_error != Error_code::SUCCESS )
  4483. {
  4484. dispatch_control_node.m_error = t_error;
  4485. return t_error;
  4486. }
  4487. }
  4488. else
  4489. {
  4490. std::cout << " huli test :::: " << " 123123123123123123123 = " << 1233 << std::endl;
  4491. std::cout << " huli test :::: " << " tp_catcher->check_status() = " << tp_catcher->check_status().to_string() << std::endl;
  4492. std::cout << " huli test :::: " << " tp_catcher->m_actual_device_status = " << tp_catcher->m_actual_device_status << std::endl;
  4493. t_error = Error_manager(Error_code::DISPATCH_PROCESS_DEVICE_STATUS_ERROR, Error_level::MINOR_ERROR,
  4494. " tp_catcher->m_actual_device_status device_status error ");
  4495. dispatch_control_node.m_error = t_error;
  4496. return t_error;
  4497. }
  4498. //设置起点
  4499. dispatch_control_node.m_source_coordinates = Dispatch_coordinates::get_instance_references().m_catcher_coordinates_map[dispatch_control_node.m_dispatch_control_request_msg.dispatch_source()];
  4500. //设置终点
  4501. dispatch_control_node.m_destination_coordinates = Dispatch_coordinates::get_instance_references().m_catcher_coordinates_map[dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination()];
  4502. std::cout << " huli test :::: " << " ---------------------------------------- = " << 123 << std::endl;
  4503. std::cout << " huli test :::: " << " dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination() = " << dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination() << std::endl;
  4504. std::cout << " huli test :::: " << " dispatch_control_node.m_destination_coordinates.x = " << dispatch_control_node.m_destination_coordinates.x << std::endl;
  4505. std::cout << " huli test :::: " << " dispatch_control_node.m_destination_coordinates.y = " << dispatch_control_node.m_destination_coordinates.y << std::endl;
  4506. std::cout << " huli test :::: " << " dispatch_control_node.m_destination_coordinates.z = " << dispatch_control_node.m_destination_coordinates.z << std::endl;
  4507. std::cout << " huli test :::: " << "*******************************************" << 123 << std::endl;
  4508. }
  4509. //搬运器的配置 准备工作
  4510. else if ( dispatch_device_type == message::Dispatch_device_type::CARRIER_1 ||
  4511. dispatch_device_type == message::Dispatch_device_type::CARRIER_2 ||
  4512. dispatch_device_type == message::Dispatch_device_type::CARRIER_3 )
  4513. {
  4514. //找到对应的设备
  4515. if ( dispatch_device_type == message::Dispatch_device_type::CARRIER_1 )
  4516. {
  4517. dispatch_control_node.mp_dispatch_device = Dispatch_manager::get_instance_references().m_carrier_map[0];
  4518. }
  4519. if ( dispatch_device_type == message::Dispatch_device_type::CARRIER_2 )
  4520. {
  4521. dispatch_control_node.mp_dispatch_device = Dispatch_manager::get_instance_references().m_carrier_map[1];
  4522. }
  4523. if ( dispatch_device_type == message::Dispatch_device_type::CARRIER_3 )
  4524. {
  4525. dispatch_control_node.mp_dispatch_device = Dispatch_manager::get_instance_references().m_carrier_map[2];
  4526. }
  4527. Carrier* tp_carrier = (Carrier*)dispatch_control_node.mp_dispatch_device.get();
  4528. //检查设备状态
  4529. if ( tp_carrier->check_status() == Error_code::SUCCESS &&
  4530. tp_carrier->m_actual_device_status == Dispatch_device_base::HARDWARE_DEVICE_READY )
  4531. {
  4532. //创建任务单
  4533. dispatch_control_node.mp_dispatch_task = std::shared_ptr<Task_Base>(new Carrier_task);
  4534. dispatch_control_node.mp_dispatch_task->task_init(NULL,std::chrono::milliseconds(15000));
  4535. Carrier_task * tp_carrier_task = (Carrier_task *)dispatch_control_node.mp_dispatch_task.get();
  4536. //第一次发送 空的唯一码, 可以和设备建立联系
  4537. tp_carrier_task->m_request_key = "";
  4538. tp_carrier_task->m_request_x = tp_carrier->m_actual_x;
  4539. tp_carrier_task->m_request_y = tp_carrier->m_actual_y;
  4540. tp_carrier_task->m_request_z = tp_carrier->m_actual_z;
  4541. tp_carrier_task->m_request_y1 = tp_carrier->m_actual_y1;
  4542. tp_carrier_task->m_request_y2 = tp_carrier->m_actual_y2;
  4543. tp_carrier_task->m_request_clamp_motion = (Carrier_task::Clamp_motion)tp_carrier->m_actual_clamp_motion1;
  4544. tp_carrier_task->m_request_joint_motion_x = (Carrier_task::Joint_motion)tp_carrier->m_actual_joint_motion_x1;
  4545. tp_carrier_task->m_request_joint_motion_y = Carrier_task::Joint_motion::E_JOINT_NO_ACTION;
  4546. tp_carrier_task->m_request_space_id = 0;
  4547. tp_carrier_task->m_request_floor_id = 0;
  4548. tp_carrier_task->m_request_wheelbase = Dispatch_coordinates::get_instance_references().m_default_wheelbase;
  4549. t_error = tp_carrier->execute_task(dispatch_control_node.mp_dispatch_task, Dispatch_device_base::DISPATCH_TASK_ONE_LEVEL);
  4550. if ( t_error != Error_code::SUCCESS )
  4551. {
  4552. dispatch_control_node.m_error = t_error;
  4553. return t_error;
  4554. }
  4555. }
  4556. else
  4557. {
  4558. std::cout << " huli test :::: " << " 123123123123123123123 = " << 4566 << std::endl;
  4559. std::cout << " huli test :::: " << " tp_carrier->check_status() = " << tp_carrier->check_status().to_string() << std::endl;
  4560. std::cout << " huli test :::: " << " tp_carrier->m_actual_device_status = " << tp_carrier->m_actual_device_status << std::endl;
  4561. t_error = Error_manager(Error_code::DISPATCH_PROCESS_DEVICE_STATUS_ERROR, Error_level::MINOR_ERROR,
  4562. " tp_carrier->m_actual_device_status device_status error ");
  4563. dispatch_control_node.m_error = t_error;
  4564. return t_error;
  4565. }
  4566. //设置起点
  4567. dispatch_control_node.m_source_coordinates = Dispatch_coordinates::get_instance_references().m_carrier_coordinates_map[dispatch_control_node.m_dispatch_control_request_msg.dispatch_source()];
  4568. //设置终点
  4569. dispatch_control_node.m_destination_coordinates = Dispatch_coordinates::get_instance_references().m_carrier_coordinates_map[dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination()];
  4570. std::cout << " huli test :::: " << " ---------------------------------------- = " << 123 << std::endl;
  4571. std::cout << " huli test :::: " << " dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination() = " << dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination() << std::endl;
  4572. std::cout << " huli test :::: " << " dispatch_control_node.m_destination_coordinates.x = " << dispatch_control_node.m_destination_coordinates.x << std::endl;
  4573. std::cout << " huli test :::: " << " dispatch_control_node.m_destination_coordinates.y = " << dispatch_control_node.m_destination_coordinates.y << std::endl;
  4574. std::cout << " huli test :::: " << " dispatch_control_node.m_destination_coordinates.z = " << dispatch_control_node.m_destination_coordinates.z << std::endl;
  4575. std::cout << " huli test :::: " << "*******************************************" << 123 << std::endl;
  4576. }
  4577. else
  4578. {
  4579. t_error = Error_manager(Error_code::DISPATCH_PROCESS_DEVICE_TYPE_ERROR, Error_level::MINOR_ERROR,
  4580. " DISPATCH_PROCESS_DEVICE_TYPE_ERROR fun error ");
  4581. dispatch_control_node.m_error = t_error;
  4582. return t_error;
  4583. }
  4584. return Error_code::SUCCESS;
  4585. }
  4586. //执行调度控制指令, 并根据完成情况给答复
  4587. Error_manager Dispatch_process::excute_dispatch_control(int dispatch_device_type, Dispatch_control_node & dispatch_control_node)
  4588. {
  4589. Error_manager t_error;
  4590. if ( dispatch_device_type == message::Dispatch_device_type::ROBOT_1 ||
  4591. dispatch_device_type == message::Dispatch_device_type::ROBOT_2 )
  4592. {
  4593. Catcher_task * tp_catcher_task = (Catcher_task *)dispatch_control_node.mp_dispatch_task.get();
  4594. // while (1)
  4595. // {
  4596. // char in;
  4597. // std::cin >> in ;
  4598. // if ( in == 'p' )
  4599. // {
  4600. // break;
  4601. // }
  4602. // }
  4603. // std::cout << " huli test :::: " << "ppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp = " << tp_catcher_task->m_step << std::endl;
  4604. // std::cout << " huli test :::: " << "1111111 tp_catcher_task->m_step = " << tp_catcher_task->m_step << std::endl;
  4605. //设备的动作也使用外部的Main()的线程来循环
  4606. switch ( dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type() )
  4607. {
  4608. case message::Dispatch_task_type::ROBOT_CATCH_CAR_FROM_INLET:
  4609. {
  4610. t_error = excute_robot_catch_car_from_inlet(dispatch_control_node);
  4611. break;
  4612. }
  4613. case message::Dispatch_task_type::ROBOT_PUT_CAR_TO_CARRIER:
  4614. {
  4615. t_error = excute_robot_put_car_to_carrier(dispatch_control_node);
  4616. break;
  4617. }
  4618. case message::Dispatch_task_type::ROBOT_CATCH_CAR_FROM_CARRIER:
  4619. {
  4620. t_error = excute_robot_catch_car_from_carrier(dispatch_control_node);
  4621. break;
  4622. }
  4623. case message::Dispatch_task_type::ROBOT_PUT_CAR_TO_OUTLET:
  4624. {
  4625. t_error = excute_robot_put_car_to_outlet(dispatch_control_node);
  4626. break;
  4627. }
  4628. case message::Dispatch_task_type::ROBOT_MOVE:
  4629. {
  4630. t_error = excute_robot_move(dispatch_control_node);
  4631. break;
  4632. }
  4633. default:
  4634. {
  4635. return Error_manager(Error_code::DISPATCH_PROCESS_TASK_STATUS_ERROR, Error_level::MINOR_ERROR,
  4636. "Dispatch_process::excute_dispatch_control() fun error ");
  4637. break;
  4638. }
  4639. }
  4640. // std::cout << " huli test :::: " << "222222 tp_catcher_task->m_step = " << tp_catcher_task->m_step << std::endl;
  4641. // std::cout << " huli test :::: " << " t_error_catcher = " << t_error.to_string() << std::endl;
  4642. }
  4643. else if ( dispatch_device_type == message::Dispatch_device_type::CARRIER_1 ||
  4644. dispatch_device_type == message::Dispatch_device_type::CARRIER_2 ||
  4645. dispatch_device_type == message::Dispatch_device_type::CARRIER_3 )
  4646. {
  4647. Catcher_task *tp_carrier_task = (Catcher_task *) dispatch_control_node.mp_dispatch_task.get();
  4648. // while (1)
  4649. // {
  4650. // char in;
  4651. // std::cin >> in;
  4652. // if (in == 'l')
  4653. // {
  4654. // break;
  4655. // }
  4656. // }
  4657. // std::cout << " huli test :::: "
  4658. // << "lllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllllll = "
  4659. // << tp_carrier_task->m_step << std::endl;
  4660. // std::cout << " huli test :::: " << "3333333 tp_carrier_task->m_step = " << tp_carrier_task->m_step
  4661. // << std::endl;
  4662. //设备的动作也使用外部的Main()的线程来循环
  4663. switch (dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type())
  4664. {
  4665. case message::Dispatch_task_type::CARRIER_RECEIVE_CAR_FROM_ROBOT:
  4666. {
  4667. t_error = excute_carrier_receive_car_from_robot(dispatch_control_node);
  4668. break;
  4669. }
  4670. case message::Dispatch_task_type::CARRIER_STORE_CAR_TO_PARKINGSPACE:
  4671. {
  4672. t_error = excute_carrier_store_car_to_parkingspace(dispatch_control_node);
  4673. break;
  4674. }
  4675. case message::Dispatch_task_type::CARRIER_STORE_CAR_TO_PARKINGSPACE_EX:
  4676. {
  4677. t_error = excute_carrier_store_car_to_parkingspace_ex(dispatch_control_node);
  4678. break;
  4679. }
  4680. case message::Dispatch_task_type::CARRIER_PICKUP_CAR_FROM_PARKINGSPACE:
  4681. {
  4682. t_error = excute_carrier_pickup_car_from_parkingspace(dispatch_control_node);
  4683. break;
  4684. }
  4685. case message::Dispatch_task_type::CARRIER_PICKUP_CAR_FROM_PARKINGSPACE_EX:
  4686. {
  4687. t_error = excute_carrier_pickup_car_from_parkingspace_ex(dispatch_control_node);
  4688. break;
  4689. }
  4690. case message::Dispatch_task_type::CARRIER_DELIVER_CAR_TO_ROBOT:
  4691. {
  4692. t_error = excute_carrier_deliver_car_to_robot(dispatch_control_node);
  4693. break;
  4694. }
  4695. case message::Dispatch_task_type::CARRIER_MOVE:
  4696. {
  4697. t_error = excute_carrier_move(dispatch_control_node);
  4698. break;
  4699. }
  4700. default:
  4701. {
  4702. return Error_manager(Error_code::DISPATCH_PROCESS_TASK_STATUS_ERROR, Error_level::MINOR_ERROR,
  4703. "Dispatch_process::excute_dispatch_control() fun error ");
  4704. break;
  4705. }
  4706. }
  4707. // std::cout << " huli test :::: " << "44444444 tp_carrier_task->m_step = " << tp_carrier_task->m_step << std::endl;
  4708. // std::cout << " huli test :::: " << " t_error_carrier = " << t_error.to_string() << std::endl;
  4709. }
  4710. dispatch_control_node.m_error = t_error;
  4711. return t_error;
  4712. }
  4713. //流程通知设备 收回任务单
  4714. Error_manager Dispatch_process::dispatch_control_withdraw_task(int dispatch_device_type, Dispatch_control_node & dispatch_control_node)
  4715. {
  4716. if ( dispatch_control_node.mp_dispatch_device.get() != NULL && dispatch_control_node.mp_dispatch_task.get() != NULL )
  4717. {
  4718. dispatch_control_node.mp_dispatch_task->set_task_statu(Task_Base::Task_statu::TASK_WITHDRAW);
  4719. }
  4720. return Error_code::SUCCESS;
  4721. }
  4722. //发送调度控制答复, 发给调度控制的
  4723. Error_manager Dispatch_process::send_dispatch_control_response_msg(int dispatch_device_type, Dispatch_control_node & dispatch_control_node, message::Dispatch_device_task_status dispatch_device_task_status)
  4724. {
  4725. dispatch_control_node.m_dispatch_control_response_msg.mutable_base_info()->set_msg_type(message::Message_type::eDispatch_control_response_msg);
  4726. dispatch_control_node.m_dispatch_control_response_msg.mutable_base_info()->set_timeout_ms(dispatch_control_node.m_dispatch_control_request_msg.base_info().timeout_ms());
  4727. dispatch_control_node.m_dispatch_control_response_msg.mutable_base_info()->set_sender(message::Communicator::eDispatch_manager);
  4728. dispatch_control_node.m_dispatch_control_response_msg.mutable_base_info()->set_receiver(message::Communicator::eDispatch_control);
  4729. dispatch_control_node.m_dispatch_control_response_msg.set_command_key(dispatch_control_node.m_dispatch_control_request_msg.command_key());
  4730. dispatch_control_node.m_dispatch_control_response_msg.set_dispatch_task_type(dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type());
  4731. dispatch_control_node.m_dispatch_control_response_msg.set_dispatch_device_type(dispatch_control_node.m_dispatch_control_request_msg.dispatch_device_type());
  4732. dispatch_control_node.m_dispatch_control_response_msg.set_dispatch_source(dispatch_control_node.m_dispatch_control_request_msg.dispatch_source());
  4733. dispatch_control_node.m_dispatch_control_response_msg.set_dispatch_destination(dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination());
  4734. dispatch_control_node.m_dispatch_control_response_msg.mutable_error_manager()->set_error_code(dispatch_control_node.m_error.get_error_code());
  4735. dispatch_control_node.m_dispatch_control_response_msg.mutable_error_manager()->set_error_level((message::Error_level)dispatch_control_node.m_error.get_error_level());
  4736. dispatch_control_node.m_dispatch_control_response_msg.mutable_error_manager()->set_error_description(dispatch_control_node.m_error.get_error_description());
  4737. dispatch_control_node.m_dispatch_control_response_msg.set_dispatch_device_target_status(dispatch_control_node.m_dispatch_control_request_msg.dispatch_device_target_status());
  4738. dispatch_control_node.m_dispatch_control_response_msg.set_dispatch_device_task_status(dispatch_device_task_status);
  4739. std::string t_msg = dispatch_control_node.m_dispatch_control_response_msg.SerializeAsString();
  4740. System_communication::get_instance_references().encapsulate_msg(t_msg);
  4741. if ( dispatch_device_task_status == message::Dispatch_device_task_status::E_TASK_OVER )
  4742. {
  4743. LOG(INFO) << " dispatch_control_node.m_dispatch_control_response_msg = "<< dispatch_control_node.m_dispatch_control_response_msg.DebugString() << " " << this;
  4744. }
  4745. return Error_code::SUCCESS;
  4746. }
  4747. //断开调度设备, 释放任务单 与设备解除连接
  4748. Error_manager Dispatch_process::disconnect_dispatch_device(int dispatch_device_type, Dispatch_control_node & dispatch_control_node)
  4749. {
  4750. if ( dispatch_control_node.mp_dispatch_device.get() != NULL && dispatch_control_node.mp_dispatch_task.get() != NULL )
  4751. {
  4752. if ( dispatch_control_node.mp_dispatch_task->get_task_statu() == Task_Base::Task_statu::TASK_FREE )
  4753. {
  4754. dispatch_control_node.mp_dispatch_task.reset();
  4755. dispatch_control_node.mp_dispatch_device.reset();
  4756. return Error_code::SUCCESS;
  4757. }
  4758. else
  4759. {
  4760. return Error_code::NODATA;
  4761. }
  4762. }
  4763. return Error_code::SUCCESS;
  4764. }
  4765. //等待调度总计划答复
  4766. Error_manager Dispatch_process::wait_dispatch_plan_response_msg()
  4767. {
  4768. std::unique_lock<std::mutex> t_lock(m_lock);
  4769. //key 相等 就表示 收到了总计划答复
  4770. if ( m_dispatch_plan_request_msg.command_key() == m_dispatch_plan_response_msg.command_key() )
  4771. {
  4772. return Error_code::SUCCESS;
  4773. }
  4774. else
  4775. {
  4776. return Error_code::NODATA;
  4777. }
  4778. }
  4779. //发送调度答复, 发给主控的
  4780. Error_manager Dispatch_process::send_dispatch_response_msg()
  4781. {
  4782. std::unique_lock<std::mutex> t_lock(m_lock);
  4783. m_dispatch_response_msg.mutable_base_info()->set_msg_type(message::Message_type::eDispatch_response_msg);
  4784. m_dispatch_response_msg.mutable_base_info()->set_timeout_ms(m_dispatch_request_msg.base_info().timeout_ms());
  4785. m_dispatch_response_msg.mutable_base_info()->set_sender(message::Communicator::eDispatch_manager);
  4786. m_dispatch_response_msg.mutable_base_info()->set_receiver(message::Communicator::eMain);
  4787. m_dispatch_response_msg.set_command_key(m_dispatch_request_msg.command_key());
  4788. m_dispatch_response_msg.set_dispatch_motion_direction(m_dispatch_request_msg.dispatch_motion_direction());
  4789. m_dispatch_response_msg.set_terminal_id(m_dispatch_request_msg.terminal_id());
  4790. m_dispatch_response_msg.mutable_locate_information()->CopyFrom(m_dispatch_request_msg.locate_information());
  4791. m_dispatch_response_msg.mutable_parkspace_info_ex()->CopyFrom(m_dispatch_request_msg.parkspace_info_ex());
  4792. m_dispatch_response_msg.set_car_type(m_dispatch_request_msg.car_type());
  4793. if ( m_dispatch_response_msg.dispatch_motion_direction() == message::E_STORE_CAR )
  4794. {
  4795. for (int i = 0; i < m_dispatch_response_msg.parkspace_info_ex_size(); ++i)
  4796. {
  4797. if ( m_dispatch_destination == m_dispatch_response_msg.parkspace_info_ex(i).parkingspace_index_id() )
  4798. {
  4799. m_dispatch_response_msg.mutable_parkspace_info_ex(i)->set_parkspace_status_target(message::Parkspace_status::eParkspace_occupied);
  4800. }
  4801. else
  4802. {
  4803. m_dispatch_response_msg.mutable_parkspace_info_ex(i)->set_parkspace_status_target(message::Parkspace_status::eParkspace_empty);
  4804. }
  4805. }
  4806. }
  4807. else if( m_dispatch_response_msg.dispatch_motion_direction() == message::E_PICKUP_CAR )
  4808. {
  4809. for (int i = 0; i < m_dispatch_response_msg.parkspace_info_ex_size(); ++i)
  4810. {
  4811. if ( m_dispatch_source == m_dispatch_response_msg.parkspace_info_ex(i).parkingspace_index_id() )
  4812. {
  4813. m_dispatch_response_msg.mutable_parkspace_info_ex(i)->set_parkspace_status_target(message::Parkspace_status::eParkspace_occupied);
  4814. }
  4815. else
  4816. {
  4817. m_dispatch_response_msg.mutable_parkspace_info_ex(i)->set_parkspace_status_target(message::Parkspace_status::eParkspace_empty);
  4818. }
  4819. }
  4820. }
  4821. m_dispatch_response_msg.mutable_error_manager()->set_error_code(m_result.get_error_code());
  4822. m_dispatch_response_msg.mutable_error_manager()->set_error_level((message::Error_level)m_result.get_error_level());
  4823. m_dispatch_response_msg.mutable_error_manager()->set_error_description(m_result.get_error_description());
  4824. std::string t_msg = m_dispatch_response_msg.SerializeAsString();
  4825. System_communication::get_instance_references().encapsulate_msg(t_msg);
  4826. return Error_code::SUCCESS;
  4827. }
  4828. //通知调度管理, 释放资源,
  4829. Error_manager Dispatch_process::release_resource()
  4830. {
  4831. return Dispatch_manager::get_instance_references().release_dispatch_process(m_command_key);
  4832. }
  4833. //异常处理
  4834. Error_manager Dispatch_process::Exception_handling()
  4835. {
  4836. LOG(INFO) << " -------------Dispatch_process::Exception_handling------------------- "<< this;
  4837. LOG(INFO) << " m_result = "<< m_result.to_string() << " " << this;
  4838. return Error_code::SUCCESS;
  4839. }
  4840. //机器手去入口抓车(例如:机器手移动到2号入口上方,然后下降到一楼抓车,最后上升到最上方)
  4841. Error_manager Dispatch_process::excute_robot_catch_car_from_inlet(Dispatch_control_node & dispatch_control_node)
  4842. {
  4843. Error_manager t_error;
  4844. Catcher * tp_catcher = NULL;
  4845. Catcher_task * tp_catcher_task = NULL;
  4846. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  4847. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  4848. {
  4849. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  4850. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  4851. }
  4852. else
  4853. {
  4854. tp_catcher = (Catcher *)dispatch_control_node.mp_dispatch_device.get();
  4855. tp_catcher_task = (Catcher_task *)dispatch_control_node.mp_dispatch_task.get();
  4856. }
  4857. // std::cout << " huli test :::: " << " tp_catcher_task->m_step = " << tp_catcher_task->m_step << std::endl;
  4858. // getchar();
  4859. if ( tp_catcher_task->m_step == 0 )
  4860. {
  4861. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4862. }
  4863. if ( tp_catcher_task->m_step == 1 )//检查姿态
  4864. {
  4865. if ( tp_catcher->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  4866. {
  4867. if ( tp_catcher->m_actual_clamp_motion1 != Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE ||
  4868. tp_catcher->m_actual_d1 + tp_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance >
  4869. tp_dispatch_coordinates->m_catcher_wheel_base_limit ||
  4870. tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_UNKNOW )
  4871. {
  4872. catcher_adjust_to_ready(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  4873. tp_catcher_task->m_step++;
  4874. }
  4875. else
  4876. {
  4877. tp_catcher_task->m_step +=2;
  4878. }
  4879. }
  4880. else
  4881. {
  4882. return Error_manager(Error_code::CATCHER_POSE_ERROR, Error_level::MINOR_ERROR,
  4883. "Dispatch_process::excute_robot_catch_car_from_inlet() fun error ");
  4884. }
  4885. }
  4886. if ( tp_catcher_task->m_step == 2 )
  4887. {
  4888. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4889. }
  4890. if ( tp_catcher_task->m_step == 3 )//机器手z轴移到最高点.
  4891. {
  4892. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  4893. tp_catcher_task->m_step++;
  4894. }
  4895. if ( tp_catcher_task->m_step == 4 )
  4896. {
  4897. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4898. }
  4899. if ( tp_catcher_task->m_step == 5 )//机器手 调整x y b d1 d2, 根据感测模块的定位信息, 调整机器手的姿态, 准备抓车.
  4900. {
  4901. catcher_adjust_from_ground(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  4902. tp_catcher_task->m_step++;
  4903. }
  4904. if ( tp_catcher_task->m_step == 6 )
  4905. {
  4906. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4907. }
  4908. if ( tp_catcher_task->m_step == 7 )//机器手z轴移到最低点.
  4909. {
  4910. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_1th_floor_z);
  4911. tp_catcher_task->m_step++;
  4912. }
  4913. if ( tp_catcher_task->m_step == 8 )
  4914. {
  4915. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4916. }
  4917. if ( tp_catcher_task->m_step == 9 )//修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  4918. {
  4919. float temp_wheel_base = tp_catcher->m_actual_d1 + tp_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance;
  4920. //修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  4921. if ( Common_data::approximate_difference(m_wheel_base, temp_wheel_base, DISPATCH_DEFAULT_DIFFERENCE) )
  4922. {
  4923. tp_catcher_task->m_step +=2;
  4924. }
  4925. else
  4926. {
  4927. catcher_adjust_wheel_base(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  4928. tp_catcher_task->m_step++;
  4929. }
  4930. }
  4931. if ( tp_catcher_task->m_step == 10 )
  4932. {
  4933. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4934. }
  4935. if ( tp_catcher_task->m_step == 11 )//机器手 夹车
  4936. {
  4937. catcher_move_c(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, Catcher_task::Clamp_motion::E_CLAMP_TIGHT);
  4938. tp_catcher_task->m_step++;
  4939. }
  4940. if ( tp_catcher_task->m_step == 12 )
  4941. {
  4942. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4943. }
  4944. if ( tp_catcher_task->m_step == 13 )//机器手 z轴上升到最高处
  4945. {
  4946. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  4947. tp_catcher_task->m_step++;
  4948. }
  4949. if ( tp_catcher_task->m_step == 14 )
  4950. {
  4951. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4952. }
  4953. if ( tp_catcher_task->m_step == 15 )//机器手调整到 准备把车放到搬运器的姿态
  4954. {
  4955. //这里机器手要反向,
  4956. catcher_adjust_to_carrier(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, true);
  4957. tp_catcher_task->m_step++;
  4958. }
  4959. if ( tp_catcher_task->m_step == 16 )
  4960. {
  4961. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4962. }
  4963. if ( tp_catcher_task->m_step == 17 )
  4964. {
  4965. return Error_code::SUCCESS;
  4966. }
  4967. return Error_code::SUCCESS;
  4968. }
  4969. //机器手把车放到中跑车上面(例如:机器手下降到中跑车上放车,最后上升到最上方)(通过目标点 指定放到哪一个中跑车上)
  4970. Error_manager Dispatch_process::excute_robot_put_car_to_carrier(Dispatch_control_node & dispatch_control_node)
  4971. {
  4972. Error_manager t_error;
  4973. Catcher * tp_catcher = NULL;
  4974. Catcher_task * tp_catcher_task = NULL;
  4975. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  4976. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  4977. {
  4978. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  4979. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  4980. }
  4981. else
  4982. {
  4983. tp_catcher = (Catcher *)dispatch_control_node.mp_dispatch_device.get();
  4984. tp_catcher_task = (Catcher_task *)dispatch_control_node.mp_dispatch_task.get();
  4985. }
  4986. // std::cout << " huli test :::: " << " tp_catcher_task->m_step = " << tp_catcher_task->m_step << std::endl;
  4987. // getchar();
  4988. if ( tp_catcher_task->m_step == 0 )
  4989. {
  4990. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  4991. }
  4992. if ( tp_catcher_task->m_step == 1 )//检查姿态
  4993. {
  4994. if ( tp_catcher->m_actual_load_status == Dispatch_device_base::Load_status::HAVE_CAR &&
  4995. tp_catcher->m_actual_clamp_motion1 == Dispatch_device_base::Clamp_motion::E_CLAMP_TIGHT &&
  4996. (Common_data::approximate_difference(tp_catcher->m_actual_b, 90, DISPATCH_DEFAULT_DIFFERENCE) || Common_data::approximate_difference(tp_catcher->m_actual_b, 270, DISPATCH_DEFAULT_DIFFERENCE) ) )
  4997. {
  4998. //检测正常, 直接跳过即可
  4999. tp_catcher_task->m_step +=2;
  5000. }
  5001. else
  5002. {
  5003. return Error_manager(Error_code::CATCHER_POSE_ERROR, Error_level::MINOR_ERROR,
  5004. "Dispatch_process::excute_robot_put_car_to_carrier() fun error ");
  5005. }
  5006. }
  5007. if ( tp_catcher_task->m_step == 2 )
  5008. {
  5009. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5010. }
  5011. if ( tp_catcher_task->m_step == 3 )//机器手 调整z轴
  5012. {
  5013. if ( tp_catcher->m_actual_z*1.02 >= tp_dispatch_coordinates->m_catcher_4th_floor_z )
  5014. {
  5015. //检测正常, 直接跳过即可
  5016. tp_catcher_task->m_step +=2;
  5017. }
  5018. else
  5019. {
  5020. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  5021. tp_catcher_task->m_step++;
  5022. }
  5023. }
  5024. if ( tp_catcher_task->m_step == 4 )
  5025. {
  5026. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5027. }
  5028. if ( tp_catcher_task->m_step == 5 )//机器手调整到 准备把车放到搬运器的姿态
  5029. {
  5030. float temp_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  5031. if ( Common_data::approximate_difference(tp_catcher->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) &&
  5032. Common_data::approximate_difference(tp_catcher->m_actual_y, temp_y, DISPATCH_DEFAULT_DIFFERENCE))
  5033. {
  5034. //检测正常, 直接跳过即可
  5035. tp_catcher_task->m_step +=2;
  5036. }
  5037. else
  5038. {
  5039. catcher_adjust_to_carrier(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, false);
  5040. tp_catcher_task->m_step++;
  5041. }
  5042. }
  5043. if ( tp_catcher_task->m_step == 6 )
  5044. {
  5045. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5046. }
  5047. if ( tp_catcher_task->m_step == 7 )//机器手 z轴下降
  5048. {
  5049. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  5050. tp_catcher_task->m_step++;
  5051. }
  5052. if ( tp_catcher_task->m_step == 8 )
  5053. {
  5054. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5055. }
  5056. if ( tp_catcher_task->m_step == 9 )//机器手 松开夹杆
  5057. {
  5058. catcher_move_c(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, Catcher_task::Clamp_motion::E_CLAMP_LOOSE);
  5059. tp_catcher_task->m_step++;
  5060. }
  5061. if ( tp_catcher_task->m_step == 10 )
  5062. {
  5063. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5064. }
  5065. if ( tp_catcher_task->m_step == 11 )//机器手 z轴上升
  5066. {
  5067. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  5068. tp_catcher_task->m_step++;
  5069. }
  5070. if ( tp_catcher_task->m_step == 12 )
  5071. {
  5072. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5073. }
  5074. if ( tp_catcher_task->m_step == 13 )
  5075. {
  5076. return Error_code::SUCCESS;
  5077. }
  5078. return Error_code::SUCCESS;
  5079. }
  5080. //机器手去中跑车上抓车(例如:机器手移动到1号中跑车上方,然后下降到中跑车抓车,最后上升到最上方)
  5081. Error_manager Dispatch_process::excute_robot_catch_car_from_carrier(Dispatch_control_node & dispatch_control_node)
  5082. {
  5083. Error_manager t_error;
  5084. Catcher * tp_catcher = NULL;
  5085. Catcher_task * tp_catcher_task = NULL;
  5086. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  5087. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  5088. {
  5089. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  5090. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  5091. }
  5092. else
  5093. {
  5094. tp_catcher = (Catcher *)dispatch_control_node.mp_dispatch_device.get();
  5095. tp_catcher_task = (Catcher_task *)dispatch_control_node.mp_dispatch_task.get();
  5096. }
  5097. // std::cout << " huli test :::: " << " tp_catcher_task->m_step = " << tp_catcher_task->m_step << std::endl;
  5098. // getchar();
  5099. if ( tp_catcher_task->m_step == 0 )
  5100. {
  5101. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5102. }
  5103. if ( tp_catcher_task->m_step == 1 )
  5104. {
  5105. if ( tp_catcher->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  5106. {
  5107. if ( tp_catcher->m_actual_clamp_motion1 != Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE ||
  5108. tp_catcher->m_actual_d1 + tp_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance >
  5109. tp_dispatch_coordinates->m_catcher_wheel_base_limit ||
  5110. tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_UNKNOW )
  5111. {
  5112. catcher_adjust_to_ready(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  5113. tp_catcher_task->m_step++;
  5114. }
  5115. else
  5116. {
  5117. tp_catcher_task->m_step +=2;
  5118. }
  5119. }
  5120. else
  5121. {
  5122. return Error_manager(Error_code::CATCHER_POSE_ERROR, Error_level::MINOR_ERROR,
  5123. "Dispatch_process::excute_robot_catch_car_from_carrier() fun error ");
  5124. }
  5125. }
  5126. if ( tp_catcher_task->m_step == 2 )
  5127. {
  5128. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5129. }
  5130. if ( tp_catcher_task->m_step == 3 )//机器手 调整z轴
  5131. {
  5132. if ( tp_catcher->m_actual_z*1.02 >= tp_dispatch_coordinates->m_catcher_4th_floor_z )
  5133. {
  5134. //检测正常, 直接跳过即可
  5135. tp_catcher_task->m_step +=2;
  5136. }
  5137. else
  5138. {
  5139. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  5140. tp_catcher_task->m_step++;
  5141. }
  5142. }
  5143. if ( tp_catcher_task->m_step == 4 )
  5144. {
  5145. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5146. }
  5147. if ( tp_catcher_task->m_step == 5 )//机器手调整到 准备把车放到搬运器的姿态
  5148. {
  5149. float temp_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  5150. if ( Common_data::approximate_difference(tp_catcher->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) &&
  5151. Common_data::approximate_difference(tp_catcher->m_actual_y, temp_y, DISPATCH_DEFAULT_DIFFERENCE))
  5152. {
  5153. //检测正常, 直接跳过即可
  5154. tp_catcher_task->m_step +=2;
  5155. }
  5156. else
  5157. {
  5158. catcher_adjust_from_carrier(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  5159. tp_catcher_task->m_step++;
  5160. }
  5161. }
  5162. if ( tp_catcher_task->m_step == 6 )
  5163. {
  5164. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5165. }
  5166. if ( tp_catcher_task->m_step == 7 )//机器手 z轴下降
  5167. {
  5168. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  5169. tp_catcher_task->m_step++;
  5170. }
  5171. if ( tp_catcher_task->m_step == 8 )
  5172. {
  5173. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5174. }
  5175. if ( tp_catcher_task->m_step == 9 )//修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  5176. {
  5177. float temp_wheel_base = tp_catcher->m_actual_d1 + tp_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance;
  5178. //修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  5179. if ( Common_data::approximate_difference(m_wheel_base, temp_wheel_base, DISPATCH_DEFAULT_DIFFERENCE) )
  5180. {
  5181. tp_catcher_task->m_step +=2;
  5182. }
  5183. else
  5184. {
  5185. catcher_adjust_wheel_base(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  5186. tp_catcher_task->m_step++;
  5187. }
  5188. }
  5189. if ( tp_catcher_task->m_step == 10 )
  5190. {
  5191. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5192. }
  5193. if ( tp_catcher_task->m_step == 11 )//机器手 夹车
  5194. {
  5195. catcher_move_c(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, Catcher_task::Clamp_motion::E_CLAMP_TIGHT);
  5196. tp_catcher_task->m_step++;
  5197. }
  5198. if ( tp_catcher_task->m_step == 12 )
  5199. {
  5200. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5201. }
  5202. if ( tp_catcher_task->m_step == 13 )//机器手 z轴上升
  5203. {
  5204. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  5205. tp_catcher_task->m_step++;
  5206. }
  5207. if ( tp_catcher_task->m_step == 14 )
  5208. {
  5209. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5210. }
  5211. if ( tp_catcher_task->m_step == 15 )
  5212. {
  5213. return Error_code::SUCCESS;
  5214. }
  5215. return Error_code::SUCCESS;
  5216. }
  5217. //机器手去出口放车(例如:机器手移动到3号出口上方,然后下降到一楼放车,最后上升到最上方)
  5218. Error_manager Dispatch_process::excute_robot_put_car_to_outlet(Dispatch_control_node & dispatch_control_node)
  5219. {
  5220. Error_manager t_error;
  5221. Catcher * tp_catcher = NULL;
  5222. Catcher_task * tp_catcher_task = NULL;
  5223. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  5224. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  5225. {
  5226. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  5227. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  5228. }
  5229. else
  5230. {
  5231. tp_catcher = (Catcher *)dispatch_control_node.mp_dispatch_device.get();
  5232. tp_catcher_task = (Catcher_task *)dispatch_control_node.mp_dispatch_task.get();
  5233. }
  5234. // std::cout << " huli test :::: " << " tp_catcher_task->m_step = " << tp_catcher_task->m_step << std::endl;
  5235. // getchar();
  5236. if ( tp_catcher_task->m_step == 0 )
  5237. {
  5238. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5239. }
  5240. if ( tp_catcher_task->m_step == 1 )//检查姿态
  5241. {
  5242. if ( tp_catcher->m_actual_load_status == Dispatch_device_base::Load_status::HAVE_CAR &&
  5243. tp_catcher->m_actual_clamp_motion1 == Dispatch_device_base::Clamp_motion::E_CLAMP_TIGHT &&
  5244. (Common_data::approximate_difference(tp_catcher->m_actual_b, 90, DISPATCH_DEFAULT_DIFFERENCE) || Common_data::approximate_difference(tp_catcher->m_actual_b, 270, DISPATCH_DEFAULT_DIFFERENCE) ) )
  5245. {
  5246. //检测正常, 直接跳过即可
  5247. tp_catcher_task->m_step +=2;
  5248. }
  5249. else
  5250. {
  5251. return Error_manager(Error_code::CATCHER_POSE_ERROR, Error_level::MINOR_ERROR,
  5252. "Dispatch_process::excute_robot_put_car_to_carrier() fun error ");
  5253. }
  5254. }
  5255. if ( tp_catcher_task->m_step == 2 )
  5256. {
  5257. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5258. }
  5259. if ( tp_catcher_task->m_step == 3 )//机器手 调整z轴
  5260. {
  5261. if ( tp_catcher->m_actual_z*1.02 >= tp_dispatch_coordinates->m_catcher_4th_floor_z )
  5262. {
  5263. //检测正常, 直接跳过即可
  5264. tp_catcher_task->m_step +=2;
  5265. }
  5266. else
  5267. {
  5268. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  5269. tp_catcher_task->m_step++;
  5270. }
  5271. }
  5272. if ( tp_catcher_task->m_step == 4 )
  5273. {
  5274. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5275. }
  5276. if ( tp_catcher_task->m_step == 5 )//机器手调整到 准备把车放到地面的姿态
  5277. {
  5278. if ( Common_data::approximate_difference(tp_catcher->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) &&
  5279. Common_data::approximate_difference(tp_catcher->m_actual_y, dispatch_control_node.m_destination_coordinates.y, DISPATCH_DEFAULT_DIFFERENCE))
  5280. {
  5281. //检测正常, 直接跳过即可
  5282. tp_catcher_task->m_step +=2;
  5283. }
  5284. else
  5285. {
  5286. catcher_adjust_to_ground(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  5287. tp_catcher_task->m_step++;
  5288. }
  5289. }
  5290. if ( tp_catcher_task->m_step == 6 )
  5291. {
  5292. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5293. }
  5294. if ( tp_catcher_task->m_step == 7 )//机器手 z轴下降
  5295. {
  5296. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  5297. tp_catcher_task->m_step++;
  5298. }
  5299. if ( tp_catcher_task->m_step == 8 )
  5300. {
  5301. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5302. }
  5303. if ( tp_catcher_task->m_step == 9 )//机器手 松开夹杆
  5304. {
  5305. catcher_move_c(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, Catcher_task::Clamp_motion::E_CLAMP_LOOSE);
  5306. tp_catcher_task->m_step++;
  5307. }
  5308. if ( tp_catcher_task->m_step == 10 )
  5309. {
  5310. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5311. }
  5312. if ( tp_catcher_task->m_step == 11 )//机器手 z轴上升
  5313. {
  5314. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_catcher_4th_floor_z);
  5315. tp_catcher_task->m_step++;
  5316. }
  5317. if ( tp_catcher_task->m_step == 12 )
  5318. {
  5319. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5320. }
  5321. if ( tp_catcher_task->m_step == 13 )
  5322. {
  5323. return Error_code::SUCCESS;
  5324. }
  5325. return Error_code::SUCCESS;
  5326. }
  5327. //机器手的自由移动(例如:机器手移动到6号出入口的上方4楼处,给其他设备避让)(不进行抓车和放车的操作)
  5328. Error_manager Dispatch_process::excute_robot_move(Dispatch_control_node & dispatch_control_node)
  5329. {
  5330. Error_manager t_error;
  5331. Catcher * tp_catcher = NULL;
  5332. Catcher_task * tp_catcher_task = NULL;
  5333. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  5334. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  5335. {
  5336. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  5337. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  5338. }
  5339. else
  5340. {
  5341. tp_catcher = (Catcher *)dispatch_control_node.mp_dispatch_device.get();
  5342. tp_catcher_task = (Catcher_task *)dispatch_control_node.mp_dispatch_task.get();
  5343. }
  5344. if ( tp_catcher_task->m_step == 0 )
  5345. {
  5346. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5347. }
  5348. if ( tp_catcher_task->m_step == 1 )//检查姿态
  5349. {
  5350. if ( tp_catcher->m_actual_d1 + tp_catcher->m_actual_d2 + tp_dispatch_coordinates->m_catcher_d1_d2_distance >
  5351. tp_dispatch_coordinates->m_catcher_wheel_base_limit ||
  5352. tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_UNKNOW )
  5353. {
  5354. catcher_adjust_to_ready(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  5355. tp_catcher_task->m_step++;
  5356. }
  5357. else
  5358. {
  5359. tp_catcher_task->m_step +=2;
  5360. }
  5361. }
  5362. if ( tp_catcher_task->m_step == 2 )
  5363. {
  5364. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5365. }
  5366. if ( tp_catcher_task->m_step == 3 )//机器手 调整z轴
  5367. {
  5368. catcher_move_z(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  5369. tp_catcher_task->m_step++;
  5370. }
  5371. if ( tp_catcher_task->m_step == 4 )
  5372. {
  5373. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5374. }
  5375. if ( tp_catcher_task->m_step == 5 )//机器手调整到 准备把车放到地面的姿态
  5376. {
  5377. catcher_adjust_to_ground(dispatch_control_node, tp_catcher, tp_catcher_task, tp_dispatch_coordinates);
  5378. tp_catcher_task->m_step++;
  5379. }
  5380. if ( tp_catcher_task->m_step == 6 )
  5381. {
  5382. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_catcher_task->m_step);
  5383. }
  5384. if ( tp_catcher_task->m_step == 7 )
  5385. {
  5386. return Error_code::SUCCESS;
  5387. }
  5388. return Error_code::SUCCESS;
  5389. }
  5390. //搬运器从机器手上接车(例如:搬运器移动到2号入口的上方,然后等待机器手把车放到中跑车上,小跑车保持松夹杆状态)
  5391. Error_manager Dispatch_process::excute_carrier_receive_car_from_robot(Dispatch_control_node & dispatch_control_node)
  5392. {
  5393. Error_manager t_error;
  5394. Carrier * tp_carrier = NULL;
  5395. Carrier_task * tp_carrier_task = NULL;
  5396. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  5397. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  5398. {
  5399. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  5400. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  5401. }
  5402. else
  5403. {
  5404. tp_carrier = (Carrier *)dispatch_control_node.mp_dispatch_device.get();
  5405. tp_carrier_task = (Carrier_task *)dispatch_control_node.mp_dispatch_task.get();
  5406. }
  5407. // std::cout << " huli test :::: " << " tp_catcher_task->m_step = " << tp_carrier_task->m_step << std::endl;
  5408. // getchar();
  5409. if ( tp_carrier_task->m_step == 0 )
  5410. {
  5411. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5412. }
  5413. if ( tp_carrier_task->m_step == 1 )//检查姿态
  5414. {
  5415. //检查姿态
  5416. if ( tp_carrier->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  5417. {
  5418. if ( tp_carrier_task->m_request_clamp_motion == Carrier_task::Clamp_motion::E_CLAMP_LOOSE &&
  5419. Common_data::approximate_difference(m_wheel_base, tp_carrier->m_actual_y1-tp_carrier->m_actual_y2, DISPATCH_DEFAULT_DIFFERENCE))
  5420. {
  5421. tp_carrier_task->m_step +=2;
  5422. }
  5423. else
  5424. {
  5425. carrier_adjust_to_ready(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates);
  5426. tp_carrier_task->m_step++;
  5427. }
  5428. }
  5429. else
  5430. {
  5431. return Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  5432. "tp_carrier->m_actual_load_status != Dispatch_device_base::Load_status::NO_CAR fun error ");
  5433. }
  5434. }
  5435. if ( tp_carrier_task->m_step == 2 )
  5436. {
  5437. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5438. }
  5439. if ( tp_carrier_task->m_step == 3 )//让小跑车回到中跑车上
  5440. {
  5441. if ( Common_data::approximate_difference(tp_carrier->m_actual_y, tp_dispatch_coordinates->m_carrier_default_y_back, DISPATCH_DEFAULT_DIFFERENCE) )
  5442. {
  5443. tp_carrier_task->m_step +=2;
  5444. }
  5445. else
  5446. {
  5447. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  5448. tp_carrier_task->m_step++;
  5449. }
  5450. }
  5451. if ( tp_carrier_task->m_step == 4 )
  5452. {
  5453. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5454. }
  5455. if ( tp_carrier_task->m_step == 5 )//让中跑车回到电梯井
  5456. {
  5457. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5458. {
  5459. tp_carrier_task->m_step +=2;
  5460. }
  5461. else
  5462. {
  5463. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  5464. {
  5465. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  5466. tp_carrier_task->m_step++;
  5467. }
  5468. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  5469. {
  5470. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  5471. tp_carrier_task->m_step++;
  5472. }
  5473. else
  5474. {
  5475. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  5476. " m_destination_coordinates.z PARAMRTER ERROR ");
  5477. }
  5478. }
  5479. }
  5480. if ( tp_carrier_task->m_step == 6 )
  5481. {
  5482. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5483. }
  5484. if ( tp_carrier_task->m_step == 7 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  5485. {
  5486. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5487. {
  5488. tp_carrier_task->m_step +=2;
  5489. }
  5490. else
  5491. {
  5492. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  5493. tp_carrier_task->m_step++;
  5494. }
  5495. }
  5496. if ( tp_carrier_task->m_step == 8 )
  5497. {
  5498. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5499. }
  5500. if ( tp_carrier_task->m_step == 9 )//电梯移动到对应的楼层
  5501. {
  5502. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5503. {
  5504. tp_carrier_task->m_step +=2;
  5505. }
  5506. else
  5507. {
  5508. carrier_move_z(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  5509. tp_carrier_task->m_step++;
  5510. }
  5511. }
  5512. if ( tp_carrier_task->m_step == 10 )
  5513. {
  5514. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5515. }
  5516. if ( tp_carrier_task->m_step == 11 )//伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  5517. {
  5518. if ( tp_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK && tp_carrier->get_device_id() !=2)
  5519. {
  5520. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  5521. tp_carrier_task->m_step++;
  5522. }
  5523. else
  5524. {
  5525. tp_carrier_task->m_step +=2;
  5526. }
  5527. }
  5528. if ( tp_carrier_task->m_step == 12 )
  5529. {
  5530. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5531. }
  5532. if ( tp_carrier_task->m_step == 13 )//中跑车 x轴移动
  5533. {
  5534. if ( Common_data::approximate_difference(tp_carrier->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) )
  5535. {
  5536. tp_carrier_task->m_step +=2;
  5537. }
  5538. else
  5539. {
  5540. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.x);
  5541. tp_carrier_task->m_step++;
  5542. }
  5543. }
  5544. if ( tp_carrier_task->m_step == 14 )
  5545. {
  5546. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5547. }
  5548. if ( tp_carrier_task->m_step == 15 )
  5549. {
  5550. return Error_code::SUCCESS;
  5551. }
  5552. return Error_code::SUCCESS;
  5553. }
  5554. //搬运器把车存到停车位上(例如:小跑车夹车后,搬运器移动到56号停车位,然后小跑车将车存入车位,之后搬运器退回至电梯井)
  5555. Error_manager Dispatch_process::excute_carrier_store_car_to_parkingspace(Dispatch_control_node & dispatch_control_node)
  5556. {
  5557. Error_manager t_error;
  5558. Carrier * tp_carrier = NULL;
  5559. Carrier_task * tp_carrier_task = NULL;
  5560. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  5561. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  5562. {
  5563. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  5564. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  5565. }
  5566. else
  5567. {
  5568. tp_carrier = (Carrier *)dispatch_control_node.mp_dispatch_device.get();
  5569. tp_carrier_task = (Carrier_task *)dispatch_control_node.mp_dispatch_task.get();
  5570. }
  5571. // std::cout << " huli test :::: " << " tp_catcher_task->m_step = " << tp_carrier_task->m_step << std::endl;
  5572. // getchar();
  5573. if ( tp_carrier_task->m_step == 0 )
  5574. {
  5575. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5576. }
  5577. if ( tp_carrier_task->m_step == 1 )//检查姿态
  5578. {
  5579. //检查姿态(注注注注注意了, 调试阶段是无车, 真实环境是有车的)
  5580. if ( tp_carrier->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR &&
  5581. tp_carrier->m_actual_clamp_motion1 == Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE)
  5582. {
  5583. //检测正常, 直接跳过即可
  5584. tp_carrier_task->m_step +=2;
  5585. }
  5586. //注意了, 如果是去7号出口, 那么就直接跳过轮距修正和夹车.
  5587. else if(dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination() == 1107)
  5588. {
  5589. tp_carrier_task->m_step = 7;
  5590. }
  5591. else
  5592. {
  5593. return Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  5594. "Dispatch_process::excute_carrier_store_car_to_parkingspace() fun error ");
  5595. }
  5596. }
  5597. if ( tp_carrier_task->m_step == 2 )
  5598. {
  5599. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5600. }
  5601. if ( tp_carrier_task->m_step == 3 )//修正轴距
  5602. {
  5603. float temp_wheel_base = tp_carrier->m_actual_y1 - tp_carrier->m_actual_y2;
  5604. if ( Common_data::approximate_difference(m_wheel_base, temp_wheel_base, DISPATCH_DEFAULT_DIFFERENCE) )
  5605. {
  5606. tp_carrier_task->m_step +=2;
  5607. }
  5608. else
  5609. {
  5610. carrier_adjust_wheel_base(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates);
  5611. tp_carrier_task->m_step++;
  5612. }
  5613. }
  5614. if ( tp_carrier_task->m_step == 4 )
  5615. {
  5616. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5617. }
  5618. if ( tp_carrier_task->m_step == 5 )//让小跑车 夹车
  5619. {
  5620. carrier_move_c(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_TIGHT);
  5621. tp_carrier_task->m_step++;
  5622. }
  5623. if ( tp_carrier_task->m_step == 6 )
  5624. {
  5625. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5626. }
  5627. if ( tp_carrier_task->m_step == 7 )//让中跑车回到电梯井
  5628. {
  5629. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5630. {
  5631. tp_carrier_task->m_step +=2;
  5632. }
  5633. else
  5634. {
  5635. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  5636. {
  5637. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  5638. tp_carrier_task->m_step++;
  5639. }
  5640. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  5641. {
  5642. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  5643. tp_carrier_task->m_step++;
  5644. }
  5645. else
  5646. {
  5647. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  5648. " m_destination_coordinates.z PARAMRTER ERROR ");
  5649. }
  5650. }
  5651. }
  5652. if ( tp_carrier_task->m_step == 8 )
  5653. {
  5654. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5655. }
  5656. if ( tp_carrier_task->m_step == 9 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  5657. {
  5658. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5659. {
  5660. tp_carrier_task->m_step +=2;
  5661. }
  5662. else
  5663. {
  5664. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  5665. tp_carrier_task->m_step++;
  5666. }
  5667. }
  5668. if ( tp_carrier_task->m_step == 10 )
  5669. {
  5670. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5671. }
  5672. if ( tp_carrier_task->m_step == 11 )//电梯移动到对应的楼层
  5673. {
  5674. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5675. {
  5676. tp_carrier_task->m_step +=2;
  5677. }
  5678. else
  5679. {
  5680. carrier_move_z(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  5681. tp_carrier_task->m_step++;
  5682. }
  5683. }
  5684. if ( tp_carrier_task->m_step == 12 )
  5685. {
  5686. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5687. }
  5688. if ( tp_carrier_task->m_step == 13 )//伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  5689. {
  5690. if ( tp_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK && tp_carrier->get_device_id() !=2)
  5691. {
  5692. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  5693. tp_carrier_task->m_step++;
  5694. }
  5695. else
  5696. {
  5697. tp_carrier_task->m_step +=2;
  5698. }
  5699. }
  5700. if ( tp_carrier_task->m_step == 14 )
  5701. {
  5702. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5703. }
  5704. if ( tp_carrier_task->m_step == 15 )//中跑车 x轴移动
  5705. {
  5706. if ( Common_data::approximate_difference(tp_carrier->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) )
  5707. {
  5708. tp_carrier_task->m_step +=2;
  5709. }
  5710. else
  5711. {
  5712. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.x);
  5713. tp_carrier_task->m_step++;
  5714. }
  5715. }
  5716. if ( tp_carrier_task->m_step == 16 )
  5717. {
  5718. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5719. }
  5720. if ( tp_carrier_task->m_step == 17 )//小跑车 进入车位
  5721. {
  5722. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_leave);
  5723. tp_carrier_task->m_step++;
  5724. }
  5725. if ( tp_carrier_task->m_step == 18 )
  5726. {
  5727. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5728. }
  5729. if ( tp_carrier_task->m_step == 19 )//小跑车 松开夹杆
  5730. {
  5731. carrier_move_c(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_LOOSE);
  5732. tp_carrier_task->m_step++;
  5733. }
  5734. if ( tp_carrier_task->m_step == 20 )
  5735. {
  5736. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5737. }
  5738. if ( tp_carrier_task->m_step == 21 )//小跑车 回到中跑车
  5739. {
  5740. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  5741. tp_carrier_task->m_step++;
  5742. }
  5743. if ( tp_carrier_task->m_step == 22 )
  5744. {
  5745. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5746. }
  5747. if ( tp_carrier_task->m_step == 23 )//让中跑车回到电梯井
  5748. {
  5749. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  5750. {
  5751. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  5752. tp_carrier_task->m_step++;
  5753. }
  5754. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  5755. {
  5756. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  5757. tp_carrier_task->m_step++;
  5758. }
  5759. else
  5760. {
  5761. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  5762. " m_destination_coordinates.z PARAMRTER ERROR ");
  5763. }
  5764. }
  5765. if ( tp_carrier_task->m_step == 24 )
  5766. {
  5767. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5768. }
  5769. if ( tp_carrier_task->m_step == 25 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  5770. {
  5771. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  5772. tp_carrier_task->m_step++;
  5773. }
  5774. if ( tp_carrier_task->m_step == 26 )
  5775. {
  5776. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5777. }
  5778. if ( tp_carrier_task->m_step == 27 )
  5779. {
  5780. return Error_code::SUCCESS;
  5781. }
  5782. return Error_code::SUCCESS;
  5783. }
  5784. //搬运器把车存到停车位上(例如:小跑车夹车后,搬运器移动到56号停车位,然后小跑车将车存入车位,之后搬运器退回至56车位外面即可)
  5785. Error_manager Dispatch_process::excute_carrier_store_car_to_parkingspace_ex(Dispatch_control_node & dispatch_control_node)
  5786. {
  5787. Error_manager t_error;
  5788. Carrier * tp_carrier = NULL;
  5789. Carrier_task * tp_carrier_task = NULL;
  5790. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  5791. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  5792. {
  5793. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  5794. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  5795. }
  5796. else
  5797. {
  5798. tp_carrier = (Carrier *)dispatch_control_node.mp_dispatch_device.get();
  5799. tp_carrier_task = (Carrier_task *)dispatch_control_node.mp_dispatch_task.get();
  5800. }
  5801. // std::cout << " huli test :::: " << " tp_carrier_task->m_step = " << tp_carrier_task->m_step << std::endl;
  5802. // getchar();
  5803. if ( tp_carrier_task->m_step == 0 )
  5804. {
  5805. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5806. }
  5807. if ( tp_carrier_task->m_step == 1 )//检查姿态
  5808. {
  5809. //检查姿态(注注注注注意了, 调试阶段是无车, 真实环境是有车的)
  5810. if ( tp_carrier->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR &&
  5811. tp_carrier->m_actual_clamp_motion1 == Dispatch_device_base::Clamp_motion::E_CLAMP_LOOSE)
  5812. {
  5813. //检测正常, 直接跳过即可
  5814. tp_carrier_task->m_step +=2;
  5815. }
  5816. //注意了, 如果是去7号出口, 那么就直接跳过轮距修正和夹车.
  5817. else if(dispatch_control_node.m_dispatch_control_request_msg.dispatch_destination() == 1107)
  5818. {
  5819. tp_carrier_task->m_step = 7;
  5820. }
  5821. else
  5822. {
  5823. return Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  5824. "Dispatch_process::excute_carrier_store_car_to_parkingspace() fun error ");
  5825. }
  5826. }
  5827. if ( tp_carrier_task->m_step == 2 )
  5828. {
  5829. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5830. }
  5831. if ( tp_carrier_task->m_step == 3 )//修正轴距
  5832. {
  5833. float temp_wheel_base = tp_carrier->m_actual_y1 - tp_carrier->m_actual_y2;
  5834. if ( Common_data::approximate_difference(m_wheel_base, temp_wheel_base, DISPATCH_DEFAULT_DIFFERENCE) )
  5835. {
  5836. tp_carrier_task->m_step +=2;
  5837. }
  5838. else
  5839. {
  5840. carrier_adjust_wheel_base(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates);
  5841. tp_carrier_task->m_step++;
  5842. }
  5843. }
  5844. if ( tp_carrier_task->m_step == 4 )
  5845. {
  5846. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5847. }
  5848. if ( tp_carrier_task->m_step == 5 )//让小跑车 夹车
  5849. {
  5850. carrier_move_c(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_TIGHT);
  5851. tp_carrier_task->m_step++;
  5852. }
  5853. if ( tp_carrier_task->m_step == 6 )
  5854. {
  5855. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5856. }
  5857. if ( tp_carrier_task->m_step == 7 )//让中跑车回到电梯井
  5858. {
  5859. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5860. {
  5861. tp_carrier_task->m_step +=2;
  5862. }
  5863. else
  5864. {
  5865. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  5866. {
  5867. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  5868. tp_carrier_task->m_step++;
  5869. }
  5870. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  5871. {
  5872. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  5873. tp_carrier_task->m_step++;
  5874. }
  5875. else
  5876. {
  5877. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  5878. " dispatch_control_node.m_destination_coordinates.z PARAMRTER ERROR ");
  5879. }
  5880. }
  5881. }
  5882. if ( tp_carrier_task->m_step == 8 )
  5883. {
  5884. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5885. }
  5886. if ( tp_carrier_task->m_step == 9 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  5887. {
  5888. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5889. {
  5890. tp_carrier_task->m_step +=2;
  5891. }
  5892. else
  5893. {
  5894. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  5895. tp_carrier_task->m_step++;
  5896. }
  5897. }
  5898. if ( tp_carrier_task->m_step == 10 )
  5899. {
  5900. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5901. }
  5902. if ( tp_carrier_task->m_step == 11 )//电梯移动到对应的楼层
  5903. {
  5904. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  5905. {
  5906. tp_carrier_task->m_step +=2;
  5907. }
  5908. else
  5909. {
  5910. carrier_move_z(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  5911. tp_carrier_task->m_step++;
  5912. }
  5913. }
  5914. if ( tp_carrier_task->m_step == 12 )
  5915. {
  5916. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5917. }
  5918. if ( tp_carrier_task->m_step == 13 )//伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  5919. {
  5920. if ( tp_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK && tp_carrier->get_device_id() !=2)
  5921. {
  5922. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  5923. tp_carrier_task->m_step++;
  5924. }
  5925. else
  5926. {
  5927. tp_carrier_task->m_step +=2;
  5928. }
  5929. }
  5930. if ( tp_carrier_task->m_step == 14 )
  5931. {
  5932. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5933. }
  5934. if ( tp_carrier_task->m_step == 15 )//中跑车 x轴移动
  5935. {
  5936. if ( Common_data::approximate_difference(tp_carrier->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) )
  5937. {
  5938. tp_carrier_task->m_step +=2;
  5939. }
  5940. else
  5941. {
  5942. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.x);
  5943. tp_carrier_task->m_step++;
  5944. }
  5945. }
  5946. if ( tp_carrier_task->m_step == 16 )
  5947. {
  5948. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5949. }
  5950. if ( tp_carrier_task->m_step == 17 )//小跑车 进入车位
  5951. {
  5952. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_leave);
  5953. tp_carrier_task->m_step++;
  5954. }
  5955. if ( tp_carrier_task->m_step == 18 )
  5956. {
  5957. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5958. }
  5959. if ( tp_carrier_task->m_step == 19 )//小跑车 松开夹杆
  5960. {
  5961. carrier_move_c(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_LOOSE);
  5962. tp_carrier_task->m_step++;
  5963. }
  5964. if ( tp_carrier_task->m_step == 20 )
  5965. {
  5966. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5967. }
  5968. if ( tp_carrier_task->m_step == 21 )//小跑车 回到中跑车
  5969. {
  5970. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  5971. tp_carrier_task->m_step++;
  5972. }
  5973. if ( tp_carrier_task->m_step == 22 )
  5974. {
  5975. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  5976. }
  5977. if ( tp_carrier_task->m_step == 23 )
  5978. {
  5979. return Error_code::SUCCESS;
  5980. }
  5981. return Error_code::SUCCESS;
  5982. }
  5983. //搬运器从停车位上取车(例如:搬运器移动到56号停车位,然后小跑车将车从车位取出,之后搬运器退回至电梯井)
  5984. Error_manager Dispatch_process::excute_carrier_pickup_car_from_parkingspace(Dispatch_control_node & dispatch_control_node)
  5985. {
  5986. Error_manager t_error;
  5987. Carrier * tp_carrier = NULL;
  5988. Carrier_task * tp_carrier_task = NULL;
  5989. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  5990. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  5991. {
  5992. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  5993. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  5994. }
  5995. else
  5996. {
  5997. tp_carrier = (Carrier *)dispatch_control_node.mp_dispatch_device.get();
  5998. tp_carrier_task = (Carrier_task *)dispatch_control_node.mp_dispatch_task.get();
  5999. }
  6000. // std::cout << " huli test :::: " << " tp_carrier_task->m_step = " << tp_carrier_task->m_step << std::endl;
  6001. // getchar();
  6002. if ( tp_carrier_task->m_step == 0 )
  6003. {
  6004. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6005. }
  6006. if ( tp_carrier_task->m_step == 1 )//检查姿态
  6007. {
  6008. //检查姿态
  6009. if ( tp_carrier->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  6010. {
  6011. if ( tp_carrier_task->m_request_clamp_motion == Carrier_task::Clamp_motion::E_CLAMP_LOOSE &&
  6012. Common_data::approximate_difference(m_wheel_base, tp_carrier->m_actual_y1-tp_carrier->m_actual_y2, DISPATCH_DEFAULT_DIFFERENCE))
  6013. {
  6014. tp_carrier_task->m_step +=2;
  6015. }
  6016. else
  6017. {
  6018. carrier_adjust_to_ready(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates);
  6019. tp_carrier_task->m_step++;
  6020. }
  6021. }
  6022. else
  6023. {
  6024. return Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  6025. "tp_carrier->m_actual_load_status != Dispatch_device_base::Load_status::NO_CAR fun error ");
  6026. }
  6027. }
  6028. if ( tp_carrier_task->m_step == 2 )
  6029. {
  6030. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6031. }
  6032. if ( tp_carrier_task->m_step == 3 )//让小跑车回到中跑车上
  6033. {
  6034. if ( Common_data::approximate_difference(tp_carrier->m_actual_y, tp_dispatch_coordinates->m_carrier_default_y_back, DISPATCH_DEFAULT_DIFFERENCE) )
  6035. {
  6036. tp_carrier_task->m_step +=2;
  6037. }
  6038. else
  6039. {
  6040. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  6041. tp_carrier_task->m_step++;
  6042. }
  6043. }
  6044. if ( tp_carrier_task->m_step == 4 )
  6045. {
  6046. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6047. }
  6048. if ( tp_carrier_task->m_step == 5 )//让中跑车回到电梯井
  6049. {
  6050. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6051. {
  6052. tp_carrier_task->m_step +=2;
  6053. }
  6054. else
  6055. {
  6056. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  6057. {
  6058. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  6059. tp_carrier_task->m_step++;
  6060. }
  6061. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  6062. {
  6063. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  6064. tp_carrier_task->m_step++;
  6065. }
  6066. else
  6067. {
  6068. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  6069. " dispatch_control_node.m_destination_coordinates.z PARAMRTER ERROR ");
  6070. }
  6071. }
  6072. }
  6073. if ( tp_carrier_task->m_step == 6 )
  6074. {
  6075. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6076. }
  6077. if ( tp_carrier_task->m_step == 7 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  6078. {
  6079. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6080. {
  6081. tp_carrier_task->m_step +=2;
  6082. }
  6083. else
  6084. {
  6085. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  6086. tp_carrier_task->m_step++;
  6087. }
  6088. }
  6089. if ( tp_carrier_task->m_step == 8 )
  6090. {
  6091. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6092. }
  6093. if ( tp_carrier_task->m_step == 9 )//电梯移动到对应的楼层
  6094. {
  6095. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6096. {
  6097. tp_carrier_task->m_step +=2;
  6098. }
  6099. else
  6100. {
  6101. carrier_move_z(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  6102. tp_carrier_task->m_step++;
  6103. }
  6104. }
  6105. if ( tp_carrier_task->m_step == 10 )
  6106. {
  6107. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6108. }
  6109. if ( tp_carrier_task->m_step == 11 )//伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  6110. {
  6111. if ( tp_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK && tp_carrier->get_device_id() != 2)
  6112. {
  6113. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  6114. tp_carrier_task->m_step++;
  6115. }
  6116. else
  6117. {
  6118. tp_carrier_task->m_step +=2;
  6119. }
  6120. }
  6121. if ( tp_carrier_task->m_step == 12 )
  6122. {
  6123. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6124. }
  6125. if ( tp_carrier_task->m_step == 13 )//中跑车 x轴移动
  6126. {
  6127. if ( Common_data::approximate_difference(tp_carrier->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) )
  6128. {
  6129. tp_carrier_task->m_step +=2;
  6130. }
  6131. else
  6132. {
  6133. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.x);
  6134. tp_carrier_task->m_step++;
  6135. }
  6136. }
  6137. if ( tp_carrier_task->m_step == 14 )
  6138. {
  6139. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6140. }
  6141. if ( tp_carrier_task->m_step == 15 )//小跑车 进入车位
  6142. {
  6143. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_leave);
  6144. tp_carrier_task->m_step++;
  6145. }
  6146. if ( tp_carrier_task->m_step == 16 )
  6147. {
  6148. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6149. }
  6150. if ( tp_carrier_task->m_step == 17 )//小跑车 夹车
  6151. {
  6152. carrier_move_c(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_TIGHT);
  6153. tp_carrier_task->m_step++;
  6154. }
  6155. if ( tp_carrier_task->m_step == 18 )
  6156. {
  6157. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6158. }
  6159. if ( tp_carrier_task->m_step == 19 )//小跑车 回到中跑车
  6160. {
  6161. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  6162. tp_carrier_task->m_step++;
  6163. }
  6164. if ( tp_carrier_task->m_step == 20 )
  6165. {
  6166. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6167. }
  6168. if ( tp_carrier_task->m_step == 21 )//让中跑车回到电梯井
  6169. {
  6170. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  6171. {
  6172. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  6173. tp_carrier_task->m_step++;
  6174. }
  6175. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  6176. {
  6177. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  6178. tp_carrier_task->m_step++;
  6179. }
  6180. else
  6181. {
  6182. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  6183. " dispatch_control_node.m_destination_coordinates.z PARAMRTER ERROR ");
  6184. }
  6185. }
  6186. if ( tp_carrier_task->m_step == 22 )
  6187. {
  6188. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6189. }
  6190. if ( tp_carrier_task->m_step == 23 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  6191. {
  6192. if ( tp_carrier->get_device_id() != 2 )
  6193. {
  6194. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  6195. tp_carrier_task->m_step++;
  6196. }
  6197. else
  6198. {
  6199. tp_carrier_task->m_step +=2;
  6200. }
  6201. }
  6202. if ( tp_carrier_task->m_step == 24 )
  6203. {
  6204. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6205. }
  6206. if ( tp_carrier_task->m_step == 25 )
  6207. {
  6208. return Error_code::SUCCESS;
  6209. }
  6210. return Error_code::SUCCESS;
  6211. }
  6212. //搬运器从停车位上取车(例如:搬运器移动到56号停车位,然后小跑车将车从车位取出,之后搬运器退回至56车位外面即可)
  6213. Error_manager Dispatch_process::excute_carrier_pickup_car_from_parkingspace_ex(Dispatch_control_node & dispatch_control_node)
  6214. {
  6215. Error_manager t_error;
  6216. Carrier * tp_carrier = NULL;
  6217. Carrier_task * tp_carrier_task = NULL;
  6218. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  6219. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  6220. {
  6221. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  6222. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  6223. }
  6224. else
  6225. {
  6226. tp_carrier = (Carrier *)dispatch_control_node.mp_dispatch_device.get();
  6227. tp_carrier_task = (Carrier_task *)dispatch_control_node.mp_dispatch_task.get();
  6228. }
  6229. // std::cout << " huli test :::: " << " tp_carrier_task->m_step = " << tp_carrier_task->m_step << std::endl;
  6230. // getchar();
  6231. if ( tp_carrier_task->m_step == 0 )
  6232. {
  6233. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6234. }
  6235. if ( tp_carrier_task->m_step == 1 )//检查姿态
  6236. {
  6237. //检查姿态
  6238. if ( tp_carrier->m_actual_load_status == Dispatch_device_base::Load_status::NO_CAR )
  6239. {
  6240. if ( tp_carrier_task->m_request_clamp_motion == Carrier_task::Clamp_motion::E_CLAMP_LOOSE &&
  6241. Common_data::approximate_difference(m_wheel_base, tp_carrier->m_actual_y1-tp_carrier->m_actual_y2, DISPATCH_DEFAULT_DIFFERENCE))
  6242. {
  6243. tp_carrier_task->m_step +=2;
  6244. }
  6245. else
  6246. {
  6247. carrier_adjust_to_ready(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates);
  6248. tp_carrier_task->m_step++;
  6249. }
  6250. }
  6251. else
  6252. {
  6253. return Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  6254. "tp_carrier->m_actual_load_status != Dispatch_device_base::Load_status::NO_CAR fun error ");
  6255. }
  6256. }
  6257. if ( tp_carrier_task->m_step == 2 )
  6258. {
  6259. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6260. }
  6261. if ( tp_carrier_task->m_step == 3 )//让小跑车回到中跑车上
  6262. {
  6263. if ( Common_data::approximate_difference(tp_carrier->m_actual_y, tp_dispatch_coordinates->m_carrier_default_y_back, DISPATCH_DEFAULT_DIFFERENCE) )
  6264. {
  6265. tp_carrier_task->m_step +=2;
  6266. }
  6267. else
  6268. {
  6269. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  6270. tp_carrier_task->m_step++;
  6271. }
  6272. }
  6273. if ( tp_carrier_task->m_step == 4 )
  6274. {
  6275. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6276. }
  6277. if ( tp_carrier_task->m_step == 5 )//让中跑车回到电梯井
  6278. {
  6279. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6280. {
  6281. tp_carrier_task->m_step +=2;
  6282. }
  6283. else
  6284. {
  6285. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  6286. {
  6287. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  6288. tp_carrier_task->m_step++;
  6289. }
  6290. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  6291. {
  6292. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  6293. tp_carrier_task->m_step++;
  6294. }
  6295. else
  6296. {
  6297. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  6298. " dispatch_control_node.m_destination_coordinates.z PARAMRTER ERROR ");
  6299. }
  6300. }
  6301. }
  6302. if ( tp_carrier_task->m_step == 6 )
  6303. {
  6304. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6305. }
  6306. if ( tp_carrier_task->m_step == 7 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  6307. {
  6308. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6309. {
  6310. tp_carrier_task->m_step +=2;
  6311. }
  6312. else
  6313. {
  6314. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  6315. tp_carrier_task->m_step++;
  6316. }
  6317. }
  6318. if ( tp_carrier_task->m_step == 8 )
  6319. {
  6320. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6321. }
  6322. if ( tp_carrier_task->m_step == 9 )//电梯移动到对应的楼层
  6323. {
  6324. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6325. {
  6326. tp_carrier_task->m_step +=2;
  6327. }
  6328. else
  6329. {
  6330. carrier_move_z(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  6331. tp_carrier_task->m_step++;
  6332. }
  6333. }
  6334. if ( tp_carrier_task->m_step == 10 )
  6335. {
  6336. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6337. }
  6338. if ( tp_carrier_task->m_step == 11 )//伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  6339. {
  6340. if ( tp_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK && tp_carrier->get_device_id() != 2)
  6341. {
  6342. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  6343. tp_carrier_task->m_step++;
  6344. }
  6345. else
  6346. {
  6347. tp_carrier_task->m_step +=2;
  6348. }
  6349. }
  6350. if ( tp_carrier_task->m_step == 12 )
  6351. {
  6352. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6353. }
  6354. if ( tp_carrier_task->m_step == 13 )//中跑车 x轴移动
  6355. {
  6356. if ( Common_data::approximate_difference(tp_carrier->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) )
  6357. {
  6358. tp_carrier_task->m_step +=2;
  6359. }
  6360. else
  6361. {
  6362. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.x);
  6363. tp_carrier_task->m_step++;
  6364. }
  6365. }
  6366. if ( tp_carrier_task->m_step == 14 )
  6367. {
  6368. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6369. }
  6370. if ( tp_carrier_task->m_step == 15 )//小跑车 进入车位
  6371. {
  6372. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_leave);
  6373. tp_carrier_task->m_step++;
  6374. }
  6375. if ( tp_carrier_task->m_step == 16 )
  6376. {
  6377. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6378. }
  6379. if ( tp_carrier_task->m_step == 17 )//小跑车 夹车
  6380. {
  6381. carrier_move_c(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_TIGHT);
  6382. tp_carrier_task->m_step++;
  6383. }
  6384. if ( tp_carrier_task->m_step == 18 )
  6385. {
  6386. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6387. }
  6388. if ( tp_carrier_task->m_step == 19 )//小跑车 回到中跑车
  6389. {
  6390. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  6391. tp_carrier_task->m_step++;
  6392. }
  6393. if ( tp_carrier_task->m_step == 20 )
  6394. {
  6395. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6396. }
  6397. if ( tp_carrier_task->m_step == 21 )
  6398. {
  6399. return Error_code::SUCCESS;
  6400. }
  6401. return Error_code::SUCCESS;
  6402. }
  6403. //搬运器把车交付给机器手(例如:搬运器移动到3号入口的上方,小跑车松夹杆,然后等待机器手把车从中跑车上取走)
  6404. Error_manager Dispatch_process::excute_carrier_deliver_car_to_robot(Dispatch_control_node & dispatch_control_node)
  6405. {
  6406. Error_manager t_error;
  6407. Carrier * tp_carrier = NULL;
  6408. Carrier_task * tp_carrier_task = NULL;
  6409. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  6410. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  6411. {
  6412. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  6413. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  6414. }
  6415. else
  6416. {
  6417. tp_carrier = (Carrier *)dispatch_control_node.mp_dispatch_device.get();
  6418. tp_carrier_task = (Carrier_task *)dispatch_control_node.mp_dispatch_task.get();
  6419. }
  6420. // std::cout << " huli test :::: " << " tp_carrier_task->m_step = " << tp_carrier_task->m_step << std::endl;
  6421. // getchar();
  6422. if ( tp_carrier_task->m_step == 0 )
  6423. {
  6424. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6425. }
  6426. if ( tp_carrier_task->m_step == 1 )//检查姿态
  6427. {
  6428. //检查姿态
  6429. if ( tp_carrier->m_actual_load_status == Dispatch_device_base::Load_status::HAVE_CAR &&
  6430. tp_carrier->m_actual_clamp_motion1 == Dispatch_device_base::Clamp_motion::E_CLAMP_TIGHT)
  6431. {
  6432. //检测正常, 直接跳过
  6433. tp_carrier_task->m_step +=2;
  6434. }
  6435. else
  6436. {
  6437. return Error_manager(Error_code::CARRIER_POSE_ERROR, Error_level::MINOR_ERROR,
  6438. "tp_carrier->m_actual_load_status != Dispatch_device_base::Load_status::NO_CAR fun error ");
  6439. }
  6440. }
  6441. if ( tp_carrier_task->m_step == 2 )
  6442. {
  6443. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6444. }
  6445. if ( tp_carrier_task->m_step == 3 )//让小跑车回到中跑车上
  6446. {
  6447. if ( Common_data::approximate_difference(tp_carrier->m_actual_y, tp_dispatch_coordinates->m_carrier_default_y_back, DISPATCH_DEFAULT_DIFFERENCE) )
  6448. {
  6449. tp_carrier_task->m_step +=2;
  6450. }
  6451. else
  6452. {
  6453. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  6454. tp_carrier_task->m_step++;
  6455. }
  6456. }
  6457. if ( tp_carrier_task->m_step == 4 )
  6458. {
  6459. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6460. }
  6461. if ( tp_carrier_task->m_step == 5 )//让中跑车回到电梯井
  6462. {
  6463. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6464. {
  6465. tp_carrier_task->m_step +=2;
  6466. }
  6467. else
  6468. {
  6469. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  6470. {
  6471. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  6472. tp_carrier_task->m_step++;
  6473. }
  6474. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  6475. {
  6476. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  6477. tp_carrier_task->m_step++;
  6478. }
  6479. else
  6480. {
  6481. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  6482. " dispatch_control_node.m_destination_coordinates.z PARAMRTER ERROR ");
  6483. }
  6484. }
  6485. }
  6486. if ( tp_carrier_task->m_step == 6 )
  6487. {
  6488. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6489. }
  6490. if ( tp_carrier_task->m_step == 7 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  6491. {
  6492. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6493. {
  6494. tp_carrier_task->m_step +=2;
  6495. }
  6496. else
  6497. {
  6498. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  6499. tp_carrier_task->m_step++;
  6500. }
  6501. }
  6502. if ( tp_carrier_task->m_step == 8 )
  6503. {
  6504. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6505. }
  6506. if ( tp_carrier_task->m_step == 9 )//电梯移动到对应的楼层
  6507. {
  6508. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6509. {
  6510. tp_carrier_task->m_step +=2;
  6511. }
  6512. else
  6513. {
  6514. carrier_move_z(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  6515. tp_carrier_task->m_step++;
  6516. }
  6517. }
  6518. if ( tp_carrier_task->m_step == 10 )
  6519. {
  6520. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6521. }
  6522. if ( tp_carrier_task->m_step == 11 )//伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  6523. {
  6524. if ( tp_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK && tp_carrier->get_device_id() !=2)
  6525. {
  6526. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  6527. tp_carrier_task->m_step++;
  6528. }
  6529. else
  6530. {
  6531. tp_carrier_task->m_step +=2;
  6532. }
  6533. }
  6534. if ( tp_carrier_task->m_step == 12 )
  6535. {
  6536. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6537. }
  6538. if ( tp_carrier_task->m_step == 13 )//中跑车 x轴移动
  6539. {
  6540. if ( Common_data::approximate_difference(tp_carrier->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) )
  6541. {
  6542. tp_carrier_task->m_step +=2;
  6543. }
  6544. else
  6545. {
  6546. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.x);
  6547. tp_carrier_task->m_step++;
  6548. }
  6549. }
  6550. if ( tp_carrier_task->m_step == 14 )
  6551. {
  6552. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6553. }
  6554. if ( tp_carrier_task->m_step == 15 )//小跑车 松开夹杆
  6555. {
  6556. carrier_move_c(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Clamp_motion::E_CLAMP_LOOSE);
  6557. tp_carrier_task->m_step++;
  6558. }
  6559. if ( tp_carrier_task->m_step == 16 )
  6560. {
  6561. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6562. }
  6563. if ( tp_carrier_task->m_step == 17 )
  6564. {
  6565. return Error_code::SUCCESS;
  6566. }
  6567. return Error_code::SUCCESS;
  6568. }
  6569. //搬运器的自由移动(可以提前到2楼来准备接车,或者为了避让就退回至电梯井)(小跑车不进行取车和存车)
  6570. Error_manager Dispatch_process::excute_carrier_move(Dispatch_control_node & dispatch_control_node)
  6571. {
  6572. Error_manager t_error;
  6573. Carrier * tp_carrier = NULL;
  6574. Carrier_task * tp_carrier_task = NULL;
  6575. Dispatch_coordinates * tp_dispatch_coordinates = Dispatch_coordinates::get_instance_pointer();
  6576. if ( dispatch_control_node.mp_dispatch_device.get() == NULL || dispatch_control_node.mp_dispatch_task.get() == NULL )
  6577. {
  6578. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  6579. "Dispatch_process::excute_robot_catch_car_from_inlet() POINTER IS NULL ");
  6580. }
  6581. else
  6582. {
  6583. tp_carrier = (Carrier *)dispatch_control_node.mp_dispatch_device.get();
  6584. tp_carrier_task = (Carrier_task *)dispatch_control_node.mp_dispatch_task.get();
  6585. }
  6586. // std::cout << " huli test :::: " << " tp_carrier_task->m_step = " << tp_carrier_task->m_step << std::endl;
  6587. // getchar();
  6588. if ( tp_carrier_task->m_step == 0 )
  6589. {
  6590. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6591. }
  6592. if ( tp_carrier_task->m_step == 1 )//让小跑车回到中跑车上
  6593. {
  6594. if ( Common_data::approximate_difference(tp_carrier->m_actual_y, tp_dispatch_coordinates->m_carrier_default_y_back, DISPATCH_DEFAULT_DIFFERENCE) )
  6595. {
  6596. tp_carrier_task->m_step +=2;
  6597. }
  6598. else
  6599. {
  6600. carrier_move_y(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_y_back);
  6601. tp_carrier_task->m_step++;
  6602. }
  6603. }
  6604. if ( tp_carrier_task->m_step == 2 )
  6605. {
  6606. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6607. }
  6608. if ( tp_carrier_task->m_step == 3 )//让中跑车回到电梯井
  6609. {
  6610. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6611. {
  6612. tp_carrier_task->m_step +=2;
  6613. }
  6614. else
  6615. {
  6616. if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 0 )
  6617. {
  6618. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_left);
  6619. tp_carrier_task->m_step++;
  6620. }
  6621. else if ( dispatch_control_node.mp_dispatch_device->get_device_id() == 1 )
  6622. {
  6623. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, tp_dispatch_coordinates->m_carrier_default_x_right);
  6624. tp_carrier_task->m_step++;
  6625. }
  6626. else
  6627. {
  6628. return Error_manager(Error_code::CARRIER_CONRTOL_PARAMETER_ERROR, Error_level::MINOR_ERROR,
  6629. " dispatch_control_node.m_destination_coordinates.z PARAMRTER ERROR ");
  6630. }
  6631. }
  6632. }
  6633. if ( tp_carrier_task->m_step == 4 )
  6634. {
  6635. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6636. }
  6637. if ( tp_carrier_task->m_step == 5 )//收回对接,之后中跑车固定在电梯上不能X轴移动,电梯可以Z轴移动
  6638. {
  6639. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6640. {
  6641. tp_carrier_task->m_step +=2;
  6642. }
  6643. else
  6644. {
  6645. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_TAKE_BACK);
  6646. tp_carrier_task->m_step++;
  6647. }
  6648. }
  6649. if ( tp_carrier_task->m_step == 6 )
  6650. {
  6651. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6652. }
  6653. if ( tp_carrier_task->m_step == 7 )//电梯移动到对应的楼层
  6654. {
  6655. if ( Common_data::approximate_difference(tp_carrier->m_actual_z, dispatch_control_node.m_destination_coordinates.z, DISPATCH_DEFAULT_DIFFERENCE) )
  6656. {
  6657. tp_carrier_task->m_step +=2;
  6658. }
  6659. else
  6660. {
  6661. carrier_move_z(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.z);
  6662. tp_carrier_task->m_step++;
  6663. }
  6664. }
  6665. if ( tp_carrier_task->m_step == 8 )
  6666. {
  6667. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6668. }
  6669. if ( tp_carrier_task->m_step == 9 )//伸出对接,之后中跑车可以x轴移动,电梯不能Z轴移动
  6670. {
  6671. if ( tp_carrier->m_actual_joint_motion_x1 == Dispatch_device_base::Joint_motion::E_JOINT_TAKE_BACK && tp_carrier->get_device_id() !=2)
  6672. {
  6673. carrier_joint_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, Carrier_task::Joint_motion::E_JOINT_HOLD_OUT);
  6674. tp_carrier_task->m_step++;
  6675. }
  6676. else
  6677. {
  6678. tp_carrier_task->m_step +=2;
  6679. }
  6680. }
  6681. if ( tp_carrier_task->m_step == 10 )
  6682. {
  6683. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6684. }
  6685. if ( tp_carrier_task->m_step == 11 )//中跑车 x轴移动
  6686. {
  6687. if ( Common_data::approximate_difference(tp_carrier->m_actual_x, dispatch_control_node.m_destination_coordinates.x, DISPATCH_DEFAULT_DIFFERENCE) )
  6688. {
  6689. tp_carrier_task->m_step +=2;
  6690. }
  6691. else
  6692. {
  6693. carrier_move_x(dispatch_control_node, tp_carrier, tp_carrier_task, tp_dispatch_coordinates, dispatch_control_node.m_destination_coordinates.x);
  6694. tp_carrier_task->m_step++;
  6695. }
  6696. }
  6697. if ( tp_carrier_task->m_step == 12 )
  6698. {
  6699. return check_task_ex(dispatch_control_node.mp_dispatch_task, tp_carrier_task->m_step);
  6700. }
  6701. if ( tp_carrier_task->m_step == 13 )
  6702. {
  6703. return Error_code::SUCCESS;
  6704. }
  6705. return Error_code::SUCCESS;
  6706. }
  6707. //执行通道口动作
  6708. Error_manager Dispatch_process::excute_passageway_motion(Dispatch_control_node & dispatch_control_node)
  6709. {
  6710. return Error_code::SUCCESS;
  6711. }
  6712. //检查 任务单 是否完成任务, 里面不会调整短步骤
  6713. Error_manager Dispatch_process::check_task_status(std::shared_ptr<Task_Base> p_task)
  6714. {
  6715. if ( p_task.get() == NULL )
  6716. {
  6717. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  6718. "Dispatch_process::check_passageway_task POINTER IS NULL ");
  6719. }
  6720. else
  6721. {
  6722. if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_OVER )
  6723. {
  6724. // dispatch_control_status = (Dispatch_control_status)(dispatch_control_status+1);
  6725. // return Error_code::NODATA; //这里返回nodata 表示任务继续下一步
  6726. //注意了, 这里返回成功, 用作动作完成判断
  6727. return Error_code::SUCCESS;
  6728. }
  6729. else if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_ERROR )
  6730. {
  6731. // dispatch_control_status = DISPATCH_CONTROL_FAULT;
  6732. return p_task->get_task_error_manager();
  6733. }
  6734. else if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_WORKING ||
  6735. p_task->get_task_statu() == Task_Base::Task_statu::TASK_SIGNED ||
  6736. p_task->get_task_statu() == Task_Base::Task_statu::TASK_CREATED ||
  6737. p_task->get_task_statu() == Task_Base::Task_statu::TASK_STOP)
  6738. {
  6739. //继续等待任务, 直到状态改变
  6740. return Error_code::NODATA;
  6741. }
  6742. else
  6743. {
  6744. LOG(INFO) << "Dispatch_process::check_task_ex failed p_catcher_task->get_task_statu() = "<< p_task->get_task_statu() << " " << this;
  6745. return Error_code::NODATA;
  6746. }
  6747. }
  6748. return Error_code::SUCCESS;
  6749. }//检查 任务单 是否完成任务, 里面会调整短步骤
  6750. Error_manager Dispatch_process::check_task_status(std::shared_ptr<Task_Base> p_task, Dispatch_control_status & dispatch_control_status)
  6751. {
  6752. if ( p_task.get() == NULL )
  6753. {
  6754. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  6755. "Dispatch_process::check_passageway_task POINTER IS NULL ");
  6756. }
  6757. else
  6758. {
  6759. if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_OVER )
  6760. {
  6761. dispatch_control_status = (Dispatch_control_status)(dispatch_control_status+1);
  6762. // return Error_code::NODATA; //这里返回nodata 表示任务继续下一步
  6763. //注意了, 这里返回成功, 用作动作完成判断
  6764. return Error_code::SUCCESS;
  6765. }
  6766. else if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_ERROR )
  6767. {
  6768. dispatch_control_status = DISPATCH_CONTROL_FAULT;
  6769. return p_task->get_task_error_manager();
  6770. }
  6771. else if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_WORKING ||
  6772. p_task->get_task_statu() == Task_Base::Task_statu::TASK_SIGNED ||
  6773. p_task->get_task_statu() == Task_Base::Task_statu::TASK_CREATED ||
  6774. p_task->get_task_statu() == Task_Base::Task_statu::TASK_STOP)
  6775. {
  6776. //继续等待任务, 直到状态改变
  6777. return Error_code::NODATA;
  6778. }
  6779. else
  6780. {
  6781. LOG(INFO) << "Dispatch_process::check_task_ex failed p_catcher_task->get_task_statu() = "<< p_task->get_task_statu() << " " << this;
  6782. return Error_code::NODATA;
  6783. }
  6784. }
  6785. return Error_code::SUCCESS;
  6786. }
  6787. //检查 任务单 是否完成任务, 里面会调整短步骤
  6788. Error_manager Dispatch_process::check_task_ex(std::shared_ptr<Task_Base> p_task, int& step)
  6789. {
  6790. if ( p_task.get() == NULL )
  6791. {
  6792. return Error_manager(Error_code::POINTER_IS_NULL, Error_level::MINOR_ERROR,
  6793. "Dispatch_process::check_passageway_task POINTER IS NULL ");
  6794. }
  6795. else
  6796. {
  6797. if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_OVER )
  6798. {
  6799. step++;
  6800. return Error_code::NODATA; //这里返回nodata 表示任务继续下一步
  6801. }
  6802. else if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_ERROR )
  6803. {
  6804. step = 0;
  6805. return p_task->get_task_error_manager();
  6806. }
  6807. else if ( p_task->get_task_statu() == Task_Base::Task_statu::TASK_WORKING ||
  6808. p_task->get_task_statu() == Task_Base::Task_statu::TASK_SIGNED ||
  6809. p_task->get_task_statu() == Task_Base::Task_statu::TASK_CREATED ||
  6810. p_task->get_task_statu() == Task_Base::Task_statu::TASK_STOP)
  6811. {
  6812. //继续等待任务, 直到状态改变
  6813. return Error_code::NODATA;
  6814. }
  6815. else
  6816. {
  6817. LOG(INFO) << "Dispatch_process::check_task_ex failed p_catcher_task->get_task_statu() = "<< p_task->get_task_statu() << " " << this;
  6818. return Error_code::NODATA;
  6819. }
  6820. }
  6821. return Error_code::SUCCESS;
  6822. }
  6823. //机器手调整到正常待机的姿态(调节夹杆和轴距)
  6824. Error_manager Dispatch_process::catcher_adjust_to_ready(Dispatch_control_node & dispatch_control_node, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  6825. {
  6826. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  6827. char t_key[50] = {0};
  6828. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_catcher_task->m_step);
  6829. tp_catcher_task->m_request_key = t_key;
  6830. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  6831. //调整姿态
  6832. tp_catcher_task->m_request_clamp_motion = Catcher_task::Clamp_motion::E_CLAMP_LOOSE;
  6833. tp_catcher_task->m_request_d1 = tp_dispatch_coordinates->m_catcher_d1_min;
  6834. tp_catcher_task->m_request_d2 = tp_dispatch_coordinates->m_catcher_d2_min;
  6835. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  6836. {
  6837. tp_catcher_task->m_request_b = 270;
  6838. }
  6839. else
  6840. {
  6841. tp_catcher_task->m_request_b = 90;
  6842. }
  6843. std::cout << " huli test :::: " << " catcher_adjust_to_ready = " << tp_catcher_task->m_request_key << std::endl;
  6844. std::cout << " huli test :::: " << " catcher_adjust_to_ready = " << tp_catcher_task->m_respons_key << std::endl;
  6845. std::cout << " huli test :::: " << " tp_catcher_task->m_request_clamp_motion = " << tp_catcher_task->m_request_clamp_motion << std::endl;
  6846. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d1 = " << tp_catcher_task->m_request_d1 << std::endl;
  6847. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d2 = " << tp_catcher_task->m_request_d2 << std::endl;
  6848. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  6849. std::cout << " huli test :::: " << " tp_catcher_task->m_request_b = " << tp_catcher_task->m_request_b << std::endl;
  6850. return Error_code::SUCCESS;
  6851. }
  6852. //机器手 移动z
  6853. Error_manager Dispatch_process::catcher_move_z(Dispatch_control_node & dispatch_control_node, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, float target)
  6854. {
  6855. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  6856. char t_key[50] = {0};
  6857. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_catcher_task->m_step);
  6858. tp_catcher_task->m_request_key = t_key;
  6859. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  6860. //机器手 移动z
  6861. tp_catcher_task->m_request_z = target;
  6862. std::cout << " huli test :::: " << " catcher_move_z = " << tp_catcher_task->m_request_key << std::endl;
  6863. std::cout << " huli test :::: " << " catcher_move_z = " << tp_catcher_task->m_respons_key << std::endl;
  6864. std::cout << " huli test :::: " << " tp_catcher_task->m_request_z = " << tp_catcher_task->m_request_z << std::endl;
  6865. return Error_code::SUCCESS;
  6866. }
  6867. //机器手调整到 准备从地面抓车前的姿态
  6868. Error_manager Dispatch_process::catcher_adjust_from_ground(Dispatch_control_node & dispatch_control_node, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  6869. {
  6870. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  6871. char t_key[50] = {0};
  6872. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_catcher_task->m_step);
  6873. tp_catcher_task->m_request_key = t_key;
  6874. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  6875. //机器手 调整x y b d1 d2, 根据感测模块的定位信息, 调整机器手的姿态, 准备抓车.
  6876. tp_catcher_task->m_request_x = m_car_measure_information.center_x;
  6877. tp_catcher_task->m_request_y = m_car_measure_information.center_y;
  6878. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  6879. {
  6880. //机器手如果旋转反向, 那就+180即可, 没有必要旋转归位.
  6881. tp_catcher_task->m_request_b = 180 + m_car_measure_information.car_angle;
  6882. }
  6883. else
  6884. {
  6885. tp_catcher_task->m_request_b = m_car_measure_information.car_angle;
  6886. }
  6887. //限制轮距, 在夹车杆松开时, 机器人下降时, 轴距不能超过3000mm, 必须下降到最下面才能调整轴距, 夹车后可以上升.
  6888. if ( m_wheel_base > tp_dispatch_coordinates->m_catcher_wheel_base_limit )
  6889. {
  6890. tp_catcher_task->m_request_d1 = (tp_dispatch_coordinates->m_catcher_wheel_base_limit - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  6891. tp_catcher_task->m_request_d2 = (tp_dispatch_coordinates->m_catcher_wheel_base_limit - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  6892. tp_catcher_task->m_request_wheelbase = tp_dispatch_coordinates->m_catcher_wheel_base_limit;
  6893. }
  6894. else
  6895. {
  6896. tp_catcher_task->m_request_d1 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  6897. tp_catcher_task->m_request_d2 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  6898. tp_catcher_task->m_request_wheelbase = m_wheel_base;
  6899. }
  6900. tp_catcher_task->m_request_clamp_motion = Catcher_task::Clamp_motion::E_CLAMP_LOOSE;
  6901. std::cout << " huli test :::: " << " catcher_adjust_from_ground = " << tp_catcher_task->m_request_key << std::endl;
  6902. std::cout << " huli test :::: " << " catcher_adjust_from_ground = " << tp_catcher_task->m_respons_key << std::endl;
  6903. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  6904. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  6905. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  6906. std::cout << " huli test :::: " << " tp_catcher_task->m_request_b = " << tp_catcher_task->m_request_b << std::endl;
  6907. std::cout << " huli test :::: " << " m_wheel_base = " << m_wheel_base << std::endl;
  6908. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d1 = " << tp_catcher_task->m_request_d1 << std::endl;
  6909. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d2 = " << tp_catcher_task->m_request_d2 << std::endl;
  6910. std::cout << " huli test :::: " << " tp_catcher_task->m_request_wheelbase = " << tp_catcher_task->m_request_wheelbase << std::endl;
  6911. std::cout << " huli test :::: " << " tp_catcher_task->m_request_clamp_motion = " << tp_catcher_task->m_request_clamp_motion << std::endl;
  6912. return Error_code::SUCCESS;
  6913. }
  6914. //机器手 修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  6915. Error_manager Dispatch_process::catcher_adjust_wheel_base(Dispatch_control_node & dispatch_control_node, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  6916. {
  6917. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  6918. char t_key[50] = {0};
  6919. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_catcher_task->m_step);
  6920. tp_catcher_task->m_request_key = t_key;
  6921. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  6922. //修正轴距
  6923. tp_catcher_task->m_request_d1 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  6924. tp_catcher_task->m_request_d2 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  6925. tp_catcher_task->m_request_wheelbase = m_wheel_base;
  6926. std::cout << " huli test :::: " << " catcher_adjust_wheel_base = " << tp_catcher_task->m_request_key << std::endl;
  6927. std::cout << " huli test :::: " << " catcher_adjust_wheel_base = " << tp_catcher_task->m_respons_key << std::endl;
  6928. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d1 = " << tp_catcher_task->m_request_d1 << std::endl;
  6929. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d2 = " << tp_catcher_task->m_request_d2 << std::endl;
  6930. std::cout << " huli test :::: " << " tp_catcher_task->m_request_wheelbase = " << tp_catcher_task->m_request_wheelbase << std::endl;
  6931. return Error_code::SUCCESS;
  6932. }
  6933. //机器手 移动c轴 夹杆
  6934. Error_manager Dispatch_process::catcher_move_c(Dispatch_control_node & dispatch_control_node, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, Catcher_task::Clamp_motion target)
  6935. {
  6936. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  6937. char t_key[50] = {0};
  6938. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_catcher_task->m_step);
  6939. tp_catcher_task->m_request_key = t_key;
  6940. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  6941. tp_catcher_task->m_request_clamp_motion = target;
  6942. std::cout << " huli test :::: " << " catcher_move_c = " << tp_catcher_task->m_request_key << std::endl;
  6943. std::cout << " huli test :::: " << " catcher_move_c = " << tp_catcher_task->m_respons_key << std::endl;
  6944. std::cout << " huli test :::: " << " tp_catcher_task->m_request_clamp_motion = " << tp_catcher_task->m_request_clamp_motion << std::endl;
  6945. return Error_code::SUCCESS;
  6946. }
  6947. //机器手调整到 准备把车放到搬运器的姿态
  6948. Error_manager Dispatch_process::catcher_adjust_to_carrier(Dispatch_control_node & dispatch_control_node, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, bool reverse_flag)
  6949. {
  6950. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  6951. char t_key[50] = {0};
  6952. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_catcher_task->m_step);
  6953. tp_catcher_task->m_request_key = t_key;
  6954. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  6955. //机器手 调整x y b d1 d2, 调整机器手的姿态, 准备把车放置到中跑车上.
  6956. tp_catcher_task->m_request_x = dispatch_control_node.m_destination_coordinates.x;
  6957. tp_catcher_task->m_request_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  6958. //存车需要反向, 取车不需要
  6959. if ( reverse_flag )
  6960. {
  6961. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  6962. {
  6963. tp_catcher_task->m_request_b = 90;
  6964. }
  6965. else
  6966. {
  6967. tp_catcher_task->m_request_b = 270;
  6968. }
  6969. }
  6970. else
  6971. {
  6972. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  6973. {
  6974. tp_catcher_task->m_request_b = 270;
  6975. }
  6976. else
  6977. {
  6978. tp_catcher_task->m_request_b = 90;
  6979. }
  6980. }
  6981. std::cout << " huli test :::: " << " catcher_adjust_to_carrier = " << tp_catcher_task->m_request_key << std::endl;
  6982. std::cout << " huli test :::: " << " catcher_adjust_to_carrier = " << tp_catcher_task->m_respons_key << std::endl;
  6983. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  6984. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  6985. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  6986. std::cout << " huli test :::: " << " tp_catcher->m_request_b = " << tp_catcher->m_request_b << std::endl;
  6987. return Error_code::SUCCESS;
  6988. }
  6989. //机器手调整到 准备把车放到地面的姿态
  6990. Error_manager Dispatch_process::catcher_adjust_to_ground(Dispatch_control_node & dispatch_control_node, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  6991. {
  6992. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  6993. char t_key[50] = {0};
  6994. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_catcher_task->m_step);
  6995. tp_catcher_task->m_request_key = t_key;
  6996. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  6997. //机器手 调整x y b d1 d2, 调整机器手的姿态, 准备把车放置到中跑车上.
  6998. tp_catcher_task->m_request_x = dispatch_control_node.m_destination_coordinates.x;
  6999. tp_catcher_task->m_request_y = dispatch_control_node.m_destination_coordinates.y;
  7000. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  7001. {
  7002. tp_catcher_task->m_request_b = 270;
  7003. }
  7004. else
  7005. {
  7006. tp_catcher_task->m_request_b = 90;
  7007. }
  7008. std::cout << " huli test :::: " << " catcher_adjust_to_ground = " << tp_catcher_task->m_request_key << std::endl;
  7009. std::cout << " huli test :::: " << " catcher_adjust_to_ground = " << tp_catcher_task->m_respons_key << std::endl;
  7010. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  7011. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  7012. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  7013. std::cout << " huli test :::: " << " tp_catcher->m_request_b = " << tp_catcher->m_request_b << std::endl;
  7014. return Error_code::SUCCESS;
  7015. }
  7016. //机器手调整到 对接搬运器的姿态
  7017. Error_manager Dispatch_process::catcher_adjust_from_carrier(Dispatch_control_node & dispatch_control_node, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7018. {
  7019. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7020. char t_key[50] = {0};
  7021. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_catcher_task->m_step);
  7022. tp_catcher_task->m_request_key = t_key;
  7023. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7024. //机器手 调整x y b d1 d2, 调整机器手的姿态, 准备把车放置到中跑车上.
  7025. tp_catcher_task->m_request_x = dispatch_control_node.m_destination_coordinates.x;
  7026. tp_catcher_task->m_request_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  7027. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  7028. {
  7029. tp_catcher_task->m_request_b = 270;
  7030. }
  7031. else
  7032. {
  7033. tp_catcher_task->m_request_b = 90;
  7034. }
  7035. //限制轮距, 在夹车杆松开时, 机器人下降时, 轴距不能超过3000mm, 必须下降到最下面才能调整轴距, 夹车后可以上升.
  7036. if ( m_wheel_base > tp_dispatch_coordinates->m_catcher_wheel_base_limit )
  7037. {
  7038. tp_catcher_task->m_request_d1 = (tp_dispatch_coordinates->m_catcher_wheel_base_limit - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7039. tp_catcher_task->m_request_d2 = (tp_dispatch_coordinates->m_catcher_wheel_base_limit - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7040. tp_catcher_task->m_request_wheelbase = tp_dispatch_coordinates->m_catcher_wheel_base_limit;
  7041. }
  7042. else
  7043. {
  7044. tp_catcher_task->m_request_d1 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7045. tp_catcher_task->m_request_d2 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7046. tp_catcher_task->m_request_wheelbase = m_wheel_base;
  7047. }
  7048. tp_catcher_task->m_request_clamp_motion = Catcher_task::Clamp_motion::E_CLAMP_LOOSE;
  7049. std::cout << " huli test :::: " << " catcher_adjust_from_carrier = " << tp_catcher_task->m_request_key << std::endl;
  7050. std::cout << " huli test :::: " << " catcher_adjust_from_carrier = " << tp_catcher_task->m_respons_key << std::endl;
  7051. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  7052. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  7053. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  7054. std::cout << " huli test :::: " << " tp_catcher_task->m_request_b = " << tp_catcher_task->m_request_b << std::endl;
  7055. std::cout << " huli test :::: " << " m_wheel_base = " << m_wheel_base << std::endl;
  7056. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d1 = " << tp_catcher_task->m_request_d1 << std::endl;
  7057. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d2 = " << tp_catcher_task->m_request_d2 << std::endl;
  7058. std::cout << " huli test :::: " << " tp_catcher_task->m_request_wheelbase = " << tp_catcher_task->m_request_wheelbase << std::endl;
  7059. std::cout << " huli test :::: " << " tp_catcher_task->m_request_clamp_motion = " << tp_catcher_task->m_request_clamp_motion << std::endl;
  7060. return Error_code::SUCCESS;
  7061. }
  7062. //搬运器调整到 正常待机的姿态(调节夹杆和轴距)
  7063. Error_manager Dispatch_process::carrier_adjust_to_ready(Dispatch_control_node & dispatch_control_node, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7064. {
  7065. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7066. char t_key[50] = {0};
  7067. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_carrier_task->m_step);
  7068. tp_carrier_task->m_request_key = t_key;
  7069. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7070. tp_carrier_task->m_request_clamp_motion = Carrier_task::Clamp_motion::E_CLAMP_LOOSE;
  7071. tp_carrier_task->m_request_wheelbase = m_wheel_base;
  7072. tp_carrier_task->m_request_y1 = tp_carrier->m_actual_y + tp_dispatch_coordinates->m_carrier_y_y1_distance;
  7073. tp_carrier_task->m_request_y2 = tp_carrier_task->m_request_y1 - tp_carrier_task->m_request_wheelbase;
  7074. std::cout << " huli test :::: " << " carrier_adjust_to_ready = " << tp_carrier_task->m_request_key << std::endl;
  7075. std::cout << " huli test :::: " << " carrier_adjust_to_ready = " << tp_carrier_task->m_respons_key << std::endl;
  7076. std::cout << " huli test :::: " << " tp_carrier_task->m_request_wheelbase = " << tp_carrier_task->m_request_wheelbase << std::endl;
  7077. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y1 = " << tp_carrier_task->m_request_y1 << std::endl;
  7078. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y2 = " << tp_carrier_task->m_request_y2 << std::endl;
  7079. std::cout << " huli test :::: " << " tp_carrier_task->m_request_clamp_motion = " << tp_carrier_task->m_request_clamp_motion << std::endl;
  7080. return Error_code::SUCCESS;
  7081. }
  7082. //搬运器 移动x
  7083. Error_manager Dispatch_process::carrier_move_x(Dispatch_control_node & dispatch_control_node, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, float target)
  7084. {
  7085. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7086. char t_key[50] = {0};
  7087. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_carrier_task->m_step);
  7088. tp_carrier_task->m_request_key = t_key;
  7089. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7090. tp_carrier_task->m_request_x = target;
  7091. std::cout << " huli test :::: " << " carrier_move_x = " << tp_carrier_task->m_request_key << std::endl;
  7092. std::cout << " huli test :::: " << " carrier_move_x = " << tp_carrier_task->m_respons_key << std::endl;
  7093. std::cout << " huli test :::: " << " tp_carrier_task->m_request_x = " << tp_carrier_task->m_request_x << std::endl;
  7094. return Error_code::SUCCESS;
  7095. }
  7096. //搬运器 移动y
  7097. Error_manager Dispatch_process::carrier_move_y(Dispatch_control_node & dispatch_control_node, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, float target)
  7098. {
  7099. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7100. char t_key[50] = {0};
  7101. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_carrier_task->m_step);
  7102. tp_carrier_task->m_request_key = t_key;
  7103. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7104. tp_carrier_task->m_request_y = target;
  7105. tp_carrier_task->m_request_wheelbase = m_wheel_base;
  7106. tp_carrier_task->m_request_y1 = tp_carrier_task->m_request_y + tp_dispatch_coordinates->m_carrier_y_y1_distance;
  7107. tp_carrier_task->m_request_y2 = tp_carrier_task->m_request_y1 - tp_carrier_task->m_request_wheelbase;
  7108. std::cout << " huli test :::: " << " carrier_move_y = " << tp_carrier_task->m_request_key << std::endl;
  7109. std::cout << " huli test :::: " << " carrier_move_y = " << tp_carrier_task->m_respons_key << std::endl;
  7110. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y = " << tp_carrier_task->m_request_y << std::endl;
  7111. std::cout << " huli test :::: " << " tp_carrier_task->m_request_wheelbase = " << tp_carrier_task->m_request_wheelbase << std::endl;
  7112. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y1 = " << tp_carrier_task->m_request_y1 << std::endl;
  7113. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y2 = " << tp_carrier_task->m_request_y2 << std::endl;
  7114. return Error_code::SUCCESS;
  7115. }
  7116. //搬运器 移动z
  7117. Error_manager Dispatch_process::carrier_move_z(Dispatch_control_node & dispatch_control_node, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, float target)
  7118. {
  7119. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7120. char t_key[50] = {0};
  7121. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_carrier_task->m_step);
  7122. tp_carrier_task->m_request_key = t_key;
  7123. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7124. tp_carrier_task->m_request_z = target;
  7125. std::cout << " huli test :::: " << " carrier_move_z = " << tp_carrier_task->m_request_key << std::endl;
  7126. std::cout << " huli test :::: " << " carrier_move_z = " << tp_carrier_task->m_respons_key << std::endl;
  7127. std::cout << " huli test :::: " << " tp_carrier_task->m_request_z = " << tp_carrier_task->m_request_z << std::endl;
  7128. return Error_code::SUCCESS;
  7129. }
  7130. //搬运器 移动c轴 夹车杆
  7131. Error_manager Dispatch_process::carrier_move_c(Dispatch_control_node & dispatch_control_node, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, Carrier_task::Clamp_motion target)
  7132. {
  7133. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7134. char t_key[50] = {0};
  7135. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_carrier_task->m_step);
  7136. tp_carrier_task->m_request_key = t_key;
  7137. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7138. tp_carrier_task->m_request_clamp_motion = target;
  7139. std::cout << " huli test :::: " << " carrier_move_c = " << tp_carrier_task->m_request_key << std::endl;
  7140. std::cout << " huli test :::: " << " carrier_move_c = " << tp_carrier_task->m_respons_key << std::endl;
  7141. std::cout << " huli test :::: " << " tp_carrier_task->m_request_clamp_motion = " << tp_carrier_task->m_request_clamp_motion << std::endl;
  7142. return Error_code::SUCCESS;
  7143. }
  7144. //搬运器调整 水平的交接
  7145. Error_manager Dispatch_process::carrier_joint_x(Dispatch_control_node & dispatch_control_node, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, Carrier_task::Joint_motion target)
  7146. {
  7147. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7148. char t_key[50] = {0};
  7149. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_carrier_task->m_step);
  7150. tp_carrier_task->m_request_key = t_key;
  7151. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7152. tp_carrier_task->m_request_joint_motion_x = target;
  7153. std::cout << " huli test :::: " << " carrier_joint_x = " << tp_carrier_task->m_request_key << std::endl;
  7154. std::cout << " huli test :::: " << " carrier_joint_x = " << tp_carrier_task->m_respons_key << std::endl;
  7155. std::cout << " huli test :::: " << " tp_carrier_task->m_request_joint_motion_x = " << tp_carrier_task->m_request_joint_motion_x << std::endl;
  7156. return Error_code::SUCCESS;
  7157. }
  7158. //搬运器 修正轴距
  7159. Error_manager Dispatch_process::carrier_adjust_wheel_base(Dispatch_control_node & dispatch_control_node, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7160. {
  7161. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7162. char t_key[50] = {0};
  7163. sprintf(t_key, "%s+%d+%d", dispatch_control_node.m_dispatch_control_request_msg.command_key().c_str(), dispatch_control_node.m_dispatch_control_request_msg.dispatch_task_type(), tp_carrier_task->m_step);
  7164. tp_carrier_task->m_request_key = t_key;
  7165. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7166. tp_carrier_task->m_request_wheelbase = m_wheel_base;
  7167. tp_carrier_task->m_request_y1 = tp_carrier->m_actual_y + tp_dispatch_coordinates->m_carrier_y_y1_distance;
  7168. tp_carrier_task->m_request_y2 = tp_carrier_task->m_request_y1 - tp_carrier_task->m_request_wheelbase;
  7169. std::cout << " huli test :::: " << " carrier_adjust_wheel_base = " << tp_carrier_task->m_request_key << std::endl;
  7170. std::cout << " huli test :::: " << " carrier_adjust_wheel_base = " << tp_carrier_task->m_respons_key << std::endl;
  7171. std::cout << " huli test :::: " << " tp_carrier_task->m_request_wheelbase = " << tp_carrier_task->m_request_wheelbase << std::endl;
  7172. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y1 = " << tp_carrier_task->m_request_y1 << std::endl;
  7173. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y2 = " << tp_carrier_task->m_request_y2 << std::endl;
  7174. return Error_code::SUCCESS;
  7175. }
  7176. //机器手 准备开始, 需要同步任务单和设备真实数据.
  7177. Error_manager Dispatch_process::catcher_ready_to_start(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7178. {
  7179. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7180. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7181. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7182. tp_catcher_task->m_request_x = tp_catcher->m_actual_x;
  7183. tp_catcher_task->m_request_y = tp_catcher->m_actual_y;
  7184. tp_catcher_task->m_request_b = tp_catcher->m_actual_b;
  7185. tp_catcher_task->m_request_z = tp_catcher->m_actual_z;
  7186. tp_catcher_task->m_request_d1 = tp_catcher->m_actual_d1;
  7187. tp_catcher_task->m_request_d2 = tp_catcher->m_actual_d2;
  7188. tp_catcher_task->m_request_wheelbase = Dispatch_coordinates::get_instance_references().m_default_wheelbase;
  7189. tp_catcher_task->m_request_clamp_motion = (Catcher_task::Clamp_motion)tp_catcher->m_actual_clamp_motion1;
  7190. return Error_code::SUCCESS;
  7191. }
  7192. //机器手调整到正常待机的姿态(调节夹杆和轴距)
  7193. Error_manager Dispatch_process::catcher_adjust_to_ready(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7194. {
  7195. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7196. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7197. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7198. //调整姿态
  7199. tp_catcher_task->m_request_clamp_motion = Catcher_task::Clamp_motion::E_CLAMP_LOOSE;
  7200. tp_catcher_task->m_request_d1 = tp_dispatch_coordinates->m_catcher_d1_min;
  7201. tp_catcher_task->m_request_d2 = tp_dispatch_coordinates->m_catcher_d2_min;
  7202. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  7203. {
  7204. tp_catcher_task->m_request_b = 270;
  7205. }
  7206. else
  7207. {
  7208. tp_catcher_task->m_request_b = 90;
  7209. }
  7210. std::cout << " huli test :::: " << " catcher_adjust_to_ready = " << tp_catcher_task->m_request_key << std::endl;
  7211. std::cout << " huli test :::: " << " catcher_adjust_to_ready = " << tp_catcher_task->m_respons_key << std::endl;
  7212. std::cout << " huli test :::: " << " tp_catcher_task->m_request_clamp_motion = " << tp_catcher_task->m_request_clamp_motion << std::endl;
  7213. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d1 = " << tp_catcher_task->m_request_d1 << std::endl;
  7214. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d2 = " << tp_catcher_task->m_request_d2 << std::endl;
  7215. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  7216. std::cout << " huli test :::: " << " tp_catcher_task->m_request_b = " << tp_catcher_task->m_request_b << std::endl;
  7217. return Error_code::SUCCESS;
  7218. }
  7219. //机器手 移动x
  7220. Error_manager Dispatch_process::catcher_move_x(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_x)
  7221. {
  7222. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7223. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7224. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7225. //机器手 移动x
  7226. tp_catcher_task->m_request_x = target_x;
  7227. std::cout << " huli test :::: " << " catcher_move_x = " << tp_catcher_task->m_request_key << std::endl;
  7228. std::cout << " huli test :::: " << " catcher_move_x = " << tp_catcher_task->m_respons_key << std::endl;
  7229. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  7230. return Error_code::SUCCESS;
  7231. }
  7232. //机器手 移动y
  7233. Error_manager Dispatch_process::catcher_move_y(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_y)
  7234. {
  7235. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7236. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7237. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7238. //机器手 移动y
  7239. tp_catcher_task->m_request_y = target_y;
  7240. std::cout << " huli test :::: " << " catcher_move_y = " << tp_catcher_task->m_request_key << std::endl;
  7241. std::cout << " huli test :::: " << " catcher_move_y = " << tp_catcher_task->m_respons_key << std::endl;
  7242. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  7243. return Error_code::SUCCESS;
  7244. }
  7245. //机器手 移动z
  7246. Error_manager Dispatch_process::catcher_move_z(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_z)
  7247. {
  7248. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7249. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7250. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7251. //机器手 移动z
  7252. tp_catcher_task->m_request_z = target_z;
  7253. std::cout << " huli test :::: " << " catcher_move_z = " << tp_catcher_task->m_request_key << std::endl;
  7254. std::cout << " huli test :::: " << " catcher_move_z = " << tp_catcher_task->m_respons_key << std::endl;
  7255. std::cout << " huli test :::: " << " tp_catcher_task->m_request_z = " << tp_catcher_task->m_request_z << std::endl;
  7256. return Error_code::SUCCESS;
  7257. }
  7258. //机器手调整到 准备从地面抓车前的姿态
  7259. Error_manager Dispatch_process::catcher_adjust_from_ground(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7260. {
  7261. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7262. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7263. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7264. //机器手 调整x y b d1 d2, 根据感测模块的定位信息, 调整机器手的姿态, 准备抓车.
  7265. tp_catcher_task->m_request_x = m_car_measure_information.center_x;
  7266. tp_catcher_task->m_request_y = m_car_measure_information.center_y;
  7267. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  7268. {
  7269. //机器手如果旋转反向, 那就+180即可, 没有必要旋转归位.
  7270. tp_catcher_task->m_request_b = 180 + m_car_measure_information.car_angle;
  7271. }
  7272. else
  7273. {
  7274. tp_catcher_task->m_request_b = m_car_measure_information.car_angle;
  7275. }
  7276. //限制轮距, 在夹车杆松开时, 机器人下降时, 轴距不能超过3000mm, 必须下降到最下面才能调整轴距, 夹车后可以上升.
  7277. if ( m_wheel_base > tp_dispatch_coordinates->m_catcher_wheel_base_limit )
  7278. {
  7279. tp_catcher_task->m_request_d1 = (tp_dispatch_coordinates->m_catcher_wheel_base_limit - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7280. tp_catcher_task->m_request_d2 = (tp_dispatch_coordinates->m_catcher_wheel_base_limit - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7281. tp_catcher_task->m_request_wheelbase = tp_dispatch_coordinates->m_catcher_wheel_base_limit;
  7282. }
  7283. else
  7284. {
  7285. tp_catcher_task->m_request_d1 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7286. tp_catcher_task->m_request_d2 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7287. tp_catcher_task->m_request_wheelbase = m_wheel_base;
  7288. }
  7289. tp_catcher_task->m_request_clamp_motion = Catcher_task::Clamp_motion::E_CLAMP_LOOSE;
  7290. std::cout << " huli test :::: " << " catcher_adjust_from_ground = " << tp_catcher_task->m_request_key << std::endl;
  7291. std::cout << " huli test :::: " << " catcher_adjust_from_ground = " << tp_catcher_task->m_respons_key << std::endl;
  7292. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  7293. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  7294. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  7295. std::cout << " huli test :::: " << " tp_catcher_task->m_request_b = " << tp_catcher_task->m_request_b << std::endl;
  7296. std::cout << " huli test :::: " << " m_wheel_base = " << m_wheel_base << std::endl;
  7297. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d1 = " << tp_catcher_task->m_request_d1 << std::endl;
  7298. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d2 = " << tp_catcher_task->m_request_d2 << std::endl;
  7299. std::cout << " huli test :::: " << " tp_catcher_task->m_request_wheelbase = " << tp_catcher_task->m_request_wheelbase << std::endl;
  7300. std::cout << " huli test :::: " << " tp_catcher_task->m_request_clamp_motion = " << tp_catcher_task->m_request_clamp_motion << std::endl;
  7301. return Error_code::SUCCESS;
  7302. }
  7303. //机器手 修正轴距, 如果轴距大于3000mm, 那么就要修正轴距.
  7304. Error_manager Dispatch_process::catcher_adjust_wheel_base(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7305. {
  7306. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7307. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7308. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7309. //修正轴距
  7310. tp_catcher_task->m_request_d1 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7311. tp_catcher_task->m_request_d2 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7312. tp_catcher_task->m_request_wheelbase = m_wheel_base;
  7313. std::cout << " huli test :::: " << " catcher_adjust_wheel_base = " << tp_catcher_task->m_request_key << std::endl;
  7314. std::cout << " huli test :::: " << " catcher_adjust_wheel_base = " << tp_catcher_task->m_respons_key << std::endl;
  7315. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d1 = " << tp_catcher_task->m_request_d1 << std::endl;
  7316. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d2 = " << tp_catcher_task->m_request_d2 << std::endl;
  7317. std::cout << " huli test :::: " << " tp_catcher_task->m_request_wheelbase = " << tp_catcher_task->m_request_wheelbase << std::endl;
  7318. return Error_code::SUCCESS;
  7319. }
  7320. //机器手 移动c轴 夹杆
  7321. Error_manager Dispatch_process::catcher_move_c(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, Catcher_task::Clamp_motion target)
  7322. {
  7323. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7324. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7325. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7326. tp_catcher_task->m_request_clamp_motion = target;
  7327. std::cout << " huli test :::: " << " catcher_move_c = " << tp_catcher_task->m_request_key << std::endl;
  7328. std::cout << " huli test :::: " << " catcher_move_c = " << tp_catcher_task->m_respons_key << std::endl;
  7329. std::cout << " huli test :::: " << " tp_catcher_task->m_request_clamp_motion = " << tp_catcher_task->m_request_clamp_motion << std::endl;
  7330. return Error_code::SUCCESS;
  7331. }
  7332. //机器手调整到 准备把车放到搬运器的姿态
  7333. Error_manager Dispatch_process::catcher_adjust_to_carrier(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_x, bool reverse_flag)
  7334. {
  7335. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7336. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7337. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7338. //机器手 调整x y b d1 d2, 调整机器手的姿态, 准备把车放置到中跑车上.
  7339. tp_catcher_task->m_request_x = target_x;
  7340. tp_catcher_task->m_request_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  7341. //存车需要反向, 取车不需要
  7342. if ( reverse_flag )
  7343. {
  7344. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  7345. {
  7346. tp_catcher_task->m_request_b = 90;
  7347. }
  7348. else
  7349. {
  7350. tp_catcher_task->m_request_b = 270;
  7351. }
  7352. }
  7353. else
  7354. {
  7355. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  7356. {
  7357. tp_catcher_task->m_request_b = 270;
  7358. }
  7359. else
  7360. {
  7361. tp_catcher_task->m_request_b = 90;
  7362. }
  7363. }
  7364. std::cout << " huli test :::: " << " catcher_adjust_to_carrier = " << tp_catcher_task->m_request_key << std::endl;
  7365. std::cout << " huli test :::: " << " catcher_adjust_to_carrier = " << tp_catcher_task->m_respons_key << std::endl;
  7366. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  7367. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  7368. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  7369. std::cout << " huli test :::: " << " tp_catcher->m_request_b = " << tp_catcher->m_request_b << std::endl;
  7370. return Error_code::SUCCESS;
  7371. }
  7372. //机器手调整到 准备把车放到地面的姿态
  7373. Error_manager Dispatch_process::catcher_adjust_to_ground(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_x, float target_y)
  7374. {
  7375. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7376. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7377. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7378. //机器手 调整x y b d1 d2, 调整机器手的姿态, 准备把车放置到中跑车上.
  7379. tp_catcher_task->m_request_x = target_x;
  7380. tp_catcher_task->m_request_y = target_y;
  7381. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  7382. {
  7383. tp_catcher_task->m_request_b = 270;
  7384. }
  7385. else
  7386. {
  7387. tp_catcher_task->m_request_b = 90;
  7388. }
  7389. std::cout << " huli test :::: " << " catcher_adjust_to_ground = " << tp_catcher_task->m_request_key << std::endl;
  7390. std::cout << " huli test :::: " << " catcher_adjust_to_ground = " << tp_catcher_task->m_respons_key << std::endl;
  7391. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  7392. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  7393. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  7394. std::cout << " huli test :::: " << " tp_catcher->m_request_b = " << tp_catcher->m_request_b << std::endl;
  7395. return Error_code::SUCCESS;
  7396. }
  7397. //机器手调整到 对接搬运器的姿态
  7398. Error_manager Dispatch_process::catcher_adjust_from_carrier(std::string dispatch_control_command_key, Catcher * tp_catcher, Catcher_task * tp_catcher_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_x)
  7399. {
  7400. std::unique_lock<std::mutex> t_lock2(tp_catcher_task->m_lock);
  7401. tp_catcher_task->m_request_key = dispatch_control_command_key;
  7402. tp_catcher_task->set_task_statu(Task_Base::TASK_CREATED);
  7403. //机器手 调整x y b d1 d2, 调整机器手的姿态, 准备把车放置到中跑车上.
  7404. tp_catcher_task->m_request_x = target_x;
  7405. tp_catcher_task->m_request_y = tp_dispatch_coordinates->m_carrier_default_y1_back - (m_wheel_base /2);
  7406. if ( tp_catcher->m_catcher_direction == Dispatch_device_base::Catcher_direction::CATCHER_DIRECTION_NEGATIVE )
  7407. {
  7408. tp_catcher_task->m_request_b = 270;
  7409. }
  7410. else
  7411. {
  7412. tp_catcher_task->m_request_b = 90;
  7413. }
  7414. //限制轮距, 在夹车杆松开时, 机器人下降时, 轴距不能超过3000mm, 必须下降到最下面才能调整轴距, 夹车后可以上升.
  7415. if ( m_wheel_base > tp_dispatch_coordinates->m_catcher_wheel_base_limit )
  7416. {
  7417. tp_catcher_task->m_request_d1 = (tp_dispatch_coordinates->m_catcher_wheel_base_limit - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7418. tp_catcher_task->m_request_d2 = (tp_dispatch_coordinates->m_catcher_wheel_base_limit - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7419. tp_catcher_task->m_request_wheelbase = tp_dispatch_coordinates->m_catcher_wheel_base_limit;
  7420. }
  7421. else
  7422. {
  7423. tp_catcher_task->m_request_d1 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7424. tp_catcher_task->m_request_d2 = (m_wheel_base - tp_dispatch_coordinates->m_catcher_d1_d2_distance)/2;
  7425. tp_catcher_task->m_request_wheelbase = m_wheel_base;
  7426. }
  7427. tp_catcher_task->m_request_clamp_motion = Catcher_task::Clamp_motion::E_CLAMP_LOOSE;
  7428. std::cout << " huli test :::: " << " catcher_adjust_from_carrier = " << tp_catcher_task->m_request_key << std::endl;
  7429. std::cout << " huli test :::: " << " catcher_adjust_from_carrier = " << tp_catcher_task->m_respons_key << std::endl;
  7430. std::cout << " huli test :::: " << " tp_catcher_task->m_request_x = " << tp_catcher_task->m_request_x << std::endl;
  7431. std::cout << " huli test :::: " << " tp_catcher_task->m_request_y = " << tp_catcher_task->m_request_y << std::endl;
  7432. std::cout << " huli test :::: " << " tp_catcher->m_catcher_direction = " << tp_catcher->m_catcher_direction << std::endl;
  7433. std::cout << " huli test :::: " << " tp_catcher_task->m_request_b = " << tp_catcher_task->m_request_b << std::endl;
  7434. std::cout << " huli test :::: " << " m_wheel_base = " << m_wheel_base << std::endl;
  7435. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d1 = " << tp_catcher_task->m_request_d1 << std::endl;
  7436. std::cout << " huli test :::: " << " tp_catcher_task->m_request_d2 = " << tp_catcher_task->m_request_d2 << std::endl;
  7437. std::cout << " huli test :::: " << " tp_catcher_task->m_request_wheelbase = " << tp_catcher_task->m_request_wheelbase << std::endl;
  7438. std::cout << " huli test :::: " << " tp_catcher_task->m_request_clamp_motion = " << tp_catcher_task->m_request_clamp_motion << std::endl;
  7439. return Error_code::SUCCESS;
  7440. }
  7441. //搬运器 准备开始, 需要同步任务单和设备真实数据.
  7442. Error_manager Dispatch_process::carrier_ready_to_start(std::string dispatch_control_command_key, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7443. {
  7444. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7445. tp_carrier_task->m_request_key = dispatch_control_command_key;
  7446. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7447. tp_carrier_task->m_request_x = tp_carrier->m_actual_x;
  7448. tp_carrier_task->m_request_y = tp_carrier->m_actual_y;
  7449. tp_carrier_task->m_request_z = tp_carrier->m_actual_z;
  7450. tp_carrier_task->m_request_y1 = tp_carrier->m_actual_y1;
  7451. tp_carrier_task->m_request_y2 = tp_carrier->m_actual_y2;
  7452. tp_carrier_task->m_request_clamp_motion = (Carrier_task::Clamp_motion)tp_carrier->m_actual_clamp_motion1;
  7453. tp_carrier_task->m_request_joint_motion_x = (Carrier_task::Joint_motion)tp_carrier->m_actual_joint_motion_x1;
  7454. tp_carrier_task->m_request_joint_motion_y = Carrier_task::Joint_motion::E_JOINT_NO_ACTION;
  7455. tp_carrier_task->m_request_space_id = 0;
  7456. tp_carrier_task->m_request_floor_id = 0;
  7457. tp_carrier_task->m_request_wheelbase = Dispatch_coordinates::get_instance_references().m_default_wheelbase;
  7458. return Error_code::SUCCESS;
  7459. }
  7460. //搬运器调整到 正常待机的姿态(调节夹杆和轴距)
  7461. Error_manager Dispatch_process::carrier_adjust_to_ready(std::string dispatch_control_command_key, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7462. {
  7463. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7464. tp_carrier_task->m_request_key = dispatch_control_command_key;
  7465. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7466. tp_carrier_task->m_request_clamp_motion = Carrier_task::Clamp_motion::E_CLAMP_LOOSE;
  7467. tp_carrier_task->m_request_wheelbase = m_wheel_base;
  7468. tp_carrier_task->m_request_y1 = tp_carrier->m_actual_y + tp_dispatch_coordinates->m_carrier_y_y1_distance;
  7469. tp_carrier_task->m_request_y2 = tp_carrier_task->m_request_y1 - tp_carrier_task->m_request_wheelbase;
  7470. std::cout << " huli test :::: " << " carrier_adjust_to_ready = " << tp_carrier_task->m_request_key << std::endl;
  7471. std::cout << " huli test :::: " << " carrier_adjust_to_ready = " << tp_carrier_task->m_respons_key << std::endl;
  7472. std::cout << " huli test :::: " << " tp_carrier_task->m_request_wheelbase = " << tp_carrier_task->m_request_wheelbase << std::endl;
  7473. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y1 = " << tp_carrier_task->m_request_y1 << std::endl;
  7474. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y2 = " << tp_carrier_task->m_request_y2 << std::endl;
  7475. std::cout << " huli test :::: " << " tp_carrier_task->m_request_clamp_motion = " << tp_carrier_task->m_request_clamp_motion << std::endl;
  7476. return Error_code::SUCCESS;
  7477. }
  7478. //搬运器 移动x
  7479. Error_manager Dispatch_process::carrier_move_x(std::string dispatch_control_command_key, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_x)
  7480. {
  7481. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7482. tp_carrier_task->m_request_key = dispatch_control_command_key;
  7483. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7484. tp_carrier_task->m_request_x = target_x;
  7485. std::cout << " huli test :::: " << " carrier_move_x = " << tp_carrier_task->m_request_key << std::endl;
  7486. std::cout << " huli test :::: " << " carrier_move_x = " << tp_carrier_task->m_respons_key << std::endl;
  7487. std::cout << " huli test :::: " << " tp_carrier_task->m_request_x = " << tp_carrier_task->m_request_x << std::endl;
  7488. return Error_code::SUCCESS;
  7489. }
  7490. //搬运器 移动y
  7491. Error_manager Dispatch_process::carrier_move_y(std::string dispatch_control_command_key, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_y)
  7492. {
  7493. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7494. tp_carrier_task->m_request_key = dispatch_control_command_key;
  7495. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7496. tp_carrier_task->m_request_y = target_y;
  7497. tp_carrier_task->m_request_wheelbase = m_wheel_base;
  7498. tp_carrier_task->m_request_y1 = tp_carrier_task->m_request_y + tp_dispatch_coordinates->m_carrier_y_y1_distance;
  7499. tp_carrier_task->m_request_y2 = tp_carrier_task->m_request_y1 - tp_carrier_task->m_request_wheelbase;
  7500. std::cout << " huli test :::: " << " carrier_move_y = " << tp_carrier_task->m_request_key << std::endl;
  7501. std::cout << " huli test :::: " << " carrier_move_y = " << tp_carrier_task->m_respons_key << std::endl;
  7502. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y = " << tp_carrier_task->m_request_y << std::endl;
  7503. std::cout << " huli test :::: " << " tp_carrier_task->m_request_wheelbase = " << tp_carrier_task->m_request_wheelbase << std::endl;
  7504. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y1 = " << tp_carrier_task->m_request_y1 << std::endl;
  7505. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y2 = " << tp_carrier_task->m_request_y2 << std::endl;
  7506. return Error_code::SUCCESS;
  7507. }
  7508. //搬运器 移动z
  7509. Error_manager Dispatch_process::carrier_move_z(std::string dispatch_control_command_key, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, float target_z)
  7510. {
  7511. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7512. tp_carrier_task->m_request_key = dispatch_control_command_key;
  7513. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7514. tp_carrier_task->m_request_z = target_z;
  7515. std::cout << " huli test :::: " << " carrier_move_z = " << tp_carrier_task->m_request_key << std::endl;
  7516. std::cout << " huli test :::: " << " carrier_move_z = " << tp_carrier_task->m_respons_key << std::endl;
  7517. std::cout << " huli test :::: " << " tp_carrier_task->m_request_z = " << tp_carrier_task->m_request_z << std::endl;
  7518. return Error_code::SUCCESS;
  7519. }
  7520. //搬运器 移动c轴 夹车杆
  7521. Error_manager Dispatch_process::carrier_move_c(std::string dispatch_control_command_key, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, Carrier_task::Clamp_motion target)
  7522. {
  7523. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7524. tp_carrier_task->m_request_key = dispatch_control_command_key;
  7525. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7526. tp_carrier_task->m_request_clamp_motion = target;
  7527. std::cout << " huli test :::: " << " carrier_move_c = " << tp_carrier_task->m_request_key << std::endl;
  7528. std::cout << " huli test :::: " << " carrier_move_c = " << tp_carrier_task->m_respons_key << std::endl;
  7529. std::cout << " huli test :::: " << " tp_carrier_task->m_request_clamp_motion = " << tp_carrier_task->m_request_clamp_motion << std::endl;
  7530. return Error_code::SUCCESS;
  7531. }
  7532. //搬运器调整 水平的交接
  7533. Error_manager Dispatch_process::carrier_joint_x(std::string dispatch_control_command_key, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates, Carrier_task::Joint_motion target)
  7534. {
  7535. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7536. tp_carrier_task->m_request_key = dispatch_control_command_key;
  7537. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7538. tp_carrier_task->m_request_joint_motion_x = target;
  7539. std::cout << " huli test :::: " << " carrier_joint_x = " << tp_carrier_task->m_request_key << std::endl;
  7540. std::cout << " huli test :::: " << " carrier_joint_x = " << tp_carrier_task->m_respons_key << std::endl;
  7541. std::cout << " huli test :::: " << " tp_carrier_task->m_request_joint_motion_x = " << tp_carrier_task->m_request_joint_motion_x << std::endl;
  7542. return Error_code::SUCCESS;
  7543. }
  7544. //搬运器 修正轴距
  7545. Error_manager Dispatch_process::carrier_adjust_wheel_base(std::string dispatch_control_command_key, Carrier * tp_carrier, Carrier_task * tp_carrier_task, Dispatch_coordinates * tp_dispatch_coordinates)
  7546. {
  7547. std::unique_lock<std::mutex> t_lock2(tp_carrier_task->m_lock);
  7548. tp_carrier_task->m_request_key = dispatch_control_command_key;
  7549. tp_carrier_task->set_task_statu(Task_Base::TASK_CREATED);
  7550. tp_carrier_task->m_request_wheelbase = m_wheel_base;
  7551. tp_carrier_task->m_request_y1 = tp_carrier->m_actual_y + tp_dispatch_coordinates->m_carrier_y_y1_distance;
  7552. tp_carrier_task->m_request_y2 = tp_carrier_task->m_request_y1 - tp_carrier_task->m_request_wheelbase;
  7553. std::cout << " huli test :::: " << " carrier_adjust_wheel_base = " << tp_carrier_task->m_request_key << std::endl;
  7554. std::cout << " huli test :::: " << " carrier_adjust_wheel_base = " << tp_carrier_task->m_respons_key << std::endl;
  7555. std::cout << " huli test :::: " << " tp_carrier_task->m_request_wheelbase = " << tp_carrier_task->m_request_wheelbase << std::endl;
  7556. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y1 = " << tp_carrier_task->m_request_y1 << std::endl;
  7557. std::cout << " huli test :::: " << " tp_carrier_task->m_request_y2 = " << tp_carrier_task->m_request_y2 << std::endl;
  7558. return Error_code::SUCCESS;
  7559. }