计算机视觉基础知识(十四)--深度学习开源框架

news2025/1/10 16:45:16

深度学习框架

  • Caffe
  • tensorflow
  • 框架是深度学习的库;
  • 编程时需要import

应用优势

  • 框架的出现降低了入门的门槛;
  • 不需要从复杂的神经网络开始编写代码;
  • 根据需要,使用已有的模型;
  • 模型的参数经过训练得到;
  • 可以在已有的模型基础上增加自己的layer;
  • 在顶端选择自己的分类器和优化算法;
  • 没有框架是完美的;
  • 不同的框架适用的领域不完全一致;
  • 深度学习框架提供了一系列深度学习的组件;
  • 实现了一些通用的算法;
  • 新的算法需要用户自己定义;
  • 调用函数接口使用用户定义的新算法;

五个核心组件

  • 张量(Tensor);
  • 基于张量的各种操作(Operation);
  • 计算图(Computation Graph)
  • 自动微分(Automatic Differentiation)工具;
  • BLAS、cuBLAS、cuDNN等拓展包;

张量

  • 所有深度学习框架中最核心的组件;
  • 后续的所有运算和优化算法都是基于张量的;
  • 几何代数中定义的张量是局域向量和矩阵的推广;
  • 标量视为零阶张量;
  • 矢量视为一阶张量;
  • 矩阵视为二阶张量;
  • 四阶张量表示一个含多张图片的数据集;
  • 四个维度分别为;
  • 图片在数据集中的编号:N;
  • 图片高度:H;
  • 图片宽度:W;
  • 色彩数据:C;

张量的优势

  • 将各种数据抽象成张量;
  • 输入神经网络模型进行后续处理;
  • 是一种非常必要且高效的策略;
  • 数据处理完成后;
  • 将张量转换回想要的格式;

基于张量的操作

  • 整个神经网络就是针对张量操作的一系列过程;
  • 张量操作包含:矩阵乘法、卷积、池化、LSTM等

基于张量计算的一些问题

  • 整合张量操作,输出期望的结果需要考虑一些问题;
  • 张量操作的种类和数量繁多,管理可能变得困难;
  • 各张量操作之间的关系难以厘清;
  • 多个操作的并行和顺序执行的选择;
  • 如何协同不同的底层设备;
  • 如何避免冗余操作;

计算图

  • 计算图的出现是为了解决张量操作的相关问题;
  • 计算图作为前后端之间的中间表示:Intermediate Representations;
  • 可带来良好的交互性;
  • Tensor对象作为数据结构;
  • 函数、方法作为操作类型;
  • 特定的操作类型应用于特定的数据结构;
  • 计算图可以使开发者宏观上俯瞰整个神经网络的内部结构;
  • 类似于编译器可以从整个代码的角度决定寄存器分配一样;
  • 计算图宏观上可以决定代码运行时GPU的内存分配;
  • 分布式环境中不同底层设备间的协作方式;
  • 计算图也可用于模型调试;
  • 可以实时输出操作类型的文本描述;

自动微分工具 

  • 计算图让模型训练的梯度计算模块化、自动化--自动微分法;
  • 将神经网络视为多非线性过程组成的复杂函数体;
  • 计算图模块化的表征了函数体内部的逻辑关系;
  • 微分此函数体(求模型梯度)的方法变为在计算图中完整的从输入到输出进行遍历的过程;

拓展包

  • 高级语言较低级语言消耗更多的cpu周期;
  • 对结构复杂的神经网络,运算缓慢成了一个天然缺陷;
  • 低级语言优化编程难度很高;
  • 大部分的基础操作有公开的最有解决方案;
  • 利用这些现成的解决方案是一个显著的加速手段;

主流深度学习框架

顶级深度学习框架四大阵营

国内深度学习框架

MindSpore

  • 厂商:华为
  • 特点:
  • 支持端、边、云独立的和协同的统一训练和推理框架;
  • 2020.03.28日开源

PaddlePaddle

  • 厂商:百度
  • github100%开源,没有内部版本
  • 能够应用于自然语言处理、图像识别、推荐引擎等
  • 优势在于开放的多个领先的预训练中文模型;

XDL(X-Deep Learning)

  • 厂商:阿里巴巴
  • 应用于阿里妈妈的广告业务算法框架是开源的;
  • 主要针对广告的深度学习问题的解决;
  • 是上层高级API框架;
  • 不是底层框架;
  • 需要采用桥接方式配合TensorFlow和MXNet作为单节点使用;
  • 依赖阿里的特定部署环境

