IntelliJ IDEA下开发FPGA——FPGA开发体验提升__下

news2025/4/17 17:22:38

前言

        由于Quartus写代码比较费劲,虽然新版已经有了代码补全,但体验上还有所欠缺。于是使用VS Code开发,效果如下所示,代码样式和基本的代码补全已经可以满足开发,其余工作则交由Quartus完成

        但VS Code的自带的git功能,说实话并不好用,只能查看更改的,需要手动展开才能浏览全局代码。而合并过程,辨识度并不是很高,容易造成重复代码

        分支方面并不清晰,虽然提供了多种视图

        基于此,打算使用CLion试试。在官网上恰好看到了对应的插件,那么也就意味着此法可行。不过官方这个插件似乎还不支持所安装的CLion

一、安装插件

        于是打算换成IntelliJ IDEA。下图中的第一个插件与VS Code下的差不多,有基本的代码补全功能,可以满足基本的Verilog开发。第三个插件有不少Verilog相关的代码检查等功能。

        需要注意的是,后者与其他Verilog插件可能不兼容,所以需要作出取舍。此处使用后者,前者需要禁用,否则工程目录会一直处在正在加载

        这个牛掰的插件,同时也是开源项目。

教程文档:Scaleda:将 IntelliJ IDEA 打造为 FPGA 开发工具 — Scaleda v0.2.1 文档

手册:快速开始 — Scaleda v0.2.1 文档

二、创建新项目

1,创建工程

新建项目,指定好路径,路径不能有中文。下图这个Scaleda图标表明插件不兼容

图标实际应为

创建后会自动生成下面文件

2,新建文件

①新建Verilog文件

新建后,会自动生成对应框架

先写一个简单的计数器模块,在强大的代码补全和代码提示下,很轻松地完成了

module demo (
input clk,
input reset,
output reg [7:0] count
);
always @(posedge clk) begin
    if (reset)
        count <= 8'h00;
    else
        count <= count + 1;
end

endmodule

②新建Testbench文件

先简单写一个测试激励文件

