123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 |
- //
- // Created by huli on 2021/3/24.
- //
- #include "dispatch_coordinates.h"
- #include "../tool/proto_tool.h"
- Dispatch_coordinates::Dispatch_coordinates()
- {
- mpp_space_lock = nullptr;
- m_space_lock_rows = 0;
- m_space_lock_columns = 0;
- m_space_lock_total = 0;
- }
- Dispatch_coordinates::~Dispatch_coordinates()
- {
- dispatch_coordinates_uninit();
- }
- //初始化 调度的坐标系 模块。如下三选一
- Error_manager Dispatch_coordinates::dispatch_coordinates_init()
- {
- return dispatch_coordinates_init_from_protobuf(DISPATCH_COORDINATES_PARAMETER_PATH);
- }
- //初始化 调度的坐标系 模块。从文件读取
- Error_manager Dispatch_coordinates::dispatch_coordinates_init_from_protobuf(std::string prototxt_path)
- {
- Dispatch_proto::Dispatch_coordinates_parameter_all t_dispatch_coordinates_parameter_all;
- if(! proto_tool::read_proto_param(prototxt_path,t_dispatch_coordinates_parameter_all) )
- {
- return Error_manager(DISPATCH_COORDINATES_READ_PROTOBUF_ERROR,MINOR_ERROR,
- "Dispatch_coordinates read_proto_param failed");
- }
- return dispatch_coordinates_init_from_protobuf(t_dispatch_coordinates_parameter_all);
- }
- //初始化 调度的坐标系 模块。从protobuf读取
- Error_manager Dispatch_coordinates::dispatch_coordinates_init_from_protobuf(Dispatch_proto::Dispatch_coordinates_parameter_all& dispatch_coordinates_parameter_all)
- {
- LOG(INFO) << " ---Dispatch_coordinates::dispatch_coordinates_init_from_protobuf() run--- "<< this;
- Error_manager t_error;
- m_space_lock_rows = dispatch_coordinates_parameter_all.parkspace_number().rows();
- m_space_lock_columns = dispatch_coordinates_parameter_all.parkspace_number().columns();
- m_space_lock_total = dispatch_coordinates_parameter_all.parkspace_number().total();
- mpp_space_lock = new space_device*[m_space_lock_rows];
- for (int i = 0; i < m_space_lock_rows; ++i)
- {
- mpp_space_lock[i] = new space_device[m_space_lock_columns];
- for (int j = 0; j < m_space_lock_columns; ++j)
- {
- //注意了, 这里一定要初始化为-1, 因为设备id=0 是有效设备
- mpp_space_lock[i][j].m_catcher_id = -1;
- mpp_space_lock[i][j].m_carrier_id = -1;
- }
- }
- int size;
- size = dispatch_coordinates_parameter_all.packspace_coordinates_parameters_size();
- for (int i = 0; i < size; ++i)
- {
- Point3D_tool::Point3D t_point3d;
- int id = dispatch_coordinates_parameter_all.packspace_coordinates_parameters(i).id();
- t_point3d.x = dispatch_coordinates_parameter_all.packspace_coordinates_parameters(i).x();
- t_point3d.y = dispatch_coordinates_parameter_all.packspace_coordinates_parameters(i).y();
- t_point3d.z = dispatch_coordinates_parameter_all.packspace_coordinates_parameters(i).z();
- m_packspace_coordinates[id] = t_point3d;
- }
- size = dispatch_coordinates_parameter_all.passageway_coordinates_parameters_size();
- for (int i = 0; i < size; ++i)
- {
- Point3D_tool::Point3D t_point3d;
- int id = dispatch_coordinates_parameter_all.passageway_coordinates_parameters(i).id();
- t_point3d.x = dispatch_coordinates_parameter_all.passageway_coordinates_parameters(i).x();
- t_point3d.y = dispatch_coordinates_parameter_all.passageway_coordinates_parameters(i).y();
- t_point3d.z = dispatch_coordinates_parameter_all.passageway_coordinates_parameters(i).z();
- m_passageway_coordinates[id] = t_point3d;
- }
- size = dispatch_coordinates_parameter_all.carrier_coordinates_parameters_size();
- for (int i = 0; i < size; ++i)
- {
- Point3D_tool::Point3D t_point3d;
- int id = dispatch_coordinates_parameter_all.carrier_coordinates_parameters(i).id();
- t_point3d.x = dispatch_coordinates_parameter_all.carrier_coordinates_parameters(i).x();
- t_point3d.y = dispatch_coordinates_parameter_all.carrier_coordinates_parameters(i).y();
- t_point3d.z = dispatch_coordinates_parameter_all.carrier_coordinates_parameters(i).z();
- m_carrier_coordinates[id] = t_point3d;
- }
- size = dispatch_coordinates_parameter_all.catcher_coordinates_parameters_size();
- for (int i = 0; i < size; ++i)
- {
- Point3D_tool::Point3D t_point3d;
- int id = dispatch_coordinates_parameter_all.catcher_coordinates_parameters(i).id();
- t_point3d.x = dispatch_coordinates_parameter_all.catcher_coordinates_parameters(i).x();
- t_point3d.y = dispatch_coordinates_parameter_all.catcher_coordinates_parameters(i).y();
- t_point3d.z = dispatch_coordinates_parameter_all.catcher_coordinates_parameters(i).z();
- m_catcher_coordinates[id] = t_point3d;
- }
- m_carrier_box.x_min = dispatch_coordinates_parameter_all.carrier_box_parameters().x_min();
- m_carrier_box.x_max = dispatch_coordinates_parameter_all.carrier_box_parameters().x_max();
- m_carrier_box.y_min = dispatch_coordinates_parameter_all.carrier_box_parameters().y_min();
- m_carrier_box.y_max = dispatch_coordinates_parameter_all.carrier_box_parameters().y_max();
- m_carrier_box.z_min = dispatch_coordinates_parameter_all.carrier_box_parameters().z_min();
- m_carrier_box.z_max = dispatch_coordinates_parameter_all.carrier_box_parameters().z_max();
- m_catcher_box.x_min = dispatch_coordinates_parameter_all.catcher_box_parameters().x_min();
- m_catcher_box.x_max = dispatch_coordinates_parameter_all.catcher_box_parameters().x_max();
- m_catcher_box.y_min = dispatch_coordinates_parameter_all.catcher_box_parameters().y_min();
- m_catcher_box.y_max = dispatch_coordinates_parameter_all.catcher_box_parameters().y_max();
- m_catcher_box.z_min = dispatch_coordinates_parameter_all.catcher_box_parameters().z_min();
- m_catcher_box.z_max = dispatch_coordinates_parameter_all.catcher_box_parameters().z_max();
- m_catcher_b_min = dispatch_coordinates_parameter_all.catcher_b_min();
- m_catcher_b_max = dispatch_coordinates_parameter_all.catcher_b_max();
- m_catcher_d1_min = dispatch_coordinates_parameter_all.catcher_d1_min();
- m_catcher_d1_max = dispatch_coordinates_parameter_all.catcher_d1_max();
- m_catcher_d2_min = dispatch_coordinates_parameter_all.catcher_d2_min();
- m_catcher_d2_max = dispatch_coordinates_parameter_all.catcher_d2_max();
- std::cout << " huli test :::: " << " m_packspace_coordinates.size() = " << m_packspace_coordinates.size() << std::endl;
- std::cout << " huli test :::: " << " m_passageway_coordinates.size() = " << m_passageway_coordinates.size() << std::endl;
- std::cout << " huli test :::: " << " m_carrier_coordinates.size() = " << m_carrier_coordinates.size() << std::endl;
- std::cout << " huli test :::: " << " m_catcher_coordinates.size() = " << m_catcher_coordinates.size() << std::endl;
- m_default_wheelbase = dispatch_coordinates_parameter_all.default_wheelbase();
- m_catcher_1th_floor_z = dispatch_coordinates_parameter_all.catcher_1th_floor_z();
- m_catcher_2th_floor_z = dispatch_coordinates_parameter_all.catcher_2th_floor_z();
- m_catcher_3th_floor_z = dispatch_coordinates_parameter_all.catcher_3th_floor_z();
- m_catcher_4th_floor_z = dispatch_coordinates_parameter_all.catcher_4th_floor_z();
- m_carrier_1th_floor_z = dispatch_coordinates_parameter_all.carrier_1th_floor_z();
- m_carrier_2th_floor_z = dispatch_coordinates_parameter_all.carrier_2th_floor_z();
- m_carrier_3th_floor_z = dispatch_coordinates_parameter_all.carrier_3th_floor_z();
- m_carrier_4th_floor_z = dispatch_coordinates_parameter_all.carrier_4th_floor_z();
- m_catcher_d1_d2_distance = dispatch_coordinates_parameter_all.catcher_d1_d2_distance();
- m_catcher_wheel_base_limit = dispatch_coordinates_parameter_all.catcher_wheel_base_limit();
- m_carrier_y_y1_distance = dispatch_coordinates_parameter_all.carrier_y_y1_distance();
- m_carrier_default_y1_back = dispatch_coordinates_parameter_all.carrier_default_y1_back();
- m_carrier_default_y1_leave = dispatch_coordinates_parameter_all.carrier_default_y1_leave();
- m_carrier_default_y_back = dispatch_coordinates_parameter_all.carrier_default_y_back();
- m_carrier_default_y_leave = dispatch_coordinates_parameter_all.carrier_default_y_leave();
- m_carrier_default_x_left = dispatch_coordinates_parameter_all.carrier_default_x_left();
- m_carrier_default_x_right = dispatch_coordinates_parameter_all.carrier_default_x_right();
- m_passageway_terminal_id_min = dispatch_coordinates_parameter_all.passageway_terminal_id_min();
- m_passageway_terminal_id_max = dispatch_coordinates_parameter_all.passageway_terminal_id_max();
- m_passageway_terminal_number = dispatch_coordinates_parameter_all.passageway_terminal_number();
- size = dispatch_coordinates_parameter_all.passageway_functioning_patterns_size();
- for (int i = m_passageway_terminal_id_min; i < size; ++i)
- {
- m_passageway_functioning_pattern_map[i] = (Passageway_functioning_pattern)dispatch_coordinates_parameter_all.passageway_functioning_patterns(i);
- }
- if ( m_passageway_terminal_number != m_passageway_terminal_id_max - m_passageway_terminal_id_min +1 ||
- m_passageway_terminal_number != size)
- {
- return Error_manager(Error_code::PARAMETER_ERROR, Error_level::MINOR_ERROR,
- " Dispatch_coordinates::dispatch_coordinates_init_from_protobuf PARAMRTER ERROR ");
- }
- m_parkspace_id_min = dispatch_coordinates_parameter_all.parkspace_id_min();
- m_parkspace_id_max = dispatch_coordinates_parameter_all.parkspace_id_max();
- m_parkspace_id_total = dispatch_coordinates_parameter_all.parkspace_id_total();
- m_car_wheel_base_min = dispatch_coordinates_parameter_all.car_wheel_base_min();
- m_car_wheel_base_max = dispatch_coordinates_parameter_all.car_wheel_base_max();
- return Error_code::SUCCESS;
- }
- //反初始化
- Error_manager Dispatch_coordinates::dispatch_coordinates_uninit()
- {
- for (int i = 0; i < m_space_lock_rows; ++i)
- {
- delete [](mpp_space_lock[i]);
- }
- delete [](mpp_space_lock);
- return Error_code::SUCCESS;
- }
- void Dispatch_coordinates::set_space_lock(int space_rows, int space_columns, int catcher_id, int carrier_id)
- {
- std::unique_lock<std::mutex> t_lock(m_lock);
- mpp_space_lock[space_rows][space_columns].m_catcher_id = catcher_id;
- mpp_space_lock[space_rows][space_columns].m_carrier_id = carrier_id;
- }
- void Dispatch_coordinates::set_space_lock_for_catcher(int space_rows, int space_columns, int catcher_id)
- {
- std::unique_lock<std::mutex> t_lock(m_lock);
- mpp_space_lock[space_rows][space_columns].m_catcher_id = catcher_id;
- }
- void Dispatch_coordinates::set_space_lock_for_carrier(int space_rows, int space_columns, int carrier_id)
- {
- std::unique_lock<std::mutex> t_lock(m_lock);
- mpp_space_lock[space_rows][space_columns].m_carrier_id = carrier_id;
- }
- void Dispatch_coordinates::set_space_lock(int space_id, int catcher_id, int carrier_id)
- {
- int space_rows = (space_id-1) / m_space_lock_columns;
- int space_columns = (space_id-1) % m_space_lock_columns;
- set_space_lock(space_rows, space_columns, catcher_id, carrier_id);
- }
- void Dispatch_coordinates::set_space_lock_for_catcher(int space_id, int catcher_id)
- {
- int space_rows = (space_id-1) / m_space_lock_columns;
- int space_columns = (space_id-1) % m_space_lock_columns;
- set_space_lock_for_catcher(space_rows, space_columns, catcher_id);
- }
- void Dispatch_coordinates::set_space_lock_for_carrier(int space_id, int carrier_id)
- {
- int space_rows = (space_id-1) / m_space_lock_columns;
- int space_columns = (space_id-1) % m_space_lock_columns;
- set_space_lock_for_carrier(space_rows, space_columns, carrier_id);
- }
|