MACE

  • 厂商:小米
  • 针对移动芯片特性进行大量优化;
  • 小米手机广泛应用;
  • 主要应用场景为人像模式、场景识别;
  • 框架采用类似Caffe2的描述文件定义模型;
  • 能方便的部署移动应用;
  • 目前该框架是TensorFlow和Caffe的模型转换工具;
  • 其他框架定义的模型能够很快的支持。

ONNX

  • 开放神经网络交换:ONNX(Open Neural Network Exchange)
  • 最初由微软和Facebook联合发布;
  • 亚马逊加入后,发布了V1版本;
  • 宣布支持ONNX的公司:AMD,ARM,华为,IBM,英特尔,Qualcomm;
  • 是一个表示深度学习模型的开放格式;
  • 用户可以更轻松的在不同框架之间转移模型;
  • 比如用户可以使用PyTorch建立模型,使用MXNet运行该模型

TensorFlow

  • 是一个采用数据流图(data flow graphs)进行数值计算的开源软件库;
  • 节点(Nodes)在图中表示数学操作;
  • 图中的线(edges)表示节点间相互联系的多维数据(张量);
  • 架构灵活,开在多平台展开计算;

TensorFlow基本用法

  • 使用图(graph)来表示计算任务;
  • 在会话(Session)的上下文(context)中执行图;
  • 使用Tensor表示数据;
  • 通过变量Variable维护状态;
  • 使用feed和fetch为任意操作赋值或获取数据;

TensorFlow概述

  • 是一个编程系统;
  • 使用图来表示计算任务;
  • 图中节点表示operation,称为op;
  • 一个op获取0个或多个Tensor,计算产生0个或多个Tensor;
  • 一个Tensor是一个类型化的多维数组;
  • 比如一个小的图像集可以表示为一个思维浮点数组;
  • 四个维度分别为:【batch,height,width,channels】;
  • TensorFlow按图计算,图必须在会话里被启动;
  • 会话将图的op分发到CPU或GPU设备上,同时提供执行op的方法;
  • 方法执行后将产生的Tensor返回;
  • python语言中返回的tensor是numpy的ndarray对象;

TensorFlow图构建

  • 创建源op;
  • 源op不需要任何输入,比如常量constant;
  • 源op的输出给到其他op进行计算;
  • 在Session中启动图;
  • 关闭session释放资源。

TensorFlow张量

  • 构件图的过程输出的结果是一个Tensor;
  • 该Tensor由三个属性构成:Name、shape、type
  • Name:表示张量的名称,是张量的唯一标识;
  • 可以在每个op上添加name属性对节点命名;
  • Name的值表示该张量莱滋第几个输出结果(编号从0开始);
  • Shape:表示张量的维度;
  • type:表示张量的类型,每个张量具有唯一的类型;
  • 运算过程中需要保证张量类型的一致;

TensorFlow常见张量类型

TensorFlow变量

  • 变量Variable维护图执行过程中的状态信息;
  • 通常将一个统计模型中的参数表示为一组变量;
  • 比如,将一个神经网络的权重作为一个变量存储在一个Tensor中;
  • 训练过程中,重复运行训练图,不断更新该tensor。

TensorFlow fetch/feed

  • Fetch:取回操作的输出内容;
  • 使用session对象的run()调用执行图,传入一些tensor;
  • 这些tensor帮用户取回结果;
  • Feed:使用一个tensor值临时替换一个操作的输出结果;
  • 提供feed数据作为run()调用的参数;
  • feed只在调用它的方法内有效,方法结束,feed消失;
  • 最常见的是将某些特殊的操作指定为feed操作;
  • 标记的方法是使用tf.placeholder()为这些操作创建占位符;

Placeholder

  • placeholder是一个数据初始化的容器;
  • 与变量最大的不同是placeholder定义的是模版;
  • 可以在session阶段运行;
  • 利用feed_dict字典结构给placeholder填充内容;
  • 不需要每次提前定义好变量的值;
  • 大大提高了代码的利用率;

TensorBoard

  • TensorBoard是TensorFlow内置的一个可视化工具;
  • 通过将TensorFlow输出的日志信息可视化;
  • 使得对TensorFlow程序的理解、调试、优化更为简单高效;
  • TensorBoard的可视化依赖于TensorFlow输出的日志文件;
  • tensorflow和TensorBoard在不同的程序中运行;

