Tcl之$$a 80%的概率......

2020-08-25 10:48:18 浏览数 (1)

上期内容:嵌套的for循环,到底对哪个执行pipeline更好

看一个典型的例子,如下图所示。变量x被赋值为10,变量a被赋值为字符x。之后,给变量b赋值$a。最终变量b的值将会是x,而不是10。

为什么b的值是$x,而不是10呢?这是因为Tcl的变量置换遵循如下两条规则:

规则1:Tcl在解析一条命令时,只从左向右解析一次,进行一轮置换,每一个字符只会被扫描一次。

规则2:每一个字符只会发生一层置换,而不会对置换后的结果再进行一次扫描置换。

根据上述规则,Tcl从左向右对命令“set b

a”进行解析,扫描所有的字符,发现

a时,执行变量置换,得到

那么如果期望$$a发生二次置换该如何操作呢?

方法1:采用[set var]的方式,如下图所示。代码第6行中括号中的set命令只跟随一个参数var,var发生变量置换,故set var等效于set a,而set a将返回变量a的值。本质上,var是[set var]的缩写版本。通过代码第10行和第12行可以看出,set后面如果只有一个参数,而这个参数又是一个已经定义的变量名,那么该命令就直接返回该变量的变量值,与

方法2:采用命令subst实现此目的,如下图所示。

AI Engine到底是什么?

ACAP不可不知的几个基本概念

HLS中循环的并行性(2)

HLS中循环的并行性(1)

HLS优化方法DATAFLOW你用了吗

HLS中如何控制流水程度

Vivado HLS学习资料有哪些

如何查看可综合C代码的中间结果

如何在C代码中插入移位寄存器

HLS IP Library?

HLS Math Library:csim ?C/RTL co-sim(2

HLS Math Library:csim ?C/RTL co-sim(1)

一些小巧的IP

IP是用DCP还是XCI?

如果使用第三方综合工具,Xilinx IP…

IP生成文件知多少

IP的约束需要处理吗?

IP为什么被Locked?

copy_ip你用过吗?

IP是XCI还是XCIX

如何降低OSERDES/CLK和CLKDIV的Clock Skew

如何获取Device DNA

谈谈设计复用

过约束到底怎么做

时序收敛之Baseline

什么情况下要用OOC综合方式

set_max_delay被覆盖怎么办

异步跨时钟域电路该怎么约束

如何复用关键路径的布局布线信息

Vivado学习资料有哪些?

异步跨时钟域电路怎么设计

ECO都有哪些应用

FPGA中的CLOCK REGION和SLR是什么含义

FPGA中的BEL, SITE, TILE是什么含义

约束文件有哪些

如何高效复用Block的位置信息?

如何复用关键寄存器的位置信息

部分可重配置都生成哪些.bit文件

VIO你用对了吗

Device视图下能看到什么

Schematic视图下能看到什么

都是pin,有什么区别

都是net,有什么区别

如何快速查找目标cell

学习笔记:深度学习与INT8

学习笔记:多层感知器

学习笔记:单层感知器的局限性

学习笔记:单层感知器基础知识

学习笔记:神经网络学习算法

学习笔记:神经网络模型

学习笔记:ReLU的各种变形函数

学习笔记:神经元模型(2)

学习笔记:神经元模型(1)

学习笔记:深度学习之“深”

学习笔记:深度学习之“学习”

学习笔记:人工智能、机器学习和深度学习

2019文章汇总

文 | Lauren 图 | Lauren

Copyright @ Lauren的FPGA

转载事宜请私信 | 获得授权后方可转载

0 人点赞