橫穿自動駕駛

如果有一條線,可以穿起來所有自動駕駛的核心模塊,那么我感覺它就是最優化,選擇優化變量、構造優化問題、求解優化問題,這幾個步驟貫穿了自動駕駛的始終。

先從我的自身接觸順序寫起。最開始做個一點深度學習,那還是2016年,深度學習已經飛速發展了4年左右,各種方法層出不窮。有幸看了李飛飛的深度學習課,AK大神講的大部分內容,手寫了一個網絡,了解深度學習就是構造并求解一個優化問題,了解了BP,了解了隨機梯度下降,帶動量的梯度下降,等等一系列優化問題求解方法。

學校里課題選了一個機器人機械臂作業方向,用到了一些圖像處理手段包括識別和跟蹤,了解了kalman filter, particle filter都可以用來做圖像固定片段的跟蹤。

后來工作之后做自動駕駛控制問題。了解了kalman filter, 知道了它是求解一個優化問題,可以用來平滑信號。后來從pid一路了解到LQR MPC,知道了LQRMPC都是最優控制里的一種方法,其本身也是構造優化問題,求解優化問題。

到這里其實我已經開始有點疑惑,為什么自動駕駛從上游感知到下游控制都有kalman filter, 都是構建優化問題,求解優化問題,這些優化問題之間有什么區別和聯系呢?當時試圖學習一些Boyd的凸優化課程,發現根本看不懂,當然現在看懂的可能性也不大。

后面換了工作,做了一陣子激光雷達定位。發現里面更全都是優化問題構造和求解,點云匹配是,前端里程計用的都是XXKF,eskf, ekf ,iekf, iesekf等等。后端里也是構造位姿優化問題。不過是直接利用求解器,過去10年,出現ceres, g2o, gtsam, sesync等等大規模位姿圖優化求解器。

后來做過一陣子決策規劃。看過一遍APOLLO,發現里面也都是優化問題求解,比如平滑路線是構造QP問題,局部軌跡規劃也是構造QP問題。后來寫了一陣子狀態機if-else,覺得沒有什么意思。于是看了一下強化學習的東西,發現核心也是優化問題的構造和求解。

我的疑惑更多了,從最開始的kalman filter 為什么從感知到控制都能用,到后面發現定位也都在用,也發現LQR MPC可以放在底層的控制階段用,也可以放在規劃用,現在很多決策博弈過程本質上也是優化問題求解過程。到DDP iLQR MPC等等從某種程度上也是強化學習。到Kalman filter和LQR的對偶性,等等。

從我接觸的東西,最后我得出了前面的結論如果有一條線,可以穿起來自動駕駛的核心模塊,那就是最優化。這個結論我自己是非常喜歡的,因為我通過實踐和總結,仿佛發現了什么了不得的東西。

后面會有一系列大雜燴,總結一下這10年來遇到的所有優化問題。順便做一些讀書筆記,看看有沒有更好玩的東西。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/38144.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/38144.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/38144.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

編碼大模型系列:Meta創新的“代碼編譯優化”的LLM

魯班號導讀正式上線。移步“魯班秘笈”,查閱更多內容。 大型語言模型 (LLM) 已在各種軟件工程和編碼任務中展現出卓越的能力。然而,它們在代碼和編譯器優化領域的應用仍未得到充分探索。訓練LLM需要大量資源,需要大量的 GPU時間和大量的數據…

23、架構-服務網格之透明通信涅槃

通信成本 在現代分布式系統中,服務之間的通信是不可避免的。然而,這種通信帶來了額外的復雜性和成本。傳統的通信方式如RPC(Remote Procedure Call)和REST(Representational State Transfer),雖…

Hive 實操案例五:統計每個類別中 Top10 的視頻熱度

一、數據表結構 視頻表 t_video 字段注釋描述videoId視頻唯一 id(String)11 位字符串uploader視頻上傳者(String)上傳視頻的用戶名 Stringage視頻年齡(int)視頻在平臺上的整數天category視頻類別&#xff0…

一個合理的前端應用文件結構

在大型應用中,最關鍵且最具挑戰性的方面之一就是擁有一個良好且合理的文件結構。在考慮通過微前端將代碼庫拆分成多個應用之前,可以遵循一些步驟來改善項目級別的架構,并在您考慮這一路徑時使過渡更容易。 我們的目標是應用某種模塊化方法&am…

MSPM0G3507——定時器例程講解4——timx_timer_mode_periodic

以下示例以周期模式配置TimerG并切換LED。周期從500ms開始,每次切換減少50ms,直到周期為100ms,然后重復。設備在等待中斷時保持待機模式 #include "ti_msp_dl_config.h"/* ((32KHz / (321)) * 0.5s) 45 - 1 495 due to N1 ticks …

MySQL入門學習-MySQL日志.錯誤日志

錯誤日志是 MySQL 中一種記錄服務器運行過程中錯誤信息的日志文件。它可以幫助管理員或開發人員快速定位和解決問題。 一、MySQL 中的錯誤日志具有以下特點: - 記錄錯誤信息: 錯誤日志主要記錄服務器在運行過程中發生的錯誤信息,包括但不限…

【算法 之選擇排序 原理及案例】

選擇排序(Selection Sort) 是一種簡單直觀的排序算法。它的工作原理是:首先在未排序序列中找到最小(或最大)元素,存放到排序序列的起始位置,然后,再從剩余未排序元素中繼續尋找最小…

