【FPGA】面试八股

1.FPGA的底层资源有哪些

(1)可编程的逻辑资源
可编程的逻辑单元由查找表(LUT),数据选择器(MUX),进位链(Carry Chain)和触发器(Flip-Flop)
(2)可编程的IO资源
支持适配不同的电器标准。
(3)布线资源
包括全局布线资源、长线资源、短线资源、分布式的布线资源;
(4)Block RAM
支持高速、低功耗、大容量、分块存储;
(5)内嵌专用硬核
ARM-Cortex系列
DSP:用于数学运算。

2.时序约束

(1)时钟约束
时钟周期,上升沿时刻,下降沿时刻。(占空比)
(2)输入延迟
数据,相较于时钟出触发沿,延迟到达的时间。
约束:最大值和最小值
确定: 通过走线进行计算,或用示波器进行测量;
(3)输出延迟
数据,相较于时钟触发沿,提前到达的时间;
(4)异步约束
单bit数据打两拍跨时钟域处理:
set_false_path:禁止对指定路径进行时序分析;
async_reg:进行约束
异步fifo:
将读写时钟加入异步时钟组;
(5)时钟不确定性约束
时钟抖动:时钟触发沿提前到达、滞后到达;时钟周期发生变化;占空比发生变化;
时钟偏移:时钟通过不同路径到达不同寄存器延迟不同;
时钟不确定性:两者之和
(6)管脚约束
分类:管脚约束、电器属性约束和其他约束
管脚约束:约束管脚编号和端口的对应关系,输入输出方向;
电器属性约束:约束电器属性,采用的工艺、工作电压;
其他约束:管脚的上拉和下拉等。

3.低功耗设计

(1)功耗的分类
静态功耗:FPGA还没有启动前,晶体管泄露的漏电流引起的功耗,维持I/O,时钟管理等引起的功耗;
动态功耗:FPGA还没有启动后,逻辑门开关活动时的功耗;
(2)降低功耗的方法
A体系结构降低功耗
采用区域电压;
动态电压频率调节:保证电路正常工作情况下,尽可能降低时钟频率;
保持寄存器:寄存器工作完成,输出保持不变,而不是清零;
门控电源:芯片区域正常工作时,打开电源;芯片区域不工作时,关闭段元;
提高阈值电压:减少漏电流。
BRTL级
状态编码:采用格雷码,状态翻转减少;
门控时钟:电路区域工作,提供时钟;电路区域不工作,关闭时钟;
模块复用:功能实现相同的电路,进行复用;
逻辑优化:优化算法。
C其他
优化布局布线
优化采用的工艺
行波计数器
禁用逻辑云

4.FPGA资源

(1)项目
LUT: 43万,使用近80%;
FF:86万个,使用近50%
BRAM:1400,用了20%

5.二进制码变为格雷码

//每一位异或其左边那位,最高位不变
在这里插入图片描述

6.FPGA实现频率计

(1)方法分类
周期测量发:先测被测信号的周期,然后根据f=1/T得到;
会存在一个测量时钟周期的误差,适用于被测时钟频率较低;
频率测量法:测量一定时间内的脉冲数,然后计算单位时间内的脉冲数即为频率;
会存在一个被测时钟周期的误差,适用于被测时钟频率较高。
门控测量法:一定被测时钟脉冲周期内,利用被测时钟和基准时钟的对应关系;
等精度测量法:在一定时间门控信号内,利用被测时钟和测量时钟的对应关系进行测量;
(2)实现
门控信号产生;
门控信号的跨时钟域处理;
门控信号的下降沿检测;
统计门控内时钟周期数;
计算最后的结果。

7.竞争冒险

(1)定义
竞争:逻辑电路中,信号由多条路径进行传输的延迟时间不同,到达逻辑汇合点的时间有先有后;
冒险:由于竞争导致输出尖峰脉冲的现象;
(2)如何识别竞争冒险
A 代数法
只有逻辑表达式可以化简为Y=AA’(1型冒险)或者Y=A+A’(0型冒险)的形式;
例子:
Y=AB+A’C,在B=C=1时,逻辑表达式可以化简为Y=A+A’,存在0型冒险;
B 卡诺图法
两个卡诺圈相切,且相切处没有其他卡诺圈包围;
C 计算机辅助法
(3)如何消除竞争冒险
A 加入滤波电容;
B修改逻辑表达式,增加冗余项;
如图所示卡诺图可以化简为Y=B’C’+AC,存在竞争冒险,加入冗余项AB’就可以消除;
在这里插入图片描述
C对组合逻辑进行打拍
由于尖峰脉冲不满足建立保持时间,所以触发器对脉冲信号不敏感;
D使格雷码进行状态编码
相邻两个状态只有一位发生变化,可以有效避免竞争冒险;

8.亚稳态

(1)定义
由于不满足建立、保持时间,导致输出处于未知状态;
(2)产生的场景
跨时钟域数据处理;
异步复位;
(3)解决办法
A 复位信号采用异步复位、同步释放;
B 跨时钟域信号,采用fifo进行缓冲;
C 对异步信号进行同步处理;
D 采用响应更快的触发器;

