FIFO深度计算分析
来源:互联网 发布:苹果铃声mac 编辑:程序博客网 时间:2024/05/17 08:59
FIFO深度计算分析
(2011-12-02 11:53:46)转载▼
标签:
fifo
分类: FPGA学习点滴FIFO深度计算分析
写时钟周期w_clk,
读时钟周期r_clk,
写时钟周期里,每B个时钟周期会有A个数据写入FIFO
读时钟周期里,每Y个时钟周期会有X个数据读出FIFO
则,FIFO的最小深度是?
首先,这道题不一定有解
有解的必要条件是在一定时间内(足够长),写入的数据数量一定要等于读出的数据数量
因此有:A/B * w_clk = X/Y * r_clk
其次,算出写数据的最大burst_length。考虑最坏情况
比如,如果条件给出,每100个写时钟,写入80个数据,那么在背靠背的情况下,burst_length = 2*80=160
最后,fifo_depth = burst_length - burst_length * X/Y * r_clk/w_clk
BTW:通常,为了安全起见,都会多留一些depth的余度
读时钟周期r_clk,
写时钟周期里,每B个时钟周期会有A个数据写入FIFO
读时钟周期里,每Y个时钟周期会有X个数据读出FIFO
则,FIFO的最小深度是?
首先,这道题不一定有解
有解的必要条件是在一定时间内(足够长),写入的数据数量一定要等于读出的数据数量
因此有:A/B * w_clk = X/Y * r_clk
其次,算出写数据的最大burst_length。考虑最坏情况
比如,如果条件给出,每100个写时钟,写入80个数据,那么在背靠背的情况下,burst_length = 2*80=160
最后,fifo_depth = burst_length - burst_length * X/Y * r_clk/w_clk
BTW:通常,为了安全起见,都会多留一些depth的余度
个人觉得,公式应该是这样:
A/(B * w_clk) = X/(Y * r_clk)
fifo_depth = burst_length - burst_length * X/Y * w_clk /r_clk
举例说明:
如果100个写时钟周期可以写入80个数据,10个读时钟可以读出8个数据
其中w_ck=5ns,r_ck=10ns
如果按照之前的公式,得出的深度为:fifo_depth = burst_length - burst_length * X/Y * r_ck/w_clk=160-160*8/10*2=-94,显然是不对的
实际上,考虑背靠背(20个clk不发数据+80clk发数据+80clk发数据+20个clk不发数据的200个clk)
这样在中间160个写时钟周期连续写的情况下,只能读出160*5/(10*10)*8=64个数据,所以FIFO的深度应该为160-64=96
也就是fifo_depth = burst_length - burst_length * X/Y * w_clk /r_clk=160-160*8/10*5/10=96
A/(B * w_clk) = X/(Y * r_clk)
fifo_depth = burst_length - burst_length * X/Y * w_clk /r_clk
举例说明:
如果100个写时钟周期可以写入80个数据,10个读时钟可以读出8个数据
其中w_ck=5ns,r_ck=10ns
如果按照之前的公式,得出的深度为:fifo_depth = burst_length - burst_length * X/Y * r_ck/w_clk=160-160*8/10*2=-94,显然是不对的
实际上,考虑背靠背(20个clk不发数据+80clk发数据+80clk发数据+20个clk不发数据的200个clk)
这样在中间160个写时钟周期连续写的情况下,只能读出160*5/(10*10)*8=64个数据,所以FIFO的深度应该为160-64=96
也就是fifo_depth = burst_length - burst_length * X/Y * w_clk /r_clk=160-160*8/10*5/10=96
0 0
- FIFO深度计算分析
- FIFO设计中的深度计算
- FIFO设计中的深度计算
- FIFO存储深度(容量)计算
- FIFO存储深度(容量)计算
- FPGA中对FIFO深度的计算
- Verilog基础知识7(FIFO深度计算)
- 关于FIFO深度的计算的讨论
- 异步FIFO最小深度计算方法及原理分析
- 异步 FIFO 最小深度计算方法及原理分析(转补)
- 互联网周刊:深度分析云计算
- 视差和深度分析与计算
- 关于FIFO的深度问题
- FIFO文件实现分析
- 深入理解FIFO(包含有FIFO深度的解释)
- FIFO和LRU计算缺页中断
- FIFO
- FIFO
- PAT:1001. A+B Format (20)
- hibernate注解方法使用总结
- Caffe 工程的一些编译错误以及解决方案(undefined reference to cv::imread)
- 求数值的的整数次方(模拟实现pow函数)
- codeforces-772C-Destroying Array
- FIFO深度计算分析
- Swift 08 备忘录模式 Memento Pattern
- byte(字节)根据长度转成KB(千字节)和MB(兆字节)
- 如何查询没有自增非空数字主键的表?
- 选择排序
- Swift 09 适配器模式 Adapter pattern
- 深度学习一
- HDU 1059 Dividing 多重背包 .
- kmp算法(字符串匹配)