barrel_shift
barrel_shift的目的就是在一个bus中根据idx动态选择一部分数据输出如:
*dw-:]; -:];// 0~132 *dw-:];
上面就要求从256的数据单元中选择124个数据单元输出,输出的起始位置为idx(取值只能爱0~132,如果取值超过132,比如是140,那么140~255不够124个数据,输出中会出现重复的数据)
数据选择其实就是mux,不过这里是要选择出多个数据(124个),需要按段进行选择;通过根据idx的译码选择出124+2^n-1个数据(必须保证选择出的数据包含了需要的124个数据,2^n-1是在找选择数据段的起始)
定义一些中间连线:
:]s0[];// widht = 124 + 2^0 - 1 :]s1[];// widht = 124 + 2^1 - 1 :]s2[];// widht = 124 + 2^2 - 1 :]s3[];// widht = 124 + 2^3 - 1 :]s4[];// widht = 124 + 2^4 - 1 :]s5[];// widht = 124 + 2^5 - 1 :]s6[];// widht = 124 + 2^6 - 1 :]s7[];// widht = 124 + 2^7 - 1 :]s8[];//input width
首先需要对输入的数据进行分块,以dw位宽为一个块,用二位数组缓存起来。
generate ;i<;i=i+)begin:REFORM_INPUT always@(*)begin s8[i][+:dw] = din[i*dw +: dw]; end end endgenerate
先开始进行idx的最高位进行译码,将din的数据分为两部分,输出的数据的起点就会在这两部分数据中,假设起点在前一部分,即起点为din[0*dw],din[1*dw]....din[127*dw],如果起点是din[127*dw]那么输出数据会是din[127*dw:(127+124-1)*dw],这部分数据包括了后半部分是数据。考虑完备,根据idx[7]的选择,需要输出128+124-1个数据(使用的2分法译码)
generate ;i<;i=i+)begin:SEL7 )begin always@(*)begin ]=='b0)begin s7[i] = s8[i]; end else begin s7[i] = s8[i+]; end end end else begin always@(*)begin s7[i] = s8[i];//只有在idx[7]==1'b0的时候才有意义,idx[7]==1'b1的时候会出现一部分重复数据。 end end end endgenerate
根据判断idx[7]从256中选择出251个数据,接下来要判断idx[6]选择出124 + 2^6 -1 = 187个数据
generate ;i<;i=i+)begin:SEL6 always@(*)begin ]=='b0)begin s6[i] = s7[i]; end else begin s6[i] = s7[i+]; end end end endgenerate
接下来的每判断idx[k]就可以去除2^k个数据,最后只剩下124个数据
generate ;i<;i=i+)begin:SEL5 always@(*)begin ]=='b0)begin s5[i] = s6[i]; end else begin s5[i] = s6[i+]; end end end endgenerate generate ;i<;i=i+)begin:SEL4 always@(*)begin ]=='b0)begin s4[i] = s5[i]; end else begin s4[i] = s5[i+]; end end end endgenerate generate ;i<;i=i+)begin:SEL3 always@(*)begin ]=='b0)begin s3[i] = s4[i]; end else begin s3[i] = s4[i+]; end end end endgenerate generate ;i<;i=i+)begin:SEL2 always@(*)begin ]=='b0)begin s2[i] = s3[i]; end else begin s2[i] = s3[i+]; end end end endgenerate generate ;i<;i=i+)begin:SEL1 always@(*)begin ]=='b0)begin s1[i] = s2[i]; end else begin s1[i] = s2[i+]; end end end endgenerate generate ;i<;i=i+)begin:SEL0 always@(*)begin ]=='b0)begin s0[i] = s1[i]; end else begin s0[i] = s1[i+]; end end end endgenerate
最后将s0数组中的数据转成输出数据的格式:
generate ;i<;i=i+)begin:GET_OUT always@(*)begin dout[i*dw +: dw] = s0[i]; end end endgenerate
berral shift使用场景,比如两个128的数据中选择124个数据输出就可以将两个128的数据拼起来,然后根据idx输出124个数据。
barrel_shift的更多相关文章
随机推荐
- 那什么时候会触发BFC呢?块级格式化上下文
<html>根元素: float的值不为none: overflow的值为auto.scroll或hidden: display的值为table-cell.table-caption和in ...
- kvm虚拟机中鼠标不同步的问题解决方法
环境:Centos7.6安装kvm创建windows虚拟机,通过novnc连接到虚拟机上发现存在鼠标位置偏移问题 解决方法: 方法一: 经测试,windows系列虚拟机关闭鼠标加速亦可缓解该问题,不过 ...
- eclipse如何更换工作空间
关于工作空间的更换,小生也操作较少,今天做个记录并分享给大家. 1.找到文件——更换工作空间——其他 2.选择自己要更换的工作空间点击确定即可.
- docker删除已经停止的容器
前言:docker容器已经停止运行的容器,怎么清理 1.如图: docker ps -a :显示所有运行过的docker容器 status : docker容器的状态 docker ...
- Python-数据类型之字典
一: 概述 字典是有大括号,逗号分隔,有k/v组成 字典的键必须hashable,如数字,字符串,布尔值,元组 二: 操作 2.1 增 2.1.1 直接赋值 如果键不存在,则增加 dic = {'n ...
- python3与mysql交互
1.安装pymysql模块 pip3 install pymysql3 2.pymysql的简单使用: # /usr/bin/env python3 import pymysql class Mysq ...
- Celery提交任务出错?
跟着官方的入门教程部署和运行的,为啥报这个错? tasks.py # -*- encoding:UTF-8 -*- from celery import Celery brokers = 'redis ...
- Eclipse 那些小技巧(值得收藏)
1.菜单命令系列 Edit→content Assist→add Alt+/ 代码关联 Windows→Next Editor→add Ctrl+Tab 切换窗口 Run→Debug Toggle L ...
- 小程序API
基础: wx.canIUse(string) boolean wx.canIUse(string schema) 判断小程序的API,回调,参数,组件等是否在当前版本可用. 参数说明 ${A ...
- docker使用教程
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Li ...