9.异步复位的removal time和recovery time

(1)定义
removol time:撤销时间,为保证复位信号有效,时钟触发沿到来之后,复位信号必须保持有效的时间;
recovery time:恢复时间,复位信号释放时,在时钟触发沿到来之前,要保持无效状态的时间;
在这里插入图片描述

10.时序路径

(1)电路说明
Device A:是设计电路的上游器件;
Designed Unit:设计电路;
Device B:是设计电路的下游器件;
在这里插入图片描述
(2)时序路径
路径1:dina->FF2:D ,设计的输入端到第一级寄存器数据输入端;
路径2:FF2:cp->FF3:D, 设计电路中,时钟输入端到下一级寄存器的数据输入端;
路径3:FF3:cp->douta,设计电路中,最后一级寄存器时钟输入端到设计电路输出端;
路径4:dinb->doutb,设计电路输入端到设计电路输出端,纯组合逻辑电路;

11.D触发器的内部结构

(1)SR触发器
由4个"与非门"分两级构成;
第一级输入的S/R分别和时钟进行与非;
第二级中,第一级输出和第二级另一支路与非;
在这里插入图片描述
(2)D触发器
SR触发器,S输入接D,R输入接D’;
在这里插入图片描述

12.数据选择器(2选1MUX)构成基本的门电路

(1)与门
在这里插入图片描述
(2)或门
在这里插入图片描述
(3)非门
在这里插入图片描述

13.CMOS构成基本的门电路

(1)非门
在这里插入图片描述
(2)与非门
在这里插入图片描述
(3)或非
在这里插入图片描述
(4)传输门
在这里插入图片描述
(5)异或门
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

xmltodict 处理 XML 数据案例解析

简介:xmltodict 是一个用于将 XML 数据转换为 Python 字典的轻量级模块。它简化了 XML 数据的解析和处理,使得在 Python 中操作 XML 变得更加直观和方便。这个模块适合用于数据交换、配置文件解析等需要 XML 数据处理的场景。 历史攻略: loc…

ajax php

文章目录 get请求postget和post的异同点ajax原生步骤jquery步骤优点 php安装&#xff0c;后台处理脚本语言。 后端开发语言不能直接允许&#xff0c;必须放在服务器对对应的文件夹下运行。 如&#xff1a;wamp的对应服务器的文件夹是www get请求 <!DOCTYPE html> &l…

ArcGIS中分区统计栅格值前需要进行投影吗(在投影坐标系下进行吗),为什么?

最近&#xff0c;我接到了一个分区统计栅格数值前需要进行投影&#xff0c;或者说是必须需要在投影坐标系下进行吗的咨询。 答案是不需要刻意去变。 但是他又说他把地理坐标系下分区统计结果与投影坐标系下的分区统计结果分别做了一遍&#xff0c;并进行了对比&#xff0c;两个…

【数据结构与算法】排序算法

