126 lines
6.3 KiB
C#
126 lines
6.3 KiB
C#
using System;
|
|
using System.Linq;
|
|
using System.Net;
|
|
using Autolabor.Benz.ObstacleDetection.DataType;
|
|
using Autolabor.Robobase;
|
|
using Autolabor.Robobase.Component.Algorithm.LidarDetection;
|
|
using Autolabor.Robobase.Component.Algorithm.LidarDetection.DataType;
|
|
using Autolabor.Robobase.Component.Business.Benz;
|
|
using Autolabor.Robobase.Component.Driver;
|
|
using Autolabor.Robobase.Component.Driver.SerialRelay;
|
|
|
|
namespace Autolabor.Benz.ObstacleDetection
|
|
{
|
|
[Serializable]
|
|
public class Detection : GroupComponent
|
|
{
|
|
// 驱动层组件
|
|
private Ld19DriverNew _lidarDriver;
|
|
private SerialRelayDriver _serialRelay;
|
|
|
|
// 算法层组件
|
|
private LidarRoiFilter _lidarFrontRoiFilter;
|
|
private LidarRoiFilter _lidarRearRoiFilter;
|
|
private ObstacleDetector _frontObstacleDetector;
|
|
private ObstacleDetector _rearObstacleDetector;
|
|
private BenzObstacleControl _benzObstacleController;
|
|
|
|
// 模拟器配置
|
|
private int _FrontLidarRpcPort = 50120;
|
|
private int _FrontLidarListenPort = 40120;
|
|
private IPAddress _serverIp = IPAddress.Loopback;
|
|
|
|
// 配置过滤区域
|
|
private LidarRoi[] _lidarFrontRoi;
|
|
private LidarRoi[] _lidarRearRoi;
|
|
|
|
public Detection(RectRoiSettings roiSettings)
|
|
{
|
|
// 1. 获取感兴趣区域
|
|
var rois = roiSettings.RectRois.Select(roi => LidarRoiFactory.Make(roi.LeftUpX, roi.LeftUpY, roi.RightDownX, roi.RightDownY)).ToList();
|
|
_lidarFrontRoi = rois.Take(1).ToArray();
|
|
_lidarRearRoi = rois.Skip(1).ToArray();
|
|
|
|
// 2. 创建各个功能组件
|
|
// 驱动组件
|
|
_lidarDriver = new Ld19DriverNew();
|
|
_serialRelay = new SerialRelayDriver();
|
|
|
|
// 算法组件
|
|
_frontObstacleDetector = new ObstacleDetector();
|
|
_rearObstacleDetector = new ObstacleDetector();
|
|
_benzObstacleController = new BenzObstacleControl();
|
|
_lidarRearRoiFilter = new LidarRoiFilter();
|
|
_lidarFrontRoiFilter = new LidarRoiFilter();
|
|
|
|
// 连接到绘图
|
|
// var lidarRender = DataRenderFactory.Make<Pose2D[]>("Benz","lidar",false,true);
|
|
// var obstacleRender = DataRenderFactory.Make<Pose2D[]>("Benz","obstacle",false,true);
|
|
// Add(lidarRender);
|
|
// Add(obstacleRender);
|
|
// _lidarDriver.OutputLocalLidarPose2D.Connect(lidarRender.Input);
|
|
// _frontObstacleDetector.OutputObstaclePoses.Connect(obstacleRender.Input);
|
|
|
|
// 3. 添加组件到容器
|
|
Add(_lidarDriver);
|
|
Add(_serialRelay);
|
|
Add(_lidarRearRoiFilter);
|
|
Add(_lidarFrontRoiFilter);
|
|
Add(_frontObstacleDetector);
|
|
Add(_rearObstacleDetector);
|
|
Add(_benzObstacleController);
|
|
|
|
// 4. 配置组件
|
|
// 激光雷达配置
|
|
_lidarDriver.SetProperty("lidar.port", "/dev/autolabor_ld19");
|
|
_lidarDriver.SetProperty("lidar.x", 0.0);
|
|
_lidarDriver.SetProperty("lidar.y", 0.0);
|
|
_lidarDriver.SetProperty("lidar.originName", "frontLidarOrigin");
|
|
_lidarDriver.SetProperty("lidar.rotation", Math.PI / 2.0);
|
|
_lidarDriver.SetProperty("lidar.startRad", -Math.PI); // 要提取的数据范围
|
|
_lidarDriver.SetProperty("lidar.rangeRad", 2.0 * Math.PI);
|
|
_lidarDriver.SetProperty("lidar.display.interval", 1000);
|
|
_lidarDriver.SetProperty("lidar.intensityLevel", 200.0);
|
|
_lidarDriver.SetProperty("sim.lidar.server.ip", _serverIp);
|
|
_lidarDriver.SetProperty("sim.lidar.rpc.port", _FrontLidarRpcPort);
|
|
_lidarDriver.SetProperty("sim.lidar.listen.port", _FrontLidarListenPort);
|
|
|
|
// 串口继电器配置
|
|
_serialRelay.SetProperty("serial.relay.port", "/dev/autolabor_relay");
|
|
|
|
// 配置过滤器
|
|
_lidarFrontRoiFilter.SetProperty("roiArray", _lidarFrontRoi);
|
|
_lidarRearRoiFilter.SetProperty("roiArray", _lidarRearRoi);
|
|
// 障碍物检测器配置
|
|
_frontObstacleDetector.SetProperty("MinClusterDistance", 0.05);
|
|
_frontObstacleDetector.SetProperty("MinClusterSize", 3);
|
|
_frontObstacleDetector.SetProperty("MaxPrjDistance", 0.05);
|
|
_frontObstacleDetector.SetProperty("GuessDistance", 1.0);
|
|
_rearObstacleDetector.SetProperty("MinClusterDistance", 0.05);
|
|
_rearObstacleDetector.SetProperty("MinClusterSize", 3);
|
|
_rearObstacleDetector.SetProperty("MaxPrjDistance", 0.05);
|
|
_rearObstacleDetector.SetProperty("GuessDistance", 1.0);
|
|
// 配置发现和丢失次数
|
|
_benzObstacleController.SetProperty("FoundObstacleThreshold", 2);
|
|
_benzObstacleController.SetProperty("LostObstacleThreshold", 3);
|
|
|
|
// 5. 连接组件
|
|
// 雷达数据流向避障检测
|
|
_lidarDriver.OutputLocalLidarPose2D.Connect(_lidarFrontRoiFilter.InputLidarPoints);
|
|
_lidarFrontRoiFilter.OutputFilteredPoints.Connect(_frontObstacleDetector.InputLidarPoints);
|
|
_lidarDriver.OutputLocalLidarPose2D.Connect(_lidarRearRoiFilter.InputLidarPoints);
|
|
_lidarRearRoiFilter.OutputFilteredPoints.Connect(_rearObstacleDetector.InputLidarPoints);
|
|
// 雷达诊断信号连接到奔驰障碍物控制器
|
|
_lidarDriver.OutputLidarDiagnostic.Connect(_benzObstacleController.InputLidarDiagnostics);
|
|
// 避障检测结果流向奔驰避障控制器
|
|
_frontObstacleDetector.OutputObstacles.Connect(_benzObstacleController.InputFrontObstacles);
|
|
_rearObstacleDetector.OutputObstacles.Connect(_benzObstacleController.InputRearObstacles);
|
|
// 奔驰避障控制器输出到继电器
|
|
_benzObstacleController.OutputRelayControl.Connect(_serialRelay.InputRelayControl);
|
|
_benzObstacleController.OutputRelayQuery.Connect(_serialRelay.InputRelayQuery);
|
|
_serialRelay.OutputRelayFeedback.Connect(_benzObstacleController.InputRelayStatus);
|
|
_serialRelay.OutputSerialConnect.Connect(_benzObstacleController.InputSerialConnect);
|
|
|
|
}
|
|
}
|
|
} |