`timescale 1ns / 1ps

module demo_tb;
    // 信号声明
    reg clk;
    reg reset;
    wire [7:0] count;

    // 实例化被测模块
    demo dut (
        .clk  (clk),
        .reset(reset),
        .count(count)
    );

    // 时钟生成(50MHz)
    initial begin
        clk = 0;
        forever #10 clk = ~clk;  // 10ns半周期
    end

    // 测试流程控制
    initial begin
        reset = 1'b1;  // 初始复位
        #100;  // 保持100ns
        reset = 1'b0;  // 释放复位

        // 监控信号变化
        $monitor("Time=%0t: count=%d", $time, count);

        // 运行16个时钟周期
        repeat (16) @(posedge clk);

        // 验证最终值(预期255+16会溢出)
//        if (count !== 8'd15) begin
//            $error("Final count mismatch! Expected 15, got %d", count);
//        end

        $finish;
    end

//    这段语句会自动生成,所以不用加
//    // VCD波形记录
//    initial begin
//    $dumpfile("demo_tb_waveform.vcd");
//    $dumpvars;    // 记录测试台顶层信号
//    end
endmodule

③格式化文件

        从上图可以看出,有很多警告表示应用Tab代替空格。

可以先按Ctrl + A全选,然后再按Ctrl + Alt + L 格式化代码

④代码检查

        代码出现问题,不仅会有报错提示,还有对应的解决措施,成功地把编写代码的难度降低一大截

3,基本功能

①语言服务器

        在设置中可以找到该插件的相关配置,首先是如图的语言服务器(LSP),提供代码检查等功能

        Verible是检测Verilog的,svls则是检测System Verilog

        手册中亦有记载

②代码样式

③配色方案

4,添加工具链

①Intel Quartus

        由于本人使用的是Quartus,所以添加的是Quartus的工具链,Vivado等在手册中有相关配置教程

点击添加,会有多个工具链模板,选择最后一个Intel Quartus

在Quartus的安装路径中找到bin64这个路径即可

②Icarus Verilog

        Intel Quartus是FPGA的综合和实现工具,而Icarus Verilog是开源仿真器,主要用于验证HDL代码

下载

                 进入网址Icarus Verilog for Windows,然后选择对应版本下载,比如最新版

安装

        选择合适的目录即可

        可以选择添加环境变量,环境变量若想生效,需要重启(此时可以不重启)

安装完成后就可以添加该工具链了,由于已经包含了所需的三个程序,故路径非常简单。但要注意,此时需要指向程序,而非目录

5,添加仿真配置

①添加目标平台

        点击右上角的任务视图

        再点击编辑任务

        然后点击“+”,会出现一个目标平台,选择对应的目标名称、工具链和顶层模块

        顶层模块,这里应添demo,而非demo_tb。约束文件暂时不管

②添加仿真任务

        点击目标平台后,再点击这个目标平台,然后点击“+”来添加仿真项目。注意!是仿真任务,所以使用的工具链是Icarus Verilog这个开源工具链

③刷新

        回到任务视图,点击刷新

可以看到对应配置都刷新出来了,这里方括号的显示与前面不一致,应该是个小bug

6,运行

        双击运行可以看到有正确的输出提示

        尴尬的是,没有产生手册中的波形图

设置波形

        回到设置里咱去看看怎么个事。可以看到前面两个选项勾选很正常,但波形处理这块应该没有生效

点开后,可以看到三个选项,其中gtkwave我们在iverilog的目录里看到过,那么就选择它吧

gtkwave

        双击任务视图里的仿真任务,或者点击上面的运行,效果相同

        此时,会弹出一个新窗口(老窗口)

点击SST栏里的demo_tb,可以将其展开,其下方栏也会有相应信息

点击这些信号,Signals那一栏就会出现相应信号,Waves下则出现对应波形

缩放一下,有那么一点韵味了

Surfer

        与前面相同,在设置里选择即可,点击运行后,可以弹出这样一个窗口。不得不说,这个背景色调相当有吸引力

Rvcd(未解决)

        虽然插件里提到,Rvcd和Surfer是内置的,不过实际运行仿真任务时Rvcd却没有任何窗口,可能是我姿势不对?

        应该是插件错误导致的

7、曲线救Rvcd(失败)

        找到Rvcd项目(非常棒的项目),Scaleda/rvcd: VCD viewer in Rust, running on ANY platform

        不过,我们并不需要下载Rust编译器。到设置里,我们可以看到LSP的可执行路径,那么我们就前往这个路径

在bin这里,可以找到我们想要的文件

双击运行

找到我们项目下的仿真波形文件

然后什么都没发生,疑似程序崩溃。那么根据README提示,使用命令行来完成操作(路径需自行替换)

.\rvcd -i "E:\Program\Embedded\FPGA\demo\.sim\demo-iverilog-sim\demo_tb_waveform.vcd"

        刚才当我没说,Rust编译器还是得下,下载是基本功,这里不啰嗦了。下载Rvcd源码压缩包后,执行下面命令进行编译

# run rvcd
cargo run
# compile to release executable
cargo build --release

三、综合Quartus项目

1,迁移

 把前面工程下的scaleda.yml复制到Quartus的旧工程里

然后右键工程文件夹,使用IDEA打开

        接着修改配置即可,如果配置不生效,那么就重启IDEA。可以选择在任务视图里修改,也就是图形化操作

        该插件对System Verilog的支持有限,建议文件后缀名为.v,使用Verilog

2,原理

        接下来是对项目进行综合,不知道为什么,这个插件Quartus的综合项目时只会卡着,什么反应都没有

        不过综合这一步终归是利用Quartus的工具,自己手动配置也没多麻烦。于是在Quartus里运行一下,进行综合。

        然后再根据输出信息框筛选出命令,可以看到它执行了下面的五条命令,我们只需要把这些命令添加到外部工具即可

        打开设置,找到外部工具,点击“+”添加外部工具

可以输入下面信息

        这些信息怎么来的呢?前面在输出信息框里,我们先找第一条命令

Info: Command: quartus_map --read_settings_files=on --write_settings_files=off Firefly -c Firefly

        “Command:”后面的内容其实就是终端里执行的命令,quartus_map就是可执行程序,后面则是它需要的参数,也就是实参

        而这个程序在哪呢?它在Quartus安装目录下的quartus/bin64目录,此目录就是Intel Quartus的工具链路径。因此程序一栏添该程序的完整执行路径即可

        我们需要编译(综合)本工程,那么工作目录自然是当前目录(项目根目录)

        

        剩下的外部工具皆是如此配置,幸运的是工作目录和实参都差不多,只有程序名称不同。不过这种方法有些劣质,如果是不同的工程,那么工作目录就需要重新改了

2,powershell目标

        为此,干脆写一个powershell脚本,创建一个powershell目标,进行一键综合。

        点击添加目标,选择Shell Script

        接下来找一个目录存放脚本

        可根据自己的情况更改

# 设置程序路径
$QUARTUS_BIN = "E:\Tools\Develop\Embedded\intelFPGA\quartus\bin64"
# 设置项目名
$PROJECT_NAME = "Firefly"
# 设置工作目录
$WORK_DIR = "E:/Program/Embedded/FPGA/Firefly"

# 初始化环境
$env:PATH = "$QUARTUS_BIN;$env:PATH"
Set-Location $WORK_DIR

# 执行流程
$commands = @(
    "quartus_map --read_settings_files=on --write_settings_files=off $PROJECT_NAME -c $PROJECT_NAME",
    "quartus_fit --read_settings_files=off --write_settings_files=off $PROJECT_NAME -c $PROJECT_NAME",
    "quartus_asm --read_settings_files=off --write_settings_files=off $PROJECT_NAME -c $PROJECT_NAME",
    "quartus_sta $PROJECT_NAME -c $PROJECT_NAME",
    "quartus_eda --read_settings_files=off --write_settings_files=off $PROJECT_NAME -c $PROJECT_NAME"
)

foreach ($cmd in $commands) {
    Write-Host "Run: $cmd" -ForegroundColor Cyan
    Invoke-Expression $cmd
    if ($LASTEXITCODE -ne 0) {
        Write-Host "[Error] $LASTEXITCODE" -ForegroundColor Red
        exit $LASTEXITCODE
    }
}



此时在目标里填上脚本路径,把解释器路径清空

执行目标后,输出结果与Quartus相同,除了最后一条总结外

这里只是提供了一种可行性的方案,进行综合还是要到Quartus里。至于烧录等操作,则同理

3,编写项目(重要)

        如果以前有项目时要非常注意,该插件对System Verilog的支持有些问题。试过许多次,最后发现,代码里不能出现中文等非ASCII字符,否则打开即崩。但它对V文件相当宽容

        这就有些难办了,既想使用System Verilog,又不能写中文注释

[Crash] Verible LSP fails to open .sv files with non-ASCII characters (e.g. Chinese comments) in IntelliJ IDEA

        考虑到Verilog下的代码提示和代码样式明显更好,Verilog就Verilog吧

4,仿真

        该插件对仿真的支持可谓差的一塌糊涂,主要是无法对sv文件进行仿真,如$sin、real、break等常见特性根本用不了。这个有空看看有没有平替或者次替

ModelSim(GUI)

        与前面综合一致,仿真时,在Quartus的输出信息框里找命令。可以看到在打开ModelSim后,输出框里有这样一条信息

而括号内的就是我们需要的命令

quartus_sh -t "e:/tools/develop/embedded/intelfpga/quartus/common/tcl/internal/nativelink/qnativesim.tcl" --rtl_sim "Firefly" "Firefly"

由于命令比较简单,改为脚本文本,同时加上quartus_sh的路径

E:\Tools\Develop\Embedded\intelFPGA\quartus\bin64\quartus_sh -t "e:/tools/develop/embedded/intelfpga/quartus/common/tcl/internal/nativelink/qnativesim.tcl" --rtl_sim "Firefly" "Firefly"

运行后会自动启动ModelSim,与前面执行仿真任务Surfer差不多,唯一的区别就是,它的仿真是根据Quartus自带的tcl脚本实现的

而内置的tcl脚本与qsf文件有关,换句话说,打开qsf文件,我们可以看到相关的约束命令

qsf的仿真解析

        在qsf文件中,搜索test,右边蓝色区域可以就是所有涉及到测试激励(仿真)的地方

        这三句对应的是图形后操作后保存的信息

这几条是仿真器的配置

这条是正在仿真的文件

这几条就是把测试激励模块与实际文件对应起来,用的是相对路径

        知道这些信息后,可以很轻松地手动修改。事实上,测试激励文件的相关操作在配置文件里修改要比图形化添加要方便一些。

        需要注意的是ModelSim仿真前,需要进行综合,也就是前面那个目标

ModelSim(命令行)

        前面的ModelSim的GUI有些简陋,那么接下来我们就可以使用命令行模式下的ModelSim,运行结束后让其再执行Surfer。

        首先我们可以在simulation/modelsim这个目录里找到Quartus自动生成的do脚本,该脚本用于vsim(也就是ModelSim的boss?可以这么说的话)。前面不是提到过Quartus运行RTL仿真时,其实是让quartus_sh执行了tcl脚本,该脚本自动生成了do脚本,并让vsim运行该脚本

脚本的内容很简单,都是些配置和启动命令

        因此我们可以让vsim来执行该脚本,并且以命令行的模式(需要带上参数-c),vsim的可执行路径需要自行去找(没有安装ModelSim是没有的,可以搜索“Quartus ModelSim”,会有一堆安装教程)

E:\Tools\Develop\Embedded\intelFPGA\ModelSim\modelsim_ase\win32aloem\vsim -c -do "do E:\\Program\\Embedded\\FPGA\\Firefly\\simulation\\modelsim\\Firefly_run_msim_rtl_verilog.do"

可以看到,脚本很顺利地执行下去了,执行后,可能会停留在vism界面(按Ctrl+C可退出)

我们可以在自动生成的do脚本里加上下面这句,即可让其仿真结束后自动退出

        那么也就意味着,我们把前面vsim执行do脚本的命令写入到ps1脚本或者bat脚本,再在后面补充上Surfer的命令。那么就可以让其仿真后,自动打开Surfer显示波形了,与之前双击Scaleda的仿真任务无异了

        为了进一步简化流程,可以写一个脚本先读取qsf中的顶层文件,再到test目录里去找有没有对应的测试激励文件,然后再生成对应的do脚本,接着让vsim执行仿真,在控制台输出信息,输出完之后,再自动打开Surfer,最后就可以优雅地欣赏波形了

                【未完待续】

5、波形显示

        由于心心念念的Rvcd不能使用,只得另辟蹊径来查看“波形”而非“波形数据”(也就是模拟波形)。在VS Code里可以找到这样的两个插件,完美代替了Rvcd和Surfe

        安装插件后,点击生成的vcd文件即可。如果两个插件都安装的话,可以在上方自行切换,二者择其一即可

WaveTrace

        点击左下角的添加信息,双击你要显示的信号即可

点击左边的信号后,上面会有三个显示类型,分别是数字、数字量化和模拟

Digital IDE

        此插件功能更丰富,但若想使用还需安装Vivado

        如此看来,除了内置git外,IDEA在Verilog方面能做到的VS Code都能做到,且某些方面更强

6、分工考虑

        编写一些基本模块的话,使用Verilog就足够了,Scaleda中的Verible可以提供非常好的语言支持。此外,git方面,IntelliJ IDEA能提供更好的体验。

        仿真的话,仅使用Verilog既冗余、晦涩难懂,又不能很好地达到效果,比如Verilog里没有real、$sin和break等,想要模拟ADC数据采集有些麻烦。而使用System Verilog的话,Scaleda的支持非常差,近乎不能使用,包括里面的仿真任务。此时只能依赖VS Code的hdl_checker插件了,对System Verilog有基本的支持(代码检查)。

        如果要对System Verilog进行仿真,那么iverilog就无能为力了,只能使用ModelSim等支持的仿真器。在测试激励文件里可以加上下面这句,以生成波形文件。然后可以在ModelSim仿真后再启动Surfer观察波形(可选项)。

initial begin
  $dumpfile("xxx.vcd");
  $dumpvars;
end

        综合起来,编写模块仿真测试使用IntelliJ IDEA仿真代码编写方面使用VS Code资源消耗方面使用Quartus。Scaleda的任务目标由于目前其缺陷性,不太适合使用。

        verilator        questasim

四、展望

        目前来说,想要一站式开发,得需要使用VS Code。IntelliJ IDEA与VS Code关于Verilog的插件并不互通,比如Digtal IDE只在VS Code有,Scaleda只在IntelliJ IDEA上有。两者都是非常优秀的工具,可根据自身开发体验自行选择。

        IntelliJ IDEA界面可能更为简介优美,且运行目标由于有现成的框架,想要运行脚本更方便。VS Code更为轻量且插件功能更为丰富,适合一站式开发,但想要达到更好的配置还需着重学习json等,学习难度较大。

        VS Code下开发FPGA——FPGA开发体验提升__下-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2330643.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

odo18实施——销售-仓库-采购-制造-制造外包-整个流程自动化单据功能的演示教程

安装模块 安装销售 、库存、采购、制造模块 2.开启外包功能 在进入制造应用点击 配置—>设置 勾选外包&#xff0c;点击保存 添加信息 一、添加客户信息 点击到销售应用 点击订单—>客户 点击新建 创建客户1&#xff0c;及其他客户相关信息&#xff0c;点…

微信小程序生成某个具体页面的二维码

微信小程序&#xff0c;如果要生成某个具体页面&#xff0c;而非首页的二维码&#xff0c;体验和正式的生成方法如下&#xff1a; 1、体验版二维码&#xff1a; 管理---版本管理---修改页面路径&#xff0c;输入具体页面的路径以及参数&#xff0c;生成的是二维码 2、正式小程…

鸿蒙开发_ARKTS快速入门_语法说明_组件声明_组件手册查看---纯血鸿蒙HarmonyOS5.0工作笔记010

然后我们来看如何使用组件 可以看到组件的组成 可以看到我们使用的组件 然后看一下组件的语法.组件中可以使用子组件. 然后组件中可以有参数,来修改组件的样式等 可以看到{},这种方式可以设置组件参数,当然在下面. 的方式也可以的 然后再来

接口异常数组基础题

题目描述 设想你正在构建一个智能家居控制系统。这个系统可以连接多种不同类型的智能设备&#xff0c;如智能灯泡、智能空调和智能门锁。每种设备都有其独特的功能&#xff0c;不过它们也有一些通用的操作&#xff0c;像开启、关闭和获取设备状态等。系统需要提供一个方法来控…

rustdesk折腾手记

背景 我的工作环境&#xff1a;主力电脑是macPro, 另外一台ThinkPad W530作为开发机&#xff0c;装的是LinuxMint&#xff0c;还有一台ThinkPad P15作为服务器。平常显示器接到macPro&#xff0c;在macOS上通过微软的远程桌面连接到另外两台Linux。基本访问比较流畅&#xff0…

使用el-tab 实现两个tab切换

1、主页面 index.vue 2、tab1&#xff1a;school.vue 3、tab2&#xff1a;parent.vue 具体代码如下&#xff1a; <template><div class"app-container"><!-- 使用el-tabs 实现两个组件的切换 --><el-tabs v-model"activeName" typ…

使用Pholcus编写Go爬虫示例

想用Pholcus库来写一个Go的爬虫程序。首先&#xff0c;我得确认Pholcus的当前状态&#xff0c;因为之前听说过它可能已经不再维护了。不过用户可能还是需要基于这个库的示例&#xff0c;所以得先提供一个基本的框架。 首先&#xff0c;我应该回忆一下Pholcus的基本用法。Pholc…

单片机实现触摸按钮执行自定义任务组件

触摸按钮执行自定义任务组件 项目简介 本项目基于RT8H8K001开发板 RT6809CNN01开发板 TFT显示屏(1024x600) GT911触摸屏实现了一个多功能触摸按钮组件。系统具备按钮控制后执行任务的功能&#xff0c;可用于各类触摸屏人机交互场景。 硬件平台 MCU: STC8H8K64U&#xff0…

Ai云防护技术解析——服务器数据安全的智能防御体系

本文深度解析AI云防护技术如何通过智能流量分析、动态行为建模、自适应防御策略构建服务器安全体系。结合2023年群联科技实战案例,揭示机器学习算法在识别新型DDoS攻击、加密流量检测、零日漏洞防御中的技术突破,并附Gartner最新防护效果验证数据。 AI驱动的流量特征建模技术…

JSONP跨域访问漏洞

一、漏洞一:利用回调GetCookie <?php$conn new mysqli(127.0.0.1,root,root,learn) or die("数据库连接不成功"); $conn->set_charset(utf8); $sql "select articleid,author,viewcount,creattime from learn3 where articleid < 5"; $result…

图形裁剪算法

1.学习目标 理解区域编码(Region Code&#xff0c;RC) 设计Cohen-Sutherland直线裁剪算法 编程实现Cohen-Sutherland直线裁剪算法 2.具体代码 1.具体算法 /*** Cohen-Sutherland直线裁剪算法 - 优化版* author AI Assistant* license MIT*/// 区域编码常量 - 使用对象枚举…

R 语言科研绘图第 36 期 --- 饼状图-基础

在发表科研论文的过程中&#xff0c;科研绘图是必不可少的&#xff0c;一张好看的图形会是文章很大的加分项。 为了便于使用&#xff0c;本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中&#xff0c;获取方式&#xff1a; R 语言科研绘图模板 --- sciRplothttps://mp.…

vue 3 从零开始到掌握

vue3从零开始一篇文章带你学习 升级vue CLI 使用命令 ## 查看vue/cli版本&#xff0c;确保vue/cli版本在4.5.0以上 vue --version ## 安装或者升级你的vue/cli npm install -g vue/cli ## 创建 vue create vue_test ## 启动 cd vue_test npm run servenvm管理node版本&#…

【R语言绘图】圈图绘制代码

绘制代码 rm(list ls())# 加载必要包 library(data.table) library(circlize) library(ComplexHeatmap) library(rtracklayer) library(GenomicRanges) library(BSgenome) library(GenomicFeatures) library(dplyr)### 数据准备阶段 ### # 1. 读取染色体长度信息 df <- re…

Python爬虫第6节-requests库的基本用法

目录 前言 一、准备工作 二、实例引入 三、GET请求 3.1 基本示例 3.2 抓取网页 3.3 抓取二进制数据 3.4 添加headers 四、POST请求 五、响应 前言 前面我们学习了urllib的基础使用方法。不过&#xff0c;urllib在实际应用中存在一些不便之处。以网页验证和Cookies处理…

什么是可靠性工程师?

一、什么是可靠性工程师&#xff1f; 可靠性工程师就是负责确保产品在使用过程中不出故障、不给客户添麻烦。 你可以理解为是那种“挑毛病的人”&#xff0c;但不是事后挑&#xff0c;是提前想清楚产品在哪些情况下可能会出问题&#xff0c;然后解决掉。 比如&#xff1a; …

如何根据设计稿进行移动端适配:全面详解

如何根据设计稿进行移动端适配&#xff1a;全面详解 文章目录 如何根据设计稿进行移动端适配&#xff1a;全面详解1. **理解设计稿**1.1 设计稿的尺寸1.2 设计稿的单位 2. **移动端适配的核心技术**2.1 使用 viewport 元标签2.1.1 代码示例2.1.2 参数说明 2.2 使用相对单位2.2.…

【Kafka基础】Kafka 2.8以下版本的安装与配置指南:传统ZooKeeper依赖版详解

对于仍在使用Kafka 2.8之前版本的团队来说&#xff0c;需要特别注意其强依赖外部ZooKeeper的特性。本文将完整演示传统架构下的安装流程&#xff0c;并对比新旧版本差异。 1 版本特性差异说明 1.1 2.8 vs 2.8-核心区别 特性 2.8版本 2.8-版本 协调服务 可选内置KRaft模式 …

Redis-x64-3.2.100.msi : Windows 安装包(MSI 格式)安装步骤

Redis-x64-3.2.100.msi 是 Redis 的 Windows 安装包&#xff08;MSI 格式&#xff09;&#xff0c;适用于 64 位系统。 在由于一些环境需要低版本的Redis的安装包。 Redis-x64-3.2.100.msi 安装包下载&#xff1a;https://pan.quark.cn/s/cc4d38262a15 Redis 是一个开源的 内…

【云计算】打造高效容器云平台:规划、部署与架构设计

引言 随着移动互联网时代的大步跃进&#xff0c;互联网公司业务的爆炸式增长发展给传统行业带来了巨大的冲击和挑战&#xff0c;被迫考虑转型和调整。对于我们传统的航空行业来说&#xff0c;还存在传统的思维、落后的技术。一项新业务从提出需求到立项审批、公开招标、项目实…