Memcached的API使用指南:常用操作與示例代碼

Memcached 是一個高性能、分布式內存對象緩存系統,常用于加速動態Web應用程序,減輕數據庫負載。本文將介紹如何使用Memcached的API進行常用操作,并提供示例代碼。 1. 安裝Memcached客戶端庫 在使用Memcached之前,需要安裝相應的…

Qt中用QLabel創建狀態燈

首先ui設計中分別創建了4個大燈和4個小燈。 編輯.h文件 #ifndef LED_H #define LED_H#include <QWidget> #include <QLabel>QT_BEGIN_NAMESPACE namespace Ui { class Led; } QT_END_NAMESPACEclass Led : public QWidget {Q_OBJECTpublic:Led(QWidget *parent n…

Spring MVC數據綁定和響應——復雜數據綁定(四)JSON數據綁定

一、消息轉換器—HttpMessageConverter接口 客戶端不同的請求&#xff0c;HttpServletRequest中數據的MediaType可能會不同&#xff0c;如果想將HttpServletRequest中的數據轉換成指定對象&#xff0c;或者將對象轉換成指定格式的數據&#xff0c;就需要使用對應的消息轉換器來…

服務器硬件以及RAID配置

目錄 一、RAID磁盤陣列原理&#xff08;嘎嘎重要&#xff09; 1、RAID的概述 2、常用的RAID 2.1、RAID 0 2.2、RAID 1 2.3、RAID 5 2.5、RAID 10 3、陣列卡介紹 二、建立軟件RAID磁盤陣列 1、添加硬盤 2、使用fdisk分區&#xff0c;類型為fd 3、mdata命令使用參數 …

安全與加密常識(3)什么是數字簽名和數字證書

文章目錄 數字簽名工作原理關鍵特點應用實例 數字證書數字證書和數字簽名趣味實例 數字簽名 數字簽名是一種通過密碼運算生成的數據&#xff0c;用于驗證信息的完整性和來源&#xff0c;確保數據在傳輸過程中未被篡改&#xff0c;同時提供發送者的身份認證和防止抵賴的功能。它…

Qt: QPushButton 按鈕實現 上圖標下文字

效果如下&#xff1a; 實現有如下幾種方式&#xff1a; 1. 使用 QPushButton 設置 setStyleSheet 例&#xff1a; ui->recorder->setStyleSheet("QPushButton{"\"border: 1px solid #00d2ff; "\"min-height: 60px; "\"col…

python多繼承的3C算法

python多繼承的3C算法 有很多地方都說python多繼承的繼承順序&#xff0c;是按照深度遍歷的方式&#xff0c;其實python多繼承順序的算法&#xff0c;不是嚴格意義上的深度遍歷&#xff0c;而是基于深度遍歷基礎上優化出一種叫3C算法 python多繼承的深度遍歷 class C:def ru…

MySQL高級-MVCC-原理分析(RR級別)

文章目錄 1、RR隔離級別下&#xff0c;僅在事務中第一次執行快照讀時生成ReadView&#xff0c;后續復用該ReadView2、總結 1、RR隔離級別下&#xff0c;僅在事務中第一次執行快照讀時生成ReadView&#xff0c;后續復用該ReadView 而RR 是可重復讀&#xff0c;在一個事務中&…

Django 配置靜態文件

1&#xff0c;DebugTrue 調試模式 Test/Test/settings.py DEBUG True...STATICFILES_DIRS [os.path.join(BASE_DIR, static),] STATIC_URL /static/ 1.1 創建靜態文件 Test/static/6/images/Sni1.png 1.2 添加視圖函數 Test/app6/views.py from django.shortcuts impor…

uniapp,uni-fab組件拖動屬性,替代方案

文章目錄 1. 背景2. 替代方案2.1 方案一2.2 方案二 參考 1. 背景 最近基于uniapp開發一款設備參數調試的APP軟件&#xff0c;其中有使用到懸浮按鈕&#xff0c;快速開發階段&#xff0c;為了能盡快上線&#xff0c;直接使用了uni-ui的擴展組件uni-fab&#xff0c;參考【1】&am…

C++ 設計模式之迭代器模式

C 設計模式之迭代器模式 簡介 1、迭代器模式&#xff08;Iterator&#xff09;是一種行為型設計模式&#xff0c;它允許我們順序訪問一個聚合對象中的各個元素&#xff0c;而又不暴露該對象的內部表示。迭代器模式提供了一種方法來遍歷容器&#xff08;容器對象&#xff0c;如…

Configure C/C++ debugging

Configure C/C debugging launch.json 文件用于在 Visual Studio Code 中配置調試器。 Visual Studio Code 會生成一個 launch.json (位于項目的 .vscode 文件夾下),其中幾乎包含了所有必需的信息。要開始調試,您需要填寫 program 字段,指定要調試的可執行文件的路徑。這必須…

如何通過流式渲染提升用戶體驗?

什么是流式渲染&#xff1f; 流式渲染的核心理念是將 HTML 文檔分割成小塊&#xff08;chunk&#xff09;&#xff0c;并逐步地發送給客戶端&#xff0c;而非等待整個頁面完整生成后再進行傳輸。這種方式能夠極大地提升用戶的初始加載體驗&#xff0c;特別是在網絡條件不佳或者…