数字IC设计思想之“乒乓操作”的总结与思考_weixin_30724853的博客-程序员秘密

   

图表 1

“ 乒乓操作 ” 是一个常常应用于数据流控制的处理技巧,典型的乒乓操作方法如图 1 所示。

乒乓操作的处理流程为:输入数据流通过 “ 输入数据选择单元 ” 将数据流等时分配到两个数据缓冲区,数据缓冲模块可以为任何存储模块,比较常用的存储单元为双口 RAM(DPRAM) 、单口 RAM(SPRAM) 、 FIFO 等。在第一个缓冲周期,将输入的数据流缓存到 “ 数据缓冲模块 1” ;在第 2 个缓冲周期,通过 “ 输入数据选择单元 ” 的切换,将输入的数据流缓存到 “ 数据缓冲模块 2” ,同时将 “ 数据缓冲模块 1” 缓存的第 1 个周期数据通过 “ 输入数据选择单元 ” 的选择,送到 “ 数据流运算处理模块 ” 进行运算处理;在第 3 个缓冲周期通过 “ 输入数据选择单元 ” 的再次切换,将输入的数据流缓存到 “ 数据缓冲模块 1” ,同时将 “ 数据缓冲模块 2” 缓存的第 2 个周期的数据通过 “ 输入数据选择单元 ” 切换,送到 “ 数据流运算处理模块 ” 进行运算处理。如此循环。(Eric:类似于视频图像处理中一帧的“场”缓存处理方式,只不过“乒乓操作”不带标记,通过时序的约束条件工作)

乒乓操作的最大特点是通过 “ 输入数据选择单元 ” 和 “ 输出数据选择单元 ” 按节拍、相互配合的切换,将经过缓冲的数据流没有停顿地送到 “ 数据流运算处理模块 ” 进行运算与处理。把乒乓操作模块当作一个整体,站在这个模块的两端看数据,输入数据流和输出数据流都是连续不断的,没有任何停顿,因此非常适合对数据流进行流水线式处理。所以乒乓操作常常应用于流水线式算法,完成数据的无缝缓冲与处理。

乒乓操作的第二个优点是可以节约缓冲区空间。比如在 WCDMA 基带应用中, 1 个帧是由 15 个时隙组成的,有时需要将 1 整帧的数据延时一个时隙后处理,比较直接的办法是将这帧数据缓存起来,然后延时 1 个时隙进行处理。这时缓冲区的长度是 1 整帧数据长,假设数据速率是 3.84Mbps , 1 帧长 10ms ,则此时需要缓冲区长度是 38400 位。如果采用乒乓操作,只需定义两个能缓冲 1 个时隙数据的 RAM( 单口 RAM 即可 ) 。当向一块 RAM 写数据的时候,从另一块 RAM 读数据,然后送到处理单元处理,此时每块 RAM 的容量仅需 2560 位即可, 2 块 RAM 加起来也只有 5120 位的容量。

  

图表 2

另外,巧妙运用乒乓操作还可以达到用低速模块处理高速数据流的效果。如图 2 所示,数据缓冲模块采用了双口 RAM ,并在 DPRAM 后引入了一级数据预处理模块,这个数据预处理可以根据需要的各种数据运算,比如在 WCDMA 设计中,对输入数据流的解扩、解扰、去旋转等。假设端口 A 的输入数据流的速率为 100Mbps ,乒乓操作的缓冲周期是 10ms 。以下分析各个节点端口的数据速率。

A 端口处输入数据流速率为 100Mbps ,在第 1 个缓冲周期 10ms 内,通过 “ 输入数据选择单元 ” ,从 B1 到达 DPRAM1 。 B1 的数据速率也是 100Mbps , DPRAM1 要在 10ms 内写入 1Mb 数据。同理,在第 2 个 10ms ,数据流被切换到 DPRAM2 ,端口 B2 的数据速率也是 100Mbps , DPRAM2 在第 2 个 10ms 被写入 1Mb 数据。在第 3 个 10ms ,数据流又切换到 DPRAM1 , DPRAM1 被写入 1Mb 数据。

仔细分析就会发现到第 3 个缓冲周期时,留给 DPRAM1 读取数据并送到 “ 数据预处理模块 1” 的时间一共是 20ms 。有的工程师困惑于 DPRAM1 的读数时间为什么是 20ms ,这个时间是这样得来的:首先,在第 2 个缓冲周期向 DPRAM2 写数据的 10ms 内, DPRAM1 可以进行读操作;另外,在第 1 个缓冲周期的第 5ms 起 ( 绝对时间为 5ms 时刻 ) , DPRAM1 就可以一边向 500K 以后的地址写数据,一边从地址 0 读数(Eric: DPRAM有两套独立的读写和地址线,能同时进行随机访问操作),到达 10ms 时, DPRAM1 刚好写完了 1Mb 数据,并且读了 500K 数据,这个缓冲时间内 DPRAM1 读了 5ms ;在第 3 个缓冲周期的第 5ms 起 ( 绝对时间为 35ms 时刻 ) ,同理可以一边向 500K 以后的地址写数据一边从地址 0 读数,又读取了 5 个 ms ,所以截止 DPRAM1 第一个周期存入的数据被完全覆盖以前, DPRAM1 最多可以读取 20ms 时间,而所需读取的数据为 1Mb ,所以端口 C1 的数据速率为: 1Mb/20ms=50Mbps 。因此, “ 数据预处理模块 1” 的最低数据吞吐能力也仅仅要求为 50Mbps 。同理, “ 数据预处理模块 2” 的最低数据吞吐能力也仅仅要求为 50Mbps 。换言之,通过乒乓操作,数据预处理模块的时序压力减轻了,所要求的数据处理速率仅仅为输入数据速率的 1/2

