您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關HLS Lesson20的示例分析,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
當pipeline作用于函數的時候,從IO角度來看數據是沒有空隙的,而作用于循環時候,則相鄰的兩個循環之間會有一個空隙
實例:cordic
這里要求z0的取值范圍為[-π/2,π/2],對于[-π,π]的數就需要先進行預處理映射到[-π/2,π/2],然后再計算,最后再進行后處理。
#include"cordic.h"
void pre_cir_cordic(di_t full_alpha,di_t &alpha,flag_t &flag)
{
if(full_alpha>PI/2)
{
alpha=PI-full_alpha;
flag=2;
}
else if(full_alpha<-PI/2)
{
alpha=-PI-full_alpha;
flag=3;
}
else
{
alpha=full_alpha;
flag=0;
}
}
void cir_cordic_calc(di_t alpha,flag_t flag,do_t &mysin,do_t &mycos,flag_t &flag_delay)
{
const int N = 16;
do_t xi[N];
do_t yi[N];
di_t zi[N];
flag_t flag_delay_a[N];
xi[0]=Kn;
yi[0]=0;
zi[0]=alpha;
flag_delay_a[0]=flag;
const di_t myarctan[16] ={
#include"myarctan.h";
};
int m=0;
loop:
for(m=0;m<N;m++)
{
if(zi[m]>=0)
{
xi[m+1]=xi[m]-(yi[m]>>m);
yi[m+1]=yi[m]+(xi[m]>>m);
zi[m+1]=zi[m]-myarctan[m];
}
else
{
xi[m+1]=xi[m]+(yi[m]>>m);
yi[m+1]=yi[m]-(xi[m]>>m);
zi[m+1]=zi[m]+myarctan[m];
}
flag_delay_a[m+1]=flag_delay_a[m];
}
mysin=yi[N-1];
mycos=xi[N-1];
flag_delay=flag_delay_a[N-1];
}
void post_cir_cordic(do_t mysin,do_t mycos,flag_t flag_delay,do_t &sin_out,do_t &cos_out)
{
switch(int(flag_delay))
{
case 2:sin_out=mysin;cos_out=-mycos;break;
case 3:sin_out=mysin;cos_out=-mycos;break;
default:sin_out=mysin;cos_out=mycos;break;
}
}
void cir_cordic(di_t full_alpha,do_t &sin_out,do_t &cos_out)
{
di_t alpha;
flag_t flag;
do_t mysin;
do_t mycos;
flag_t flag_delay;
pre_cir_cordic(full_alpha,alpha,flag);
cir_cordic_calc(alpha,flag,mysin,mycos,flag_delay);
post_cir_cordic(mysin,mycos,flag_delay,sin_out,cos_out);
}
看完上述內容,你們對HLS Lesson20的示例分析有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。