1 Star 1 Fork 3

JackieSP/AgvDispatch

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
agv.cpp 9.18 KB
一键复制 编辑 原始数据 按行查看 历史
#include <thread>
#include "agv.h"
#include "mapmap/mapmanager.h"
#include "agvtask.h"
#include "network/tcpclient.h"
#include "userlogmanager.h"
#include "msgprocess.h"
#include "mapmap/mapmanager.h"
#include "mapmap/blockmanager.h"
Agv::Agv(int _id, std::string _name, std::string _ip, int _port) :
currentTask(nullptr),
id(_id),
name(_name),
ip(_ip),
port(_port),
lastStation(0),
nowStation(0),
nextStation(0),
x(0),
y(0),
theta(0),
floor(-1)
{
}
Agv::~Agv()
{
}
void Agv::init()
{
}
void Agv::setPosition(int _lastStation, int _nowStation, int _nextStation) {
lastStation = _lastStation;
nowStation = _nowStation;
nextStation = _nextStation;
auto mapmanagerptr = MapManager::getInstance();
if (nowStation > 0) {
onArriveStation(nowStation);
mapmanagerptr->addOccuStation(nowStation,shared_from_this());
}else if(lastStation>0 && nextStation>0){
auto line = mapmanagerptr->getPathByStartEnd(lastStation,nextStation);
if(line!=nullptr){
mapmanagerptr->addOccuLine(line->getId(),shared_from_this());
}
}
}
//到达后是否停下,如果不停下,就是不减速。
//是一个阻塞的函数
void Agv::goStation(int station, bool stop)
{
}
void Agv::stop()
{
}
void Agv::onArriveStation(int station)
{
auto mapmanagerptr = MapManager::getInstance();
auto blockmanagerptr = BlockManager::getInstance();
//set floor
auto floorid = mapmanagerptr->getFloor(station);
setFloor(floorid);
//add block occu station
MapPoint *point = mapmanagerptr->getPointById(station);
if(point == nullptr)return ;
combined_logger->info("agv id:{0} arrive station:{1}",getId(),point->getName());
auto blocks1 = mapmanagerptr->getBlocks(station);
bool addOccuResult = blockmanagerptr->tryAddBlockOccu(blocks1,getId(),station);
x = point->getX();
y = point->getY();
if(station>0){
if(nowStation>0){
lastStation = nowStation;
//free last station occu
mapmanagerptr->freeStation(lastStation,shared_from_this());
auto blockss = mapmanagerptr->getBlocks(lastStation);
blockmanagerptr->freeBlockOccu(blockss,getId(),lastStation);
}
nowStation = station;
stationMtx.lock();
for (int i = 0; i < excutestations.size(); ++i) {
if (excutestations[i] == station) {
if (i + 1 < excutestations.size()) {
nextStation = excutestations[i + 1];
}else{
nextStation = 0;
}
break;
}
}
stationMtx.unlock();
}
//TODO:释放之前的线路和站点
std::vector<MapPath *> paths;
stationMtx.lock();
for(auto line:excutespaths){
MapPath *path = mapmanagerptr->getPathById(line);
if(path == nullptr)continue;
paths.push_back(path);
}
stationMtx.unlock();
int findIndex = -1;
for(int i=0;i<paths.size();++i){
auto line = paths[i];
if(line->getEnd() == station){
findIndex = i;
}
}
if(findIndex != -1){
//之前的道路占用全部释放
//之前的站点占用全部释放
for(int i=0;i<=findIndex;++i){
auto line = paths[i];
int start = line->getStart();
int end = line->getEnd();
int lineId = line->getId();
//free start station
mapmanagerptr->freeStation(start,shared_from_this());
auto blocks4 = mapmanagerptr->getBlocks(start);
blockmanagerptr->freeBlockOccu(blocks4,getId(),start);
//free end station
if(i!=findIndex){
mapmanagerptr->freeStation(end,shared_from_this());
auto blocks5 = mapmanagerptr->getBlocks(end);
blockmanagerptr->freeBlockOccu(blocks5,getId(),end);
}
//free last line
mapmanagerptr->freeLine(lineId,shared_from_this());
auto blocks6 = mapmanagerptr->getBlocks(lineId);
blockmanagerptr->freeBlockOccu(blocks6,getId(),lineId);
}
}
char buf[SQL_MAX_LENGTH];
snprintf(buf, SQL_MAX_LENGTH, "update agv_agv set lastStation=%d,nowStation=%d,nextStation=%d where id = %d;", lastStation, nowStation, nextStation, id);
try {
g_db.execDML(buf);
}
catch (CppSQLite3Exception e) {
combined_logger->error("sqlerr code:{0} msg:{1}", e.errorCode(), e.errorMessage());
}
catch (std::exception e) {
combined_logger->error("sqlerr code:{0} ", e.what());
}
if(addOccuResult){
//判断下一段线路的可行性 [block]
//判断下一个线路 是否在block内,block内是否已经有其他车辆。如果有的话,就暂停 一下当前动作
stationMtx.lock();
auto itr = std::find(excutestations.begin(),excutestations.end(),nowStation);
if(itr!=excutestations.end()){
++itr;
if(itr!=excutestations.end()){
nextStation = *itr;
stationMtx.unlock();
//next path is block free
auto p = mapmanagerptr->getPathByStartEnd(nowStation,nextStation);
if(p!=nullptr){
auto bs = mapmanagerptr->getBlocks(p->getId());
if(!blockmanagerptr->blockPassable(bs,getId())){
pause();
}
}
}else{
stationMtx.unlock();
}
}else{
stationMtx.unlock();
}
}else{
pause();
}
blockmanagerptr->printBlock();
mapmanagerptr->printGroup();
}
void Agv::onLeaveStation(int stationid)
{
auto mapmanagerptr = MapManager::getInstance();
auto blockmanagerptr = BlockManager::getInstance();
//free block occur station
auto blocks1 = mapmanagerptr->getBlocks(stationid);
blockmanagerptr->freeBlockOccu(blocks1,getId(),stationid);
//add block occur next path
auto nextPath = mapmanagerptr->getPathByStartEnd(stationid,nextStation);
bool addOccuResult = true;
if(nextPath!=nullptr){
auto blocks2 = mapmanagerptr->getBlocks(nextPath->getId());
addOccuResult = blockmanagerptr->tryAddBlockOccu(blocks2,getId(),nextPath->getId());
}
nowStation = 0;
lastStation = stationid;
auto point = mapmanagerptr->getPointById(stationid);
if(point!=nullptr){
combined_logger->info("agv id:{0} leave station:{1}",getId(),point->getName());
}
//释放这个站点的占用
MapManager::getInstance()->freeStation(stationid,shared_from_this());
bool b_getNextStation = false;
stationMtx.lock();
for(auto line:excutespaths){
MapPath *path = mapmanagerptr->getPathById(line);
if(path == nullptr)continue;
if(path->getStart() == nowStation){
nextStation = path->getEnd();
b_getNextStation = true;
break;
}
}
stationMtx.unlock();
if(!b_getNextStation){
nextStation = 0;
}
if(nextStation == 0){
setFloor(mapmanagerptr->getFloor(lastStation));
}else{
auto pp = mapmanagerptr->getPathByStartEnd(lastStation,nextStation);
if(pp!=nullptr){
setFloor(mapmanagerptr->getFloor(pp->getId()));
}else{
setFloor(-1);
}
}
char buf[SQL_MAX_LENGTH];
snprintf(buf, SQL_MAX_LENGTH, "update agv_agv set lastStation=%d,nowStation=%d,nextStation=%d where id = %d;", lastStation, nowStation, nextStation,id);
try {
g_db.execDML(buf);
}
catch (CppSQLite3Exception e) {
combined_logger->error("sqlerr code:{0} msg:{1}", e.errorCode(), e.errorMessage());
}
catch (std::exception e) {
combined_logger->error("sqlerr code:{0} ", e.what());
}
//判断下一个站点的可行性 [block]
//判断下一个站点 是否在block内,block内是否已经有其他车辆。如果有的话,就暂停 一下当前动作
if(addOccuResult){
auto p = mapmanagerptr->getPointById(nextStation);
if(p!=nullptr){
auto blocks4 = mapmanagerptr->getBlocks(p->getId());
if(!blockmanagerptr->blockPassable(blocks4,getId())){
pause();
}
}
}else{
pause();
}
blockmanagerptr->printBlock();
//mapmanagerptr->printGroup();
}
void Agv::onError(int code, std::string msg)
{
status = AGV_STATUS_ERROR;
char sss[1024];
snprintf(sss, 1024, "Agv id:%d occur error code:%d msg:%s", id, code, msg.c_str());
std::string ss(sss);
//combined_logger->error(ss.c_str());
UserLogManager::getInstance()->push(ss);
MsgProcess::getInstance()->errorOccur(code, msg, true);
}
void Agv::onWarning(int code, std::string msg)
{
char sss[1024];
snprintf(sss, 1024, "Agv id:%d occur warning code:%d msg:%s", id, code, msg.c_str());
std::string ss(sss);
//combined_logger->warn(ss.c_str());
UserLogManager::getInstance()->push(ss);
MsgProcess::getInstance()->errorOccur(code, msg, false);
}
//请求切换地图(呼叫电梯)
void Agv::callMapChange(int station)
{
}
void Agv::cancelTask()
{
onTaskCanceled(currentTask);
}
void Agv::reconnect()
{
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/JackieSP/AgvDispatch.git
git@gitee.com:JackieSP/AgvDispatch.git
JackieSP
AgvDispatch
AgvDispatch
master

搜索帮助