3.7 排序算法 概述 比较排序算法 算法最好最坏平均空间稳定思想注意事项冒泡O(n)O( n 2 n^2 n2)O( n 2 n^2 n2)O(1)Y比较最好情况需要额外判断选择O( n 2 n^2 n2)O( n 2 n^2 n2)O( n 2 n^2 n2)O(1)N比较交换次数一般少于冒泡堆O( n l o g n nlogn nlogn)O( n l o g n nlogn …

美化pytest运行:pytest-sugar

简介&#xff1a;pytest-sugar 是一个用于增强 pytest 测试框架的插件&#xff0c;它提供了美观的测试运行报告&#xff0c;使测试输出更加直观易读。通过简单的配置&#xff0c;开发者可以快速获得测试的状态、运行时间和其他关键信息。该模块特别适合于大型项目或团队合作&am…

[C#]winform部署官方yolov11-obb旋转框检测的onnx模型

【官方框架地址】 https://github.com/ultralytics/ultralytics 【算法介绍】 Yolov11-obb&#xff08;You Only Look Once version 8 with Oriented Bounding Boxes&#xff09;是一种先进的对象检测算法&#xff0c;它在传统的Yolov3和Yolov4基础上进行了优化&#xff0c;加…

Python深度学习进阶与前沿应用:注意力机制、Transformer模型、生成式模型、目标检测算法、图神经网络、强化学习等

近年来&#xff0c;伴随着以卷积神经网络&#xff08;CNN&#xff09;为代表的深度学习的快速发展&#xff0c;人工智能迈入了第三次发展浪潮&#xff0c;AI技术在各个领域中的应用越来越广泛。为了帮助广大学员更加深入地学习人工智能领域最近3-5年的新理论与新技术&#xff0…

【重学 MySQL】六十、空间类型

【重学 MySQL】六十、空间类型 空间数据类型的分类空间数据类型的属性空间数据的表示方式空间数据的操作应用场景 在MySQL中&#xff0c;空间类型&#xff08;Spatial Types&#xff09;主要用于支持地理特征的生成、存储和分析。这些地理特征可以表示世界上具有位置的任何东西…

【书生浦语实战】MindSearch 部署到HuggingFace Space

结果速览 欢迎来玩&#xff1a;https://huggingface.co/spaces/LLyn/mindsearch_exercise 配置开发环境 使用github codespace 第一次使用github的codespace&#xff5e;本质上跟在intern studio一样&#xff0c;但是页面是vscode效果&#xff08;intern studio是linux cl…

Carsim报错总结及解决方法

1. simulink报错&#xff1a;vs_state 、StopMode无法识别 - matlab命令行窗口输入&#xff1a;vs_state -1&#xff0c;StopMode -1 2. Video变暗&#xff0c;无法点击 - 说明书中提示&#xff1a;如果输出文件不存在&#xff08;例如&#xff0c;在单击复制按钮创…

关于ad 的焊盘自动排序功能说明

你是不是想&#xff0c;不想手动一个一个改焊盘的号数&#xff0c;真的很累&#xff0c;对吧 那么下来看看&#xff0c;关于这个的用法的说明 比如我要改这个红色框中的焊盘的序号&#xff0c;那么我们就先框选好&#xff0c;来到右边的栏目&#xff0c;看到红色圈出的地方&am…

深度学习--------------------------------使用注意力机制的seq2seq

目录 动机加入注意力Bahdanau注意力的架构 总结Bahdanau注意力代码带有注意力机制的解码器基本接口实现带有Bahdanau注意力的循环神经网络解码器测试Bahdanau注意力解码器该部分总代码 训练从零实现总代码简洁实现代码 将几个英语句子翻译成法语该部分总代码 将注意力权重序列进…

Oracle架构之物理存储中各种文件详解

文章目录 1 物理存储1.1 简介1.2 数据文件&#xff08;data files&#xff09;1.2.1 定义1.2.2 分类1.2.2.1 系统数据文件1.2.2.2 撤销数据文件1.2.2.3 用户数据文件1.2.2.4 临时数据文件 1.3 控制文件&#xff08;Control files&#xff09;1.3.1 定义1.3.2 查看控制文件1.3.3…

定时器定时中断定时器外部中断

基础背景&#xff1a;TIM定时中断-CSDN博客 TIM的函数 // 恢复缺省设置 void TIM_DeInit(TIM_TypeDef* TIMx); // 时基单元初始化&#xff0c;第一个参数TIMx选择某个定时器&#xff0c;第二个参数是结构体&#xff0c;包含了配置时基单元的一些参数。 void TIM_TimeBaseInit…

【时间盒子】-【9.任务设置项】自定义任务名称、任务时长等设置项组件

Tips: Stage、Link装饰器的使用&#xff1b; 参考我的帖子&#xff1a;https://developer.huawei.com/consumer/cn/forum/topic/0208152234389094513?fid0101587866109860105 一、预览 红色框&#xff1a;任务设置项列表&#xff0c;把它定义为一个组件对象SettingList。绿…

linux基础 超级笔记

1.Linux系统的组成 Linux系统内核&#xff1a;提供系统最核心的功能&#xff0c;如软硬件和资源调度。 系统及应用程序&#xff1a;文件、任务管理器。 2.Linux发行版 通过修改内核代码自行集成系统程序&#xff0c;即封装。比如Ubuntu和centos这种。不过基础命令是完全相…

【C++ Primer Plus】4

2 字符串 字符串是存储在内存的连续字节中的一系列字符&#xff1b;C处理字符串的方式有两种&#xff0c; c-风格字符串&#xff08;C-Style string&#xff09;string 类 2.1 c-风格字符串&#xff08;C-Style string&#xff09; 2.1.1 char数组存储字符串&#xff08;c-…

『网络游戏』自适应制作登录UI【01】

首先创建项目 修改场景名字为SceneLogin 创建一个Plane面板 - 将摄像机照射Plane 新建游戏启动场景GameRoot 新建空节点重命名为GameRoot 在子级下创建Canvas 拖拽EventSystem至子级 在Canvas子级下创建空节点重命名为LoginWnd - 即登录窗口 创建公告按钮 创建字体文本 创建输入…

Java:数据结构-初始结合框架 时间复杂度和空间复杂度 初识泛型

一 初始结合框架 1.什么是Java的集合框架 Java 的集合框架&#xff08;Java Collection Framework&#xff0c;JCF&#xff09;是 Java 标准库中的一部分&#xff0c;用于存储和操作一组数据。它提供了一些常用的数据结构和接口&#xff0c;用来高效管理和操作数据。Java 的…

TOP-K问题

目录 TOP-K问题 1.对TOP-K问题的理解 1.1.TOP-K问题定义 1.2.TOP-K问题的解决思路 1.3.以求N个数据中的前K个最大元素为例&#xff0c;阐述建堆来解决TOP-K的原理 1.4.TOP-K问题的类型 2.类型1&#xff1a;数据量N较小&#xff0c;可以全部加载到内存中。求数据量N的前K…