TensorBoard实例

  • 生成一个具有写权限的日志文件对象;
  • 将当前命名空间的计算图写进日志文件;
  • writer=tf.summary.FileWriter('logs',tf.get_default_graph())
    writer.close()
    #启动tensorboard服务(在命令行启动)
    tensorboard --logdir logs
    #启动tensorboard服务后,复制地址病在本地浏览器中打开
    TensorBoard 1.14.0 at Http://Cam-L1E00050:6006/(Press CTRL+C to quit)

TensorFlow版本选择

  • TensorFlow版本的兼容性较差;
  • 各大公司目前仍较多使用1版本;
  • 迁移成本较高;

TensorFlow1

  • 静态图
  • 需要session run

TensorFlow2

  • 动态图
  • 不需要session run

TensorFlow2下使用TensorFlow1的代码

  • import tensorflow.compat.v1 as tf
    tf.compat.v1.disable_eager_execution()
    #或者
    tf.disable_v2_behavior()

PyTorch

  • Torch的python版本;
  • 由Facebook开源的神经网络框架;
  • 专门针对GPU加速的深度神经网络(DNN)编程;
  • Torch是一个经典的对多维矩阵数据操作的张量库;
  • 在机器学习和其他数学密集型应用中应用广泛;
  • 具有动态计算图,根据需要实时改变计算图;
  • Torch语言采用Lua,国内比较小众;
  • 逐渐被支持python的TensorFlow抢走用户;
  • PyTorch是经典的机器学习库Torch的端口;
  • PyTorch为python语言的使用者提供了舒适的写代码选择;
  • PyTorch是基于Python的科学计算包;
  • 替代numpy发挥GPU潜能;
  • 提供了高度灵活性和效率的深度学习实验平台。

 PyTorch的优势

简洁

  • 设计追求最少封装,避免重复造轮子;
  • 不像TensorFlow具有session、graph、operation、names_scope、variable、tensor、layer等全新的概念;
  • 遵循tensor-->variable(autograd)-->nn.Module三个抽象层次;
  • 上述三个层次由低到高,代表高维数组(张量)、自动求导(变量)、神经网络(层、模块);
  • 上述三者之间联系紧密、可同时修改和操作;

速度

  • 灵活性不以速度为代价;
  • 速度胜过TensorFlow和Keras等框架

易用

  • 面向对象设计的最优雅者;
  • 接口设计来源于Torch;
  • Torch的接口设计以灵活易用而著称;
  • Keras受Torch的启发而开发;

活跃的社区

  • 完整的文档
  • 循序渐进的指南;
  • 作者亲自维护论坛,供用户交流;
  • Facebook人工智能研究院提供强力支持

PyTorch常用工具包

  • torch:类似Numpy的张量库,支持GPU;
  • torch.autograd:基于type的自动区别库,支持Torch中的所有可区分张量;
  • torch.nn:追求最大灵活性,与autograd深度整合;
  • torch.optim:与torch.nn一起使用的优化包,含SGD\RMSProp\LBFGS\Adam,标准优化方式;
  • torch.multiprocessing:python多进程并发,进程之间torch tensor内存共享;
  • torch.utils:数据载入器,具有训练器和其他便利功能;
  • torch.legacy(.nn/.optim):向后兼容,从Torch移植;

PyTorch特别注意

  • OpenCV的默认通道为:H*W*C;
  • PyTorch的默认通道为:C*H*W;
  • TensorFlow两者都支持;

理解PyTorch

  • Numpy风格的Tensor操作;
  • Tensor API参考了Numpy的设计;
  • 变量自动求导:在计算过程形成的计算图中,变量可方便的计算自己对目标函数的梯度;
  • 高层封装神经网络层与函数优化;
  • 网络层封装在torch.nn模块中;
  • 损失函数由torch.nn.functional模块提供;
  • 优化函数由torch.optim模块提供;

PyTorch 张量类型

PyTorch Tensor创建接口

PyTorch Tensor对象方法

PyTorch自动求导

  • tensor对象通过一系列运算可以组成动态图
  • 每个tensor对象有以下几个求导属性

PyTorch神经网络 

  • torch.nn模块提供创建网络的基础构件
  • 这些层继承自Module类;
  • 可训练的层使用module;
  • 不需要训练的层比如softmax,可以使用funcational中的函数;

Pytorch较重要的神经网络层组件

  • nn.functional模块中提供层的函数实现

PyTorch神经网络构建

  • torch.nn.Module提供了神经网络的基类;
  • 实现神经网络时要继承此模块;
  • 在初始化函数中创建网络要包含的层;
  • 实现forward函数完成前向计算;
  • 自动求导机制会处理网络的反向计算;
  • 将需要训练的层写在init函数中;
  • 将不需要训练参数的层在forward方法中调用相应的函数实现层功能

PyTorch神经网络构建步骤

  • 写好网络;
  • 编写数据的标签和路径索引;
  • 将数据送到网络;

PyTorch优化算法

original-loss:

  • 整个训练集上的loss

minibatch-loss

  • 在一个mini batch上的loss

BGD

  • 最原始的梯度下降算法;
  • 想计算original-loss,需要使用训练集全部数据;
  • 训练数据过大时,BGD可能造成内存不够用,可使用SGD

SGD

  • 又称online梯度下降,随机梯度下降;
  • 每次估计梯度时,只用一个或几个batch训练样本;
  • 近似计算original-loss时,只使用一个mini batch,用minibatch-loss上的梯度近似original-loss的梯度

mini-batch SGD算法特点

  • 训练神经网络时;
  • 将数据拆解成一小批一小批的进行训练;
  • 这是常用的mini-batch SGD训练算法;
  • 该算法能够带来很好的训练速度;
  • 但并不总能达到最优解,而是在最优解附近徘徊;
  • mini-batch SGD算法需要用户提供一个合适的学习率;
  • 学习率太小,导致网络训练收敛慢;
  • 学习率太大,优化的幅度跳过函数的最优点;
  • 理想的网络在优化时损失函数有很好的收敛速度,幅度摆动又不会太大;

Momentum

  • 目标是加速学习;
  • 对于处理高曲率的梯度,小但一致的梯度,带噪声的梯度时效果较好;
  • 累计以往梯度指数衰减移动的均值,且沿该方向继续移动;

v_{dw}=\beta v_{dw}+(1-\beta)dw

v_{db}=\beta v_{db}+(1-\beta)db

w=w-\alpha v_{dw}

b=b-\alpha v_{db}

  • v_{dw}--损失函数在前t-1轮迭代中累计的权重梯度动量;
  • v_{db}--损失函数在前t-1轮迭代中累计的偏置梯度动量;
  • \beta--梯度累计的一个指数,一般设置为0.9;
  • \alpha--网络的学习率
  • dw--损失函数反向传播时计算得到的权重梯度;
  • db--损失函数反向传播时计算得到的偏置梯度;
  • 利用类似于移动指数加权平均的方法来对网络参数进行平滑处理;
  • 使得梯度的摆动幅值变得更小;

RMSProp(Root Mean Square Prop)

  • 为进一步优化损失函数在参数更新中摆动幅度过大,引入RMSProp算法;
  • RMSProp算法对权重w和偏置b的梯度使用微分平方加权平均数;
  • t轮迭代的公式如下;

s_{dw}=\beta s_{dw}+(1-\beta) dw^2

s_{db}=\beta s_{db}+(1-\beta)db^2

w=w-\alpha \frac{dw}{\sqrt{s_{dw}}+\epsilon}

b=b-\alpha \frac{db}{\sqrt{s_{db}}+\epsilon}

  • s_{dw}--损失函数在前t-1轮迭代中累计的权重梯度动量;
  • s_{db}--损失函数在前t-1轮迭代中累计的偏置梯度动量;
  • \beta--梯度累计的一个指数,一般设置为0.9;
  • \alpha--网络的学习率
  • dw--损失函数反向传播时计算得到的权重梯度;
  • db--损失函数反向传播时计算得到的偏置梯度;
  • 该算法对梯度计算了微分平方加权平均数;
  • 该方法有利于消除摆动幅度大的方向,修正摆动幅度;
  • 使各维度摆动幅度都较小,另一方面,网络收敛更快;
  • 防止分母为零,使用很小的数值\epsilon进行平滑,一般为10^{-8};

Adam

  • Adam(Adapative Moment Estimation)
  • 将Momentum算法和RMSProp算法结合使用;
  • 参数和以上两者一致;
  • 在训练开始时需要初始化梯度的累积量和平方累积量;

v_{dw}=0,v_{db}=0;s_{dw}=0,s_{db}=0;

  • 训练的第t轮,计算得到Momentum和RMSProp的参数更新;

v_{dw}=\beta_1 v_{dw}+(1-\beta_1)dw

v_{db}=\beta_1 v_{db}+(1-\beta_1)db

s_{dw}=\beta_2 s_{dw}+(1-\beta_2)dw^2

s_{db}=\beta_2 s_{dw}+(1-\beta_2)db^2

  • 移动指数平均在迭代开始初期与初始值的差异较大;
  • 需要对上面几个值做偏差修正;

v_{dw}^c=\frac{v_{dw}}{1-\beta_1^t}

v_{db}^c=\frac{v_{db}}{1-\beta_1^t}

s_{dw}^c=\frac{s_{dw}}{1-\beta_2^t}

s_{db}^c=\frac{s_{db}}{1-\beta_2^t}

  • 通过上述公式可以求得参数梯度累积量的修正值;
  • 接下来根据Momentum和RMSProp算法的结合计算权重w和偏置b的参数更新;

w=w-\alpha \frac{v_{dw}^c}{\sqrt{s_{dw}^c}+\epsilon}

b=b-\alpha \frac{v_{db}^c}{\sqrt{s_{db}^c}+\epsilon}

  • Adam中的\beta_1与Momentum算法中的\beta一样,一般取值0.9;
  • \beta_2对应RMSProp算法中的\beta值,一般取值0.999;
  • \epsilon是一个平滑项,一般取值10^{-8};
  • \alpha需要在训练的时候微调;

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

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

相关文章

2024最新版Redis安装使用指南

2024最新版Redis安装使用指南 Installation and Usage Guide to the Latest Redis in 2024 By JacksonML 1. 什么是Redis? The open-source, in-memory data store used by millions of developers as a cache, vector database, document database, streaming engine, an…

Linux 常用命令100+

Linux 运维/开发/测试 常用命令100 线上查询及帮助命令(2个) 命令功能说明示例man 命令查看普通命令帮助,命令的词典,更复杂的还有info,但不常用。rootbrLinux ~]#man lshelp 命令查看Linux内置命令的帮助,比如cd命令。[rootbrL…

【C++】初始化列表、static成员、友元、匿名对象、附练习题

文章目录 前言一、构造函数【初始化列表】1.1 构造函数体赋值1.2 初始化列表1.3 explicit关键字 二、static成员2.1 概念2.2 特性 三、友元3.1 友元函数3.2 内部类 四、匿名对象4.1 拷贝对象时的一些编译器优化 五、再次理解类和对象六、练习题6.1 求123...n,要求不…

面试:正确率能很好的评估分类算法吗

正确率(accuracy) 正确率是我们最常见的评价指标,accuracy (TPTN)/(PN),正确率是被分对的样本数在所有样本数中的占比,通常来说,正确率越高,分类器越好。 不同算法有不同特点,在不同…

算法项目(1)—— LSTM+CNN+四种注意力对比的股票预测

本文包含什么? 项目运行的方式(包教会)项目代码(在线运行免环境配置)不通注意力的模型指标对比一些效果图运行有问题? csdn上后台随时售后.项目说明 本项目实现了基于CNN+LSTM构建模型,然后对比不同的注意力机制预测股票走势的效果。首先看一下模型结果的对比: 模型MS…

十、计算机视觉-腐蚀操作

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、什么是腐蚀二、如何实现腐蚀三、腐蚀的原理 一、什么是腐蚀 在我们生活中常会见到腐蚀,比如金属表面受到氧化或其他化学物质的侵蚀,导致…

uniapp不同平台获取文件内容以及base64编码特征

前言 文件图片上传,客户端预览是很正常的需求,获取文件的md5特征码也是很正常的,那么,在uniapp中三种环境,h5, 小程序以及 app环境下,如何实现的? 参考: 如何在uniapp中读取文件Arr…

电动汽车充电负荷时空分布预测(matlab)

目录 1 主要内容 交通网-配电网交互模型 动态交通路网模型 2 部分代码 3 程序结果 4 下载链接 1 主要内容 该程序参考《基于动态交通信息的电动汽车充电负荷时空分布预测》和《基于动态交通信息的电动汽车充电需求预测模型及其对配网的影响分析》文献模型,考虑…

