使用 MATLAB 和 Simulink 設(shè)計(jì)和構(gòu)建 Rivian 車輛仿真界面平臺(tái)幫助我們實(shí)現(xiàn)了關(guān)鍵目標(biāo)。我們?yōu)?a class="article-link" target="_blank" href="/tag/%E5%B7%A5%E7%A8%8B%E5%B8%88/">工程師和非工程師創(chuàng)建了統(tǒng)一平臺(tái),用于運(yùn)行整車仿真、后處理結(jié)果和創(chuàng)建報(bào)告。
整個(gè)汽車行業(yè)的工程師越來越依賴仿真來評估操控性能、加速性能、續(xù)航里程和其他關(guān)鍵性能指標(biāo)。與物理測試相比,通過仿真來評估車輛性能速度更快,成本也更低。整車仿真還有助于設(shè)計(jì)工作在原型硬件可用之前在開發(fā)過程中盡早進(jìn)行。然而,隨著車輛仿真的成本和效率優(yōu)勢在組織內(nèi)日趨明顯,仿真需求的增加使得車輛仿真面臨一系列挑戰(zhàn)。
考慮到與商業(yè)仿真軟件對接和運(yùn)行整車仿真所帶來的復(fù)雜性,需要擁有一支專門的仿真工程師團(tuán)隊(duì),他們具備必要的專業(yè)知識。然而,該團(tuán)隊(duì)可能很快會(huì)因各利益相關(guān)者的要求而不堪重負(fù),這些利益相關(guān)者包括屬性工程師、性能工程師、動(dòng)力學(xué)工程師、續(xù)航里程和效率工程師以及高級管理人員。簡單地執(zhí)行這些團(tuán)隊(duì)要求的多個(gè)仿真也可能成為瓶頸,特別是當(dāng)這些仿真連續(xù)地在商業(yè)軟件上運(yùn)行時(shí)更是如此。最后,由于缺乏標(biāo)準(zhǔn)化的車輛數(shù)據(jù),加上對仿真結(jié)果的臨時(shí)后處理,這使得工程師爭相獲取黃金源數(shù)據(jù)和采用獲準(zhǔn)的方法來報(bào)告結(jié)果,從而加劇了這些困難。
在 Rivian,我們的團(tuán)隊(duì)開發(fā)了可擴(kuò)展、易于使用的平臺(tái),用于配置、運(yùn)行和后處理大量整車仿真。此車輛仿真界面(VSI)平臺(tái)是使用 MATLAB? 和 Simulink? 開發(fā)的,有助于減少冗余,提高復(fù)用性,并通過并行處理提高仿真吞吐量。借助使用 App 設(shè)計(jì)工具構(gòu)建的直觀用戶界面,該平臺(tái)還讓整個(gè)公司的工程團(tuán)隊(duì)都能輕松實(shí)現(xiàn)仿真,從而消除了仿真請求瓶頸(圖 1)。
圖 1.VSI 用戶界面。
本文介紹我們?nèi)绾问褂妹嫦驅(qū)ο蟮脑瓌t設(shè)計(jì) VSI,如何利用它來使仿真更平等普及,以及如何使用并行處理來擴(kuò)展仿真工作量。
VSI 的面向?qū)ο蟮脑O(shè)計(jì)
當(dāng)我們開始設(shè)計(jì) VSI 平臺(tái)時(shí),面向?qū)ο蟮姆椒@然是實(shí)現(xiàn)靈活性、可擴(kuò)展性和復(fù)用性等目標(biāo)的最直接方法。我們首先明確定義了幾個(gè)基本對象:Vehicle、Load Case 和 Simulation。在這種情形下,Vehicle 對象用于表示 Rivian 車輛,例如 Rivian R1T、Rivian R1S 或 Rivian EDV(我們的電動(dòng)貨車)。此對象還表示車輛的配置,用于定義特定的電池組、動(dòng)力總成系統(tǒng)、輪胎、前后驅(qū)動(dòng)裝置和其他組件。Load Case 對象用于定義仿真場景,包括速度曲線、環(huán)境條件和駕駛工況。而 VSI Simulation 對象只是 Vehicle 實(shí)例與特定 Load Case 的組合(圖 2)。
圖 2.VSI 仿真包括特定車輛配置和預(yù)定義的測試場景。
從編程的角度來看,可將 Simulation 的概念視為構(gòu)成 VSI 平臺(tái)基礎(chǔ)框架的超類。此超類的屬性包括可以通過用戶界面選擇的車輛配置和測試場景屬性,以及一組用于創(chuàng)建模型、運(yùn)行仿真、執(zhí)行后處理、提取度量和共享結(jié)果的方法(圖 3)。借助 MATLAB 的面向?qū)ο蟮木幊坦δ埽覀兛梢暂p松地針對 VSI 平臺(tái)創(chuàng)建這種類結(jié)構(gòu)體的實(shí)現(xiàn)。MATLAB 句柄對象尤其適用于封裝仿真中包含的所有信息(不僅包括車輛和測試場景,還包括用戶設(shè)置、結(jié)果和度量),并在 VSI 內(nèi)高效傳輸這些信息,而無需復(fù)制數(shù)據(jù)。這些對象隨后可以轉(zhuǎn)換為元數(shù)據(jù)文本文件并進(jìn)行存檔,使我們能夠通過從元數(shù)據(jù)重新構(gòu)造對象來重新創(chuàng)建任何歷史仿真。
圖 3.VSISim 超類,包括仿真輸入和執(zhí)行方法。
使仿真更平等普及和最大化復(fù)用
我們已將 VSI 部署為 MATLAB 工具箱和獨(dú)立可執(zhí)行文件(用 MATLAB Compiler? 編譯),可供未安裝 MATLAB 的同事使用。由于可以輕松訪問 VSI,團(tuán)隊(duì)不再需要等待 Simulink 工程師來運(yùn)行仿真并獲得結(jié)果。
VSI 界面的左側(cè)(如圖 1 所示)用于選擇車輛配置和測試場景,而界面的右側(cè)顯示用不同顏色表示的仿真列表。紅色表示尚未運(yùn)行的仿真,綠色表示已完成的仿真,琥珀色表示已完成的仿真以及過期結(jié)果(例如,當(dāng)新組件數(shù)據(jù)可用或模型修訂時(shí),可能會(huì)發(fā)生這種情況)。值得注意的是,VSI 的仿真結(jié)果是共享的;工程師可能會(huì)發(fā)現(xiàn)他們要運(yùn)行的仿真已由本團(tuán)隊(duì)或完全不同的團(tuán)隊(duì)中的某個(gè)人完成。工程師可以利用已有的仿真結(jié)果,避免運(yùn)行相同且不必要的仿真,從而節(jié)省時(shí)間和計(jì)算資源。
在定義并選擇了要運(yùn)行的仿真后,工程師可點(diǎn)擊標(biāo)有 Run&Post-Process 的按鈕(如圖 1 所示)。仿真是結(jié)合使用 Simulink 和商業(yè)仿真軟件在后臺(tái)通過 MATLAB API 啟動(dòng)的(圖 4)。
圖 4.集群仿真的工作流程圖,以及顯示五個(gè)調(diào)度仿真的 VSI 界面(以藍(lán)色突出顯示)。紫色狀態(tài)表示仿真正在進(jìn)行中;紅色狀態(tài)則表示仿真已完成。
在單個(gè)仿真完成后,記錄的數(shù)據(jù)會(huì)發(fā)送回 MATLAB 工作區(qū)進(jìn)行處理,然后轉(zhuǎn)換為 Apache? Parquet 數(shù)據(jù)文件格式,并最終存檔在共享目錄中。我們還開發(fā)了一套 MATLAB 腳本,用于匯總結(jié)果以生成關(guān)鍵度量,根據(jù)我們的需求管理系統(tǒng)中設(shè)置的目標(biāo)報(bào)告仿真狀態(tài),并生成自動(dòng)報(bào)告來概括關(guān)鍵性能指標(biāo),以供 Rivian 高級管理層參考。
通過并行處理實(shí)現(xiàn)擴(kuò)展
在 VSI 用戶界面中,工程師可以選擇使用本地計(jì)算機(jī)上的多個(gè)內(nèi)核來并行運(yùn)行仿真,也可以選擇使用遠(yuǎn)程 Amazon? Web Services(AWS?)集群來執(zhí)行此操作(圖 5)。本地方法利用了 Parallel Computing Toolbox?,它是工程師在測試模型更新和更改時(shí)最常選用的方法。遠(yuǎn)程方法基于運(yùn)行 MATLAB Parallel Server? 的 AWS EC2 實(shí)例,適用于具有已經(jīng)過測試和驗(yàn)證的模型的生產(chǎn)環(huán)境。
圖 5.用于并行處理的 VSI 選項(xiàng)。
在遠(yuǎn)程并行工作流中,MATLAB Parallel Server 和 MATLAB 作業(yè)調(diào)度器發(fā)揮著重要作用。VSI 先從 MATLAB Parallel Server 調(diào)用 parcluster 函數(shù),以根據(jù)我們所定義的 AWS EC2 配置文件創(chuàng)建一個(gè)集群對象。在為要并行運(yùn)行的每個(gè)仿真創(chuàng)建了一個(gè)仿真對象后,VSI 將在集群上創(chuàng)建一個(gè)作業(yè),并為每個(gè)仿真創(chuàng)建一個(gè)單獨(dú)的任務(wù)。該作業(yè)及其任務(wù)通過 MATLAB 作業(yè)調(diào)度器提交到 AWS EC2 實(shí)例。該調(diào)度器可協(xié)調(diào)作業(yè)的執(zhí)行,并將任務(wù)分配給各個(gè)集群工作進(jìn)程。當(dāng)仿真完成時(shí),MATLAB 后處理函數(shù)會(huì)在集群上運(yùn)行,然后結(jié)果再進(jìn)行存檔和共享。對于大型作業(yè),例如涉及 14 個(gè)冗長仿真的作業(yè),遠(yuǎn)程并行方法要快得多,在 68 分鐘內(nèi)即可完成作業(yè),而依序方法需要 9 個(gè)多小時(shí)(圖 6)。
圖 6.依序(黃色)、本地并行(藍(lán)色)和遠(yuǎn)程并行(紅色)方法的基準(zhǔn)仿真時(shí)間。
在過去的六個(gè)月里,我們在 Rivian 的同事已使用 VSI 進(jìn)行了 9,000 多次整車仿真,總共模擬行駛了大約 200 萬英里。
計(jì)劃的改進(jìn)
使用 MATLAB 和 Simulink 設(shè)計(jì)和構(gòu)建 VSI 平臺(tái)幫助我們實(shí)現(xiàn)了關(guān)鍵目標(biāo)。我們?yōu)楣こ處熀头枪こ處焺?chuàng)建了統(tǒng)一平臺(tái),用于運(yùn)行整車仿真、后處理結(jié)果和創(chuàng)建報(bào)告。我們消除了仿真請求瓶頸,減少了仿真任務(wù)中的冗余,并提高了仿真復(fù)用性。此外,我們還通過支持在 AWS 集群或本地工作站的多個(gè)內(nèi)核上并行運(yùn)行仿真,最大程度地提高了吞吐量。
我們計(jì)劃對 VSI 做出大量改進(jìn),包括將該平臺(tái)部署為 Web 應(yīng)用,為關(guān)鍵性能指標(biāo)添加儀表板,以及簡化從用戶界面使用試驗(yàn)設(shè)計(jì)(DOE)的過程。與此同時(shí),我們還在繼續(xù)開發(fā)和擴(kuò)展 Rivian 的 MATLAB Minimart,這是內(nèi)部構(gòu)建的 MATLAB 工具箱集合,用于數(shù)據(jù)轉(zhuǎn)換和查看、啟動(dòng)和制動(dòng)分析,以及各種其他經(jīng)常需要的功能。