通过乒乓操作实现低速模块处理高速数据的实质是:通过 DPRAM 这种缓存单元实现了数据流的串并转换,并行用 “ 数据预处理模块 1” 和 “ 数据预处理模块 2” 处理分流的数据,是面积与速度互换原则的体现!

转载于:https://www.cnblogs.com/Amazing-Eric/archive/2010/05/10/1731764.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_30724853/article/details/94772770

智能推荐

TTGO可编程手表入门_库 esp insights 中的分类 '' 不可用。设置为 'uncategorized_流鱼a_ec的博客-程序员秘密

一、简介前几天淘了一款可编程手表,于是准备玩一下这个小玩意。二、环境搭建在开始之前,首先就是搭建相关的环境。按照说明书上的来,不可避免的,我又遇到了麻烦。于是开始在百度上寻找答案。终于找到一篇博文:(16条消息) ESP32环境搭建(arduino)_风度青年的博客-程序员秘密_arduino esp32...

Spark面试相关_aeluwl2038的博客-程序员秘密

Spark Core面试篇01一、简答题1.Spark master使用zookeeper进行HA的,有哪些元数据保存在Zookeeper?答:spark通过这个参数spark.deploy.zookeeper.dir指定master元数据在zookeeper中保存的位置,包括Worker,Driver和Application以及Executors。standby节点要从zk中获...

gaussdb 数据库用户和安全管理【数据加密】【03】_高斯数据库关闭ssl加密_Zhao.Mr的博客-程序员秘密

1. 数据加密数据加密的密钥由系统对钱夹密码的复杂变化逻辑生成。钱夹密码由用户指定输入,必须符合密码复杂度要求。注意:GaussDB不提供修改钱夹密码的接口,一旦设定,请牢记。01.设定用于数据加密的钱夹密码。通过以下SQL命令设定钱夹密码,以设定钱夹密码为gaussdb_123为例:ALTER SYSTEM SET ENCRYPTION KEY IDENTIFIED BY 'gaussdb_123'; 说明:钱夹密码设定后,GaussDB通过对钱夹密码的一系列复杂变化,生成用于数

ATM模拟(查余额,存款,取款)_一键生成atm机余额视频_是小光a~的博客-程序员秘密

ATM模拟该代码只能执行简单的查余额,存款,取款操作(卡号信息由用户输入,默认密码为"000000",默认余额为0)该代码缺点:功能较少,注释信息,提示信息较多,虽然部分体现了类的思想,但是主函数中仍然是大的模拟,可以优化为操作类或外部函数来使代码具有可读性(这个代码读起来还是挺烦的)。。。#include<cstdio>#include<iostream>#in...

win10/11安装子系统 ubuntu18.04 wsl 及其 gcc/g++ 安装_卷中卷的博客-程序员秘密

win10/11安装子系统 ubuntu18.04 wsl 及其 gcc/g++ 安装

overpass language 笔记_ssuqin001的博客-程序员秘密

原创链接:https://blog.csdn.net/sakuya_kazuya/article/details/72306979overpass turbo的query语言分为QL和XML两种,所获得的结果是一样的。XML语言需要以<osm-script></osm-script>包围,<osm-script output="json">可以定义输出数...

随便推点

L1-018 大笨钟 (10 分) python_微博上有个自称“大笨钟v”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于_马里奥赛德的博客-程序员秘密

微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当...

HTML鼠标移到导航上面时当前的LI变色_坦GA的博客-程序员秘密

原文地址:http://www.cnblogs.com/roucheng/p/3452230.html鼠标移到导航上面 当前的LI变色 处于当前的位置,广泛应用于当前导航。点击这里查看效果以下是源代码: 1 html> 2 head> 3 meta http-equiv="Content-Type" content="text/html; charset=utf8"

智能POS机项目原理分析_hjw45611的博客-程序员秘密

开发本质智能POS机本质上就是一个Android手机,我们要开发的支付软件从本质上也是一个普通的app,只不过这个Android手机是根据指定商家进行配置的,所以我们开发的app也只能给特定POS机使用,POS机厂家通过审核商家材料定制出商家POS机,商家就可以在POS机的应用商店下载并使用商家自己的app进行支付收银操作。商家现在的操作场景是在PC系统收银调起POS机app,这就是在云端...

K8S Core-DNS-程序员秘密

1. Kube-dns1.1 概述KubeDNS 由三部分构成:kube-dns:核心组件KubeDNS:依赖 client-go 中的 informer 机制,监听 Service 和 Endpoint 的变化情况,并将相关信息更新到 SkyDNS 中SkyDNS:负责 DNS 解析,监听在 10053 端口,同时也监听在 10055 端口提供 metrics 服务dnsmasq:区分 Domain 是集群内部还是外部,给外部域名提供上游解析,内部域名发往10053端口,并将解析

MR本地运行报错:[email protected]的博客-程序员秘密

文章目录1.问题2.解决1.问题在Win10环境下运行MR任务,报错如下:D:\Java\jdk1.8.0_201\bin\java.exe "-javaagent:D:\Program Files\JetBrains\IntelliJ IDEA 2020.1\lib\idea_rt.jar=64181:D:\Program Files\JetBrains\IntelliJ IDEA 2020.1\bin" -Dfile.encoding=UTF-8 -classpath D:\Java\jdk1.8