Py之ydata-profilin:ydata-profiling的简介、安装、使用方法之详细攻略

Py之ydata-profilin:ydata-profiling的简介、安装、使用方法之详细攻略 目录 ydata-profiling的简介 1、主要特点 2、案例应用 (1)、比较数据集、对时序数据集进行分析、对大型数据集进行分析、处理敏感数据、数据集元数据和数据字典、自定义报告的外观、不同类型…

yolov5-tracking-xxxsort yolov5融合六种跟踪算法(一)--环境配置CPU版本

本次开源计划主要针对大学生无人机相关竞赛的视觉算法开发。 开源代码仓库链接:https://github.com/zzhmx/yolov5-tracking-xxxsort.git 如果需要配置GPU版本环境可以查看我的这篇博客:yolov5-tracking-xxxsort yolov5融合六种跟踪算法(一&am…

动态表格 点击单元格查看完整内容

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>分享收藏</title><script src"https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script><style…

Java零基础 - 逻辑运算符

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一个人虽可以走的更快&#xff0c;但一群人可以走的更远。 我是一名后…

[word] word带圈数字20以上 #笔记#笔记

word带圈数字20以上 办公中有时候需要用到带圈数字&#xff0c;超过20的数字就不能直接编辑了&#xff0c;那么20以上带圈数字要怎么输入呢&#xff1f;其实通过小技巧就能完成的&#xff0c;接下来就给大家介绍下呢&#xff0c;一起看看吧&#xff01; 20以上带圈数字输入技巧…

LaunchPad 市场的复苏,Penpad 成新兴生力军

以 Fair Launch 为主要启动方式的铭文市场的爆发&#xff0c;推动了 LaunchPad 市场的复苏&#xff0c;绝多数所铭文项目都能通过 Fairr Launch 的方式筹集资金实现启动&#xff0c;该赛道的爆发不仅推动了数百亿美元的热钱开始在链上不断涌动&#xff0c;同时也进一步形成了新…

String为什么是不可变的?

一、String字符串类型的数据结构 首先&#xff0c;String类是由 final 关键字修饰&#xff0c;这说明String 不可被继承。其次&#xff0c;由源代码可以看出String的成员字段value是一个char[ ]数组&#xff0c;在后面所有的String方法里都不提供修改Array数组的方法&#xff0…

torch.manual_seed(233333)

torch.manual_seed&#xff08;233333&#xff09; 介绍报错信息解决问题总结 介绍 这是在使用GPT-SoVITS时运行缺失pytorch导致报的错 报错信息 Traceback (most recent call last): File “D:\vits\GPT-SoVITS-beta\GPT-SoVITS-beta0217\webui.py”, line 10, in torch.m…

文件上传漏洞--Upload-labs--Pass17--条件竞争

一、条件竞争原理&#xff08;结合代码审计&#xff09; 1、首先进行代码审计&#xff0c;查看源代码。 我们可知&#xff0c;将文件上传至服务器后&#xff0c;不会被立即删除&#xff0c;而是做短暂的停留&#xff0c;中间会有一小部分时间差&#xff0c;这部分时间差是代码…

STM32使用软件SPI协议操作TFT18彩屏

时间记录&#xff1a;2024/2/20 一、SPI协议介绍 &#xff08;1&#xff09;SPI设备通过4根线进行通信&#xff0c;CS片选线&#xff0c;选择从设备&#xff0c;SCK时钟线&#xff0c;由主设备产生时钟&#xff0c;主机MOSI线连从机MISO线&#xff0c;由主机向从机发送信息&am…

HighTec编译器系列之01新建工程

HighTec编译器系列之01新建工程 继上篇《Hightec编译器系列之白嫖就是爽》小T告诉大家如何白嫖HighTec编译器长达一年之久之后&#xff0c;今天小T告诉大家如何进行HighTec编译器IDE的基础操作-即新建HighTec工程。 以下是本期内容的行文大纲&#xff1a; S1&#xff1a;创建…

Cesium for Unreal 从源码编译到应用——插件编译

一、安装环境 Unreal Engine 5.3 CMake 3.17.5 Microsoft Visual Studio 2019 二、源码准备 下载cesium-unreal-samples工程。 git clone https://github.com/CesiumGS/cesium-unreal-samples.git 然后在工程目录创建Plugins文件夹&#xff0c;并下载cesium-unreal工程。 …