Verilog

Friday, June 23, 2006

吊橋的程式

這次的吊橋,自己有嘗試去寫過,可是卻漏洞百出,慘不忍睹阿,只好參考同學所作出來的程式,經過一番了解,與跟人探討後,無形中亦學到了很多東西!雖然這個版本的程式,每個後面都有註解,但還是有些東西是字面上所得不到的,一定要自己思考過,重新寫過一次,這樣東西才會變成自己的!

===================================================================

module bridge();
real fL,fR,w,dx,ans,t1,t2,t3,a;
real change,app,dff,max;
integer i; //正整數I
parameter nodes=11; //節點我看就不要改好ㄌ
reg[0:100]x[0:nodes]; //有N個點每一點都有100個位元
reg[0:100]a1,a2,a3,temp;
initial //initial區塊
begin
dff=1.0; //為分兩次的值
fL=10.0; //吊橋最左邊低高度
fR=20.0; //吊橋最右邊低高度
w=10.0; //吊橋低寬度
a=(fR-fL-0.5*dff*w*w)/w; //為解析法中X項的的係數0.5*dff*i*dx*i*dx+"a"*i*dx+fL
dx=w/(nodes-1); //節點之間低距離
max=1.0; //最大誤差起始值
x[0]=$realtobits(fL); //將FL轉成2進制存到X[0]裡面
x[nodes-1]=$realtobits(fR); //將FR轉成2進制存到x[nodes-1]裡面
for(i=1;i<=nodes-2;i=i+1) //起始化但是保留最左邊根最右邊的值 x[i]=0.0; //將X[1]到X[9]起始值都設為0 while (max>0.001)//最大誤差要是比0.001大或是-0.001大就進入回圈
begin
max=0.0;
for(i=1;i<=nodes-2;i=i+1)//此FOR迴圈開始就是疊代 begin //此三數為連續如456那a1=4 a2=5 a3=6 a1=x[i-1];//左邊的點 a2=x[i];//中間的點 a3=x[i+1];//右邊的點 t1=$bitstoreal(a1);//必須轉回10進制才能運算 t2=$bitstoreal(a2);//必須轉回10進制才能運算 t3=$bitstoreal(a3);//必須轉回10進制才能運算 ans=0.5*(t1+t3-dff*dx*dx);//此行老師為必考推導過程下面附注 change=ans-t2;//把後面算出來的減掉前一次所算出的答案 x[i]=$realtobits(ans);//把ANS轉成2進制存到X[i] if(change<0) change="change*-1.0;//">max)//change要是比MAX大MAX換成change
max=change;//
end
end
for(i=0;i begin
temp=x[i];//將上一個迴圈的X[i]抓下來存到temp
app=$bitstoreal(temp);//再把temp轉成10進制存到app
$display(" nodes %d\n 差分 %f 解析 %f\n"
,i,app,0.5*dff*i*dx*i*dx+a*i*dx+fL);
//0.5*dff*i*dx*i*dx+a*i*dx+fL此行為解析法就是對dff做兩次積分所得到的]
end
end
endmodule
//ANS推導
//d^2w/dx^2={a1-2(a2)+a3}/dx^2=dff
//{a1-2(a2)+a3}/dx^2=dff把此式做移項
//a1-2a2+a3=(dff)(dx^2)
//2a2=(dff)(dx^2)-a1-a3
//a2={(dff)(dx^2)-a1-a3}/2
//參考老師C語言P195頁
//a=(fR-fL-0.5*dff*w*w)/w;推導
//對d^2w/dx^2=dff做兩次積分
//dw/dx=dff*x+a第一次積分
//w(x)=1/2(dff*x^2)+a*x+b
//將邊界條件帶入
//當x=0(即是吊橋最左邊=fl)w(0)=fl
//1/2(dff*0^2)+a*0+b=fl所以a跟dff項為0所以fl=b
//所以原式改寫成
//w(x)=1/2(dff*x^2)+a*x+fl
//當x=10(即是吊橋最左邊=fr)w(10)=fr
//1/2(dff*w^2)+a*w+fl=fr
//求出a
//a*w=fr-fl-1/2(dff*w^2)
//a={fr-fl-1/2(dff*w^2)}/w
//搞定


Friday, June 09, 2006

test_Add_rca_4

感覺老師給的課堂作業比較難了,原本以為只是把課本的東西打一打,然後再加個top上去,就可以跑出來了,可是sum、c_out那邊都跑不出來。經由老師的開導,跟參考同學的程式碼,原來是要在內部加訊號就可,而不用加top送訊息進去,真是不經一事不長一智阿!
===================================================================
module test_Add_rca_4();
reg [3:0] a,b;
reg c_in;
wire [3:0] sum;
wire c_out;

initial
begin
a=1;
b=1;
c_in=1;
#40
$display ($time,,"sum=%b c_out=%b C_in4=%b c_in3=%b c_in2=%b c_in=%b",sum,c_out,M1.c_in4,M1.c_in3,M1.c_in2,c_in);
end

initial
begin
//stomulus patterns for data paths go here
end

Add_rca_4 M1 (sum,c_out,a,b,c_in); //module declaration
endmodule

module Add_rca_4(sum,c_out,a,b,c_in);
output [3:0] sum;
output c_out;
input [3:0] a,b;
input c_in;
wire c_out,c_in4,c_in3,c_in2;
Add_full G1(sum[0],c_in2,a[0],b[0],c_in);
Add_full G2(sum[1],c_in3,a[1],b[1],c_in2);
Add_full G3(sum[2],c_in4,a[2],b[2],c_in3);
Add_full G4(sum[3],c_out,a[3],b[3],c_in4);

endmodule
module Add_full(sum,c_out,a,b,c_in);
input a,b,c_in;
output c_out,sum;
wire w1,w2,w3;
half_adder m1(w1,w2,a,b);
half_adder m2(sum,w3,c_in,w1);
or (c_out,w2,w3);
endmodule

module half_adder(sum,c_out,a,b);
input a,b;
output sum,c_out;
wire c_out_bar;
xor (sum,a,b);
nand (c_out_bar,a,b);
not (c_out,c_out_bar);
endmodule

Friday, June 02, 2006

本次上課心得

這次上課,聽老師教的內容,讓我有種當頭棒喝的感覺,真是一語驚醒夢中人,有如打通任督二脈,一舉成為武林高手!原來reg跟wire的差別只需短短的幾句話就能詮釋,老師就是老師,行家一出手,果然不同凡響!