FPGA开发:可编程逻辑器件概述

2024-09-06 13:28

本文主要是介绍FPGA开发:可编程逻辑器件概述,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PLD

1、什么是PLD?

PLD指Programmable Logic Device,翻译为"可编程逻辑器件"。是20世纪70年代发展起来的一种新的集成电路,是一种半定制的集成电路

PLD具有逻辑功能实现灵活。集成度高、处理速度快的特点。

  • PLD就像是一个可定制的积木盒,里面装满了各种各样的"电子积木"(逻辑门、触发器、寄存器等)。这些积木在盒子里原本没有固定的连接方式,但你可以根据自己的想法,像搭积木一样,将它们连接起来,创造出各种形状的玩具(即实现各种逻辑功能)。当你完成了这个定制过程,这个积木盒(PLD)就变成了一个专为你设计的玩具,能够执行你想要的任何逻辑操作。

2、PLD基本框架

任何组合逻辑表达式都可表达为"与-或"形式,因此通过对与、或阵列编程就可以得到任何我们想要的组合逻辑功能。

PLD基本框架
  • 首先外面信号加进来后,经过输入电路模块后,会得到一个互补输入(假如输入信号为A,经过输入电路模块后,会输出A和A');
  • 来到与门阵列,此模块将所有的互补过的变量根据要求去相与(假如此时有A、A'、B、B'、C、C'这几个变量,通过此模块后会输出若干乘积相,例如:ABC、AB、AC'、B'C'等等);
  • 再到或门阵列,此模块就是将前面输出的若干乘积项按要求相加(继续上述假设,则输出为ABC+AB+AC'+B'C'),最后输出即可。

3、PLD表示方式

由于PLD的与阵列和或阵列的规模很大,为了便于表达,其逻辑图的画法与传统画法不同,具体如下:

  • 连接的表示

其中硬线连接单元被编程接通单元都是指两条线是被连起来的,其区别为前者不可以编程的,后者是可编程的(连或不连可以控制)。

  • 基本门电路的表示

【注意】其中(b)是输出恒等于0的与门结构,通常打个"×"来表示。(d)是实现互补输出的结构。


4、PLD的分类

  • 按集成度

低密度器件:1000门以下为低密度(如PLA、GAL、PROM);

高密度器件:1000门以上为高密度(如CPLD、FPGA);

  • 按PLD结构体系

分为简单PLD(如PAL、GAL)、复杂可编程逻辑器件CPLD、现场可编程门阵列FPGA。

  • 按照与、或阵列是否可编程
与阵列固定、或阵列可编程PROM
与、或阵列均可编程PLA
与阵列可编程、或阵列固定PAL

 

  • 按逻辑函数实现方式
基于与、或阵列的PLD
基于查表LUT的PLD

这篇关于FPGA开发:可编程逻辑器件概述的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142134

相关文章

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD