企業(yè)網(wǎng)站建設(shè)
介紹關(guān)于軟件開發(fā)v流程的實(shí)施7大步驟解析,如下提供參考,代理開發(fā)隨時(shí)咨詢。
代理免費(fèi)咨詢熱線:15656027219(微信同號)
武漢分公司地址:江夏區(qū)創(chuàng)星匯科技園A棟468室
即日起,注冊臥濤網(wǎng),2024年開始高新技術(shù)企業(yè)認(rèn)定、復(fù)審,十年高企申報(bào)經(jīng)驗(yàn),全國代理統(tǒng)一價(jià)格19800元,更有持續(xù)更新最新各歸口補(bǔ)貼政策,一手政策消息隨時(shí)掌握!
(臥濤科技:項(xiàng)目申報(bào)、知識產(chǎn)權(quán)代理、軟件開發(fā)、商業(yè)計(jì)劃書、工商注冊財(cái)稅規(guī)劃、可行性研究報(bào)告、體系認(rèn)證等。分公司:南京、安慶、蘇州、宿州、武漢)
1.系統(tǒng)需求分析
這部分為系統(tǒng)需求。需要系統(tǒng)工程師完成。
基于項(xiàng)目的整體需求,以及軟硬件整體定義,對系統(tǒng)邏輯架構(gòu)進(jìn)行整體定義,這部分工作包括:硬件功能定義,控制器與其他控制器通信定義,軟件簡要功能定義。這個(gè)過程并不會對具體的技術(shù)實(shí)現(xiàn)做出定義。
通常會使用Doors等流程軟件定義系統(tǒng)需求。
2. 軟件需求分析
這部分為軟件需求,需要系統(tǒng)工程師完成。
系統(tǒng)工程師根據(jù)系統(tǒng)相關(guān)方需求說明書、軟硬件接口文件、變更通知書等輸入,梳理定義軟件研發(fā)需求說明書,包括操作系統(tǒng)需求、電源管理策略、傳感器讀取,執(zhí)行器控制、信號特性需求、存儲服務(wù)、通信服務(wù),網(wǎng)絡(luò)管理、故障診斷、標(biāo)定、程序升級等功能需求和非功能需求。
根據(jù)項(xiàng)目規(guī)劃,制定軟件開發(fā)計(jì)劃。
軟件需求分析建立需求追蹤矩陣,將軟件需求映射到系統(tǒng)需求,確保軟件要實(shí)現(xiàn)的系統(tǒng)需求全部覆蓋,為了完成這個(gè)功能,通常我們也是使用Doors等流程軟件完成。
成功實(shí)施這個(gè)過程的結(jié)果如下:
1) 定義了系統(tǒng)中分配給軟件要素的軟件需求及其接口;
2) 將軟件需求進(jìn)行分類,并分析了其正確性和可驗(yàn)證性;
3) 分析了軟件需求對運(yùn)行環(huán)境的影響;
4) 定義了軟件需求實(shí)現(xiàn)的優(yōu)先級;
5) 根據(jù)需要更新了軟件需求;
6) 在系統(tǒng)需求與軟件需求之間、在系統(tǒng)架構(gòu)設(shè)計(jì)與軟件需求之間建立了一致性和雙向可追溯性;
7) 從成本、進(jìn)度和技術(shù)影響來評估軟件需求;
8) 約定了軟件需求,并與所有受影響方溝通。
3. 軟件架構(gòu)設(shè)計(jì)
這部分為軟件架構(gòu),需要架構(gòu)工程師完成。
為了建立清晰的、結(jié)構(gòu)化的軟件設(shè)計(jì),應(yīng)該統(tǒng)一分配軟件需求,然后完成軟件架構(gòu)設(shè)計(jì)。根據(jù)系統(tǒng)相關(guān)需求、軟硬件接口表、軟件需求確定軟件架構(gòu)。將每條軟件需求合理分配到軟件模塊中,定義每個(gè)軟件模塊的輸入輸出接口、動態(tài)行為、資源消耗目標(biāo)等,評估多種軟件架構(gòu)的優(yōu)缺點(diǎn)等。
架構(gòu)工程師需要使用EA等架構(gòu)軟件畫出整個(gè)控制器軟件所有模塊的輸入輸出接口、以及內(nèi)部動態(tài)行為。
如果項(xiàng)目基于AUTOSAR開發(fā),需要架構(gòu)工程師配置應(yīng)用層的所有組件,并輸出每個(gè)組件的ARXML描述文件。
一般來說,還需要架構(gòu)工程師輸出架構(gòu)文檔。
成功實(shí)施這個(gè)過程的結(jié)果如下:
1) 定義了識別軟件要素的軟件架構(gòu)設(shè)計(jì);
2) 將軟件需求分配給軟件的要素
3) 定義了每個(gè)軟件要素的接口
4) 定義了軟件要素的動態(tài)行為和資源消耗目標(biāo)
5) 建立了軟件需求與軟件架構(gòu)設(shè)計(jì)之間的一致性和雙向可追溯性
6) 約定了軟件架構(gòu)設(shè)計(jì),并與所有受影響方溝通。
4. 軟件單元設(shè)計(jì)和軟件實(shí)現(xiàn)
這部分為軟件單元設(shè)計(jì),需要軟件開發(fā)工程師完成。
在此階段,需要對每個(gè)組件內(nèi)部的算法邏輯進(jìn)行詳細(xì)的內(nèi)部設(shè)計(jì)。組件功能的詳細(xì)設(shè)計(jì)需要與軟件需求建立有效的對應(yīng)關(guān)系。
如果是算法邏輯編碼,建議使用Matlab進(jìn)行模型開發(fā),如果是接近底層的復(fù)雜驅(qū)動,一般是使用手寫代碼。
如果項(xiàng)目使用AUTOSAR架構(gòu),使用模型開發(fā)時(shí)需要導(dǎo)入arxml生成模型框架進(jìn)行開發(fā),使用手寫代碼進(jìn)行開發(fā)時(shí)需要使用AUTOSAR工具生成的組件代碼框架進(jìn)行開發(fā)。
需要將代碼經(jīng)過多次代碼審查和優(yōu)化之后,將最終版本上傳至代碼庫,以實(shí)現(xiàn)最佳的可靠性和性能。
成功實(shí)施這個(gè)過程的結(jié)果如下:
1) 開發(fā)了描述軟件單元的詳細(xì)設(shè)計(jì);
2) 定義了各軟件單元的接口;
3) 定義了軟件單元的動態(tài)行為;
4) 建立了軟件需求與軟件單元之間的一致性和雙向可追溯性;建立了軟件架構(gòu)設(shè)計(jì)與軟件詳細(xì)設(shè)計(jì)之間的一致性和雙向可追溯性;建立了軟件詳細(xì)設(shè)計(jì)與軟件單元之間一致性和雙向可追溯性;
5) 約定了軟件詳細(xì)設(shè)計(jì)及該設(shè)計(jì)與軟件架構(gòu)設(shè)計(jì)的關(guān)系,并和所有受影響
方溝通;
6) 生成了軟件詳細(xì)設(shè)計(jì)所定義的軟件單元。
6. 軟件單元測試
當(dāng)進(jìn)行單元測試通過后,將會將軟件編譯成ECU可執(zhí)行的文件,比如Hex格式的文件,將其刷寫到ECU進(jìn)行集成測試(或稱HIL測試),如果只是測試底層軟件,那么一般只需要額外的硬件負(fù)載箱支持就行,比如用負(fù)載箱來模擬一些傳感器信號輸入,或制造一些執(zhí)行器的短路和開路故障;如果測試包括應(yīng)用層軟件,那么就還需要物理模型支持才行,比如電機(jī)控制就需要電機(jī)的物理模型,變速箱控制可能就需要整個(gè)動力傳動系統(tǒng)的模型才行。
這部分為組件單元測試,一般需要軟件開發(fā)工程師完成,也可以讓測試工程師完成。
單元測試與軟件單元設(shè)計(jì)對應(yīng)。
單元測試是根據(jù)軟件單元設(shè)計(jì),進(jìn)行代碼級別上進(jìn)行的測試。
單元測試一般可以通過Matlab和Tessy等工具進(jìn)行。
成功實(shí)施這個(gè)過程的結(jié)果如下:
1) 制訂了包括回歸策略在內(nèi)的軟件單元驗(yàn)證策略,以驗(yàn)證軟件單元;
2) 根據(jù)軟件單元驗(yàn)證策略,制訂了軟件單元驗(yàn)證準(zhǔn)則,以適于提供軟件單元符合軟件詳細(xì)設(shè)計(jì)及非功能性軟件需求的證據(jù);
3) 根據(jù)軟件單元驗(yàn)證策略及軟件單元驗(yàn)證準(zhǔn)則,驗(yàn)證了軟件單元并記錄了結(jié)果;
4) 建立了軟件單元、驗(yàn)證準(zhǔn)則及驗(yàn)證結(jié)果之間的雙向可追溯性和一致性;
5) 總結(jié)了單元驗(yàn)證結(jié)果,并與所有受影響方溝通。
7. 軟件集成測試
這部分為集成測試,需要測試工程師完成。
集成測試與軟件需求對應(yīng)。
集成測試將各個(gè)組成部分整合入一個(gè)軟件系統(tǒng)中之后,最后進(jìn)行軟件的集成測試。根據(jù)定義的需求,測試相應(yīng)的功能是否滿足軟件需求。
成功實(shí)施本過程的結(jié)果如下:
1) 制訂了與項(xiàng)目計(jì)劃、發(fā)布計(jì)劃和軟件架構(gòu)設(shè)計(jì)相一致的軟件集成策略,以集成軟件項(xiàng);
2) 制訂了包括軟件回歸測試策略在內(nèi)的軟件集成測試策略,以測試軟件單元之間和軟件項(xiàng)之間的交互;
3) 根據(jù)軟件集成測試策略,開發(fā)了軟件集成測試規(guī)范,以適于提供集成的軟件項(xiàng)符合軟件架構(gòu)設(shè)計(jì)(包括軟件單元之間和軟件項(xiàng)之間的接口)的證據(jù);
4) 根據(jù)集成策略集成了軟件單元和軟件項(xiàng)直至完整的集成軟件;
5) 根據(jù)軟件集成測試策略和發(fā)布計(jì)劃,選擇了軟件集成測試規(guī)范中的測試用例;
6) 使用選定的測試用例測試了集成的軟件項(xiàng),并記錄了測試結(jié)果;
7) 建立了軟件架構(gòu)設(shè)計(jì)要素與軟件集成測試規(guī)范中的測試用例之間的一致性和雙向可追溯性,并建立了測試用例與測試結(jié)果之間的一致性和雙向可追溯性;
8) 總結(jié)了軟件集成測試結(jié)果,并與所有受影響方溝通。
8. 軟件系統(tǒng)測試
這部分為系統(tǒng)測試,需要測試工程師完成。
系統(tǒng)測試與系統(tǒng)需求對應(yīng)。
因?yàn)檐浖o各個(gè)ECU提供了相應(yīng)的功能,因此在集成測試中,需要將軟件燒錄至硬件中。然后ECU要與其他電子系統(tǒng)組件集成起來,比如傳感器和執(zhí)行器。在接下來的系統(tǒng)綜合測試中,對所有系統(tǒng)設(shè)備的交互響應(yīng)進(jìn)行評估。