Розробка AI-системи допомоги водієві (ADAS)
ADAS (Advanced Driver Assistance Systems) – це рівень L1–L2 автономності: система допомагає водію, але не замінює його. Конкретні функції: попередження про виїзд зі смуги (LDW), екстрене гальмування (AEB), адаптивний круїз-контроль (ACC), моніторинг сліпих зон (BSW). Кожна з них – окреме CV-завдання зі своїми вимогами до latency та точності.
Ключові функції та реалізація
import cv2
import numpy as np
from ultralytics import YOLO
import torch
class ADASSystem:
def __init__(self, config: dict):
self.lane_detector = self._load_lane_model(config)
self.object_detector = YOLO(config['object_model']) # YOLOv8n для скорости
self.depth_estimator = self._load_depth_model(config)
self.camera_matrix = np.array(config['camera_intrinsics'])
self.focal_length = self.camera_matrix[0, 0]
self.baseline = config.get('stereo_baseline', None)
# Пороги для предупреждений
self.ttc_warning = 2.5 # секунды — предупреждение
self.ttc_critical = 1.5 # секунды — AEB
self.lane_offset_threshold = 0.3 # метра
def lane_departure_warning(self, frame: np.ndarray,
vehicle_speed: float) -> dict:
"""
Детекция полосы: классика — UFLD (Ultra-Fast Lane Detection)
или CLRNet для сложных условий (пересечения, плохая разметка).
"""
lanes = self.lane_detector(frame)
if len(lanes) < 2:
return {'warning': False, 'reason': 'no_lanes'}
# Центр автомобиля относительно полосы
frame_center = frame.shape[1] // 2
lane_center = (lanes[0][-1][0] + lanes[1][-1][0]) // 2
offset_px = frame_center - lane_center
# Перевод пикселей в метры через гомографию
offset_m = offset_px * (3.5 / abs(lanes[1][-1][0] - lanes[0][-1][0]))
warning = abs(offset_m) > self.lane_offset_threshold
return {
'warning': warning,
'offset_meters': offset_m,
'lane_width': abs(lanes[1][-1][0] - lanes[0][-1][0])
}
def collision_warning(self, frame: np.ndarray,
ego_speed: float) -> dict:
detections = self.object_detector(frame, conf=0.5,
classes=[0, 2, 3, 5, 7])
depth_map = self.depth_estimator(frame)
warnings = []
for box in detections[0].boxes:
x1, y1, x2, y2 = map(int, box.xyxy[0])
cx = (x1 + x2) // 2
# Дистанция из depth map (стерео или монокулярная)
roi_depth = depth_map[y1:y2, x1:x2]
distance = float(np.percentile(roi_depth, 10)) # ближняя часть объекта
# TTC при текущей скорости
if distance > 0 and ego_speed > 0:
ttc = distance / ego_speed # упрощённо, без учёта скорости объекта
else:
ttc = float('inf')
if ttc < self.ttc_critical:
action = 'AEB'
elif ttc < self.ttc_warning:
action = 'WARNING'
else:
continue
warnings.append({
'class': self.object_detector.model.names[int(box.cls)],
'distance_m': distance,
'ttc_sec': ttc,
'action': action
})
return {'warnings': sorted(warnings, key=lambda x: x['ttc_sec'])}
Продуктивність: чому latency важливіша за точність
На швидкості 100 км/год. автомобіль проїжджає 27,8 метра в секунду. Затримка системи 100ms = 2,78 метра «наосліп». Тому для ADAS:
| Функція | Макс. latency | Рекомендована модель |
|---|---|---|
| AEB (екстренне гальмування) | < 30ms | YOLOV8n + TensorRT INT8 |
| LDW (попередження про смугу) | < 50ms | CLRNet або UFLD |
| BSW (сліпі зони) | < 100ms | YOLOV8s |
| ACC (круїз-контроль) | < 100ms | Глибина + детекція |
| Дорожні знаки | < 200ms | EfficientDet-D2 |
YOLOV8n з TensorRT FP16 на NVIDIA Orin: 3-5ms на кадр. Qualcomm SA8295P (Snapdragon Ride): 8-12ms через QNN SDK.
Монокулярна оцінка глибини
Якщо стерео камери немає, використовуємо MonoDepth2 або DPT (Dense Prediction Transformer). Точність гірша за стерео, але достатня для попереджень:
from transformers import AutoImageProcessor, AutoModelForDepthEstimation
class MonocularDepth:
def __init__(self):
self.processor = AutoImageProcessor.from_pretrained(
"LiheYoung/depth-anything-large-hf"
)
self.model = AutoModelForDepthEstimation.from_pretrained(
"LiheYoung/depth-anything-large-hf"
)
@torch.no_grad()
def estimate(self, image: np.ndarray) -> np.ndarray:
inputs = self.processor(images=image, return_tensors="pt")
outputs = self.model(**inputs)
depth = outputs.predicted_depth.squeeze().numpy()
# Масштабируем в метры через калибровочный коэффициент
return depth
Depth Anything v2 Large дає AbsRel = 0.076 на KITTI — достатньо визначення дистанції до ±10% при 10–30 метрах.
Сертифікація та стандарти
ADAS-системи для серійних автомобілів вимагають відповідності:
- ISO 26262 (Functional Safety, ASIL-B/C для AEB)
- ISO/SAE 21434 (Cybersecurity)
- UNECE R79/R130 (регуляторні вимоги для LDW та AEB)
Для внутрішньоцехового або carport застосування (не public road) вимоги є м'якшими — використовуємо automotive grade без повної ISO 26262 сертифікації.
| Тип проекту | Термін |
|---|---|
| Прототип однієї функції (LDW чи AEB) | 6-10 тижнів |
| Комплекс L2 ADAS (4-6 функцій) | 4-7 місяців |
| Automotive-grade з ISO 26262 | 12–24 місяці |







