对于函数,可以使用PIPELINE或DATAFLOW。
对于循环,可以使用PIPELINE(可选rewind)、UNROLL(可选factor)或DATAFLOW。
对于数组,可以使用ARRAY_PARTITION,有block、cyclic、complete三种优化方式。
data:image/s3,"s3://crabby-images/4653a/4653ad99d49259709417268f6a27bbe0b4ec4d34" alt=""
PIPELINE作用于函数和循环的情况如下,作用于循环时,两次循环之间会存在空档,被称为bubble,rewind可以解决这个问题。
data:image/s3,"s3://crabby-images/64e35/64e35d2fa44db5671dd846d64df5abbfab63f575" alt=""
对于latency,有专门的LATENCY约束用于函数和循环,可以指定min和max。
LOOP_MERGE用于合并多个循环
LOOP_FLATTEN用于perfect/semi-perfect循环
data:image/s3,"s3://crabby-images/0868f/0868f7f7ee8fb0a9f9d2817a14739e8d2648f04b" alt=""
在区域中:
数据类型和位宽也是影响硬件效率和资源使用的原因
INLINE用于函数
ALLOCATION用于函数的实例化
ARRAY_MAP和ARRAY_RESHAPE用于数组
FUNCTION_INSTANTIATE用于函数
data:image/s3,"s3://crabby-images/65676/6567616e4f297fa18fe8c90f0d82cfc4872d52e7" alt=""