Excess 3 Adder: Add 2 three digits numbers in excess 3. ex. 998+345 in excess 3. i don't have any idea on how to continue, please help. thx ! module Decimal_to_E3(input[10:0] dec, output reg[15:0] E3); reg[10:0] aux; reg[1:0] counter; always @ (dec) begin aux = dec; E3 = {4{4'b0011}}; counter = 2'b00; while(aux != 0) begin E3[counter * 4 +: 4] = aux % 10 + 3; aux = aux / 10; counter = counter + 1; end end endmodule //E3_Adder module E3_Adder(input [11:0] in_1, in_2, output [15:0] out_1); PA v1(in_1[3:0],in_2[3:0], out_1[3:0], cout); //how do i continue ???? endmodule module PA(a,b,sum,cout); input [3:0]a, b; output cout; output [3:0]sum; wire c0,c1,c2; HA u1(a[0], b[0], sum[0], c0); FA u2(a[1], b[1], c0, sum[1], c1); FA u3(a[2], b[2], c1, sum[2], c2); FA u4(a[3], b[3], c2, sum[3], cout); endmodule module FA(a, b, cin, sum, carry); input a, b, cin; output sum, carry; wire sum, carry; assign sum = a^b^cin;//sum bit assign carry = ((a&b) | (b&cin) | (a&cin));//carry bit endmodule module HA(a, b, sum, carry); input a, b; output sum, carry; wire sum, carry; assign sum = a^b; assign carry = a&b; endmodule /* module P_Adder(a,b,sum, cin, cout); input a */ module Decimal_to_E3_tb(); reg[10:0] dec_tb; wire[15:0] E3_tb; Decimal_to_E3 DUT(.dec(dec_tb), .E3(E3_tb)); initial begin for(dec_tb = 0; dec_tb <= 2000; dec_tb = dec_tb + 1) begin #1; $display("For value = %d, the output is = %0X", dec_tb, E3_tb); end end endmodule /* Arhitectura lui E3_Adder_tb este: ______________________________ ________________________ | | | | test_input_1 --.------>|>dec E3>|---in_1_tb---->|>in_1 | | | Decimal_to_E3 | | | | |_____________________________| | | ___________ | | E3_Adder | | | | ______________________________ | [DUT] out_1>|----out_1_tb_actual-------------------------------->| | | | | | | | | test_input_2 - ( --.-->|>dec E3>|---in_2_tb---->|>in_2 | | | | | | Decimal_to_E3 | | | | | | | |_____________________________| |________________________| | | | | _________ ______________________________ | Comparare |----REZULTAT_TEST-------> | |---------------------test_input_2-------->| | | | | | | | | | | | | | | + |-----test_output_1--->|>dec E3>|---out_1_tb_exp---->| | | | | | Decimal_to_E3 | | | |-------------------------test_input_1-------->|_________| |______________________________| |___________| */ module E3_Adder_tb(); /* Urmatorii parametrii ai testului pot fi modificati: DISPLAY_ALL: 0 sau 1. Daca DISPLAY_ALL este 1, atunci mai multe detalii despre fiecare test vor fi afisate pe ecran. Altfel, doar rezultatul testului va fi tiparit, cu diferenta dintre rezultatul corect si cel caclulat de E3_Adder, in cazul in care difera. DISPLAY_FAILED: 0 sau 1. Daca DISPLAY_FAILED este 1, atunci doar testele failed vor fi afisate pe ecran. Altfel, si rezultatele passed se vor afisa. NAX_VAL_in1: Valoarea maxima la care poate ajunge intrarea in_1, exprimata in decimal. MAX_VAL_in2: Valoarea maxima la care poate ajunge intrare in_2, exprimata in decimal. Testul va lua toate perechile de (in_1, in_2) din intervalul MAX_VAL_in1 X MAX_VAL_in2 si va compara rezultatul obtinut de E3_Adder cu cel corect IMPORTANT: Nota pentru testbenchul public va fi acordata pentru testele care ruleaza cu MAX_VAL_in1 = 500 si MAX_VAL_in2 = 500 */ wire[11:0] in_1_tb, in_2_tb; reg[10:0] test_input_1, test_input_2, test_output_1; wire[15:0] out_1_tb_actual, out_1_tb_exp; reg[10:0] MAX_VAL_in1, MAX_VAL_in2; reg DISPLAY_ALL, DISPLAY_ONLY_FAILED; integer n_tests_passed, n_tests_total; /* Modul ajutator de convertire din decimal in E3 */ Decimal_to_E3 convert_input_1(.dec(test_input_1), .E3(in_1_tb)); Decimal_to_E3 convert_input_2(.dec(test_input_2), .E3(in_2_tb)); Decimal_to_E3 convert_output_1(.dec(test_output_1), .E3(out_1_tb_exp)); /* Modulul testat */ E3_Adder DUT(.in_1(in_1_tb), .in_2(in_2_tb), .out_1(out_1_tb_actual)); initial begin /* parametrii configurabili */ DISPLAY_ALL = 1'b1; DISPLAY_ONLY_FAILED = 1'b1; MAX_VAL_in1 = 11'd500; MAX_VAL_in2 = 11'd500; /* ======================== */ n_tests_total = (MAX_VAL_in1 + 1) * (MAX_VAL_in2 + 1); n_tests_passed = 0; if(MAX_VAL_in1 > 999 || MAX_VAL_in2 > 999) begin $display("[WARNING] Testul nu va functiona cum trebuie! Valorile maxime NU trebuie sa fie mai mari de 999"); end for(test_input_1 = 0; test_input_1 <= MAX_VAL_in1; test_input_1 = test_input_1 + 1) begin for(test_input_2 = 0; test_input_2 <= MAX_VAL_in2; test_input_2 = test_input_2 + 1) begin test_output_1 = test_input_1 + test_input_2; #1; $display("Test nr: %d", test_input_1 * (MAX_VAL_in2 + 1) + test_input_2 + 1); if(DISPLAY_ALL == 1'b1) begin $display("Pentru urmatoarele intrari:\nin_1(decimal) = %d, in_1(E3) = %b \nin_2(decimal) = %d, in_2(E3) = %b \n", test_input_1, in_1_tb, test_input_2, in_2_tb); $display("Rezultatul asteptat: out_1(decimal) = %d, out_1(E3) = %b", test_output_1, out_1_tb_exp); $display("Rezultatul obtinut: out_1(E3) = %b", out_1_tb_actual); end if(out_1_tb_exp == out_1_tb_actual) begin if(DISPLAY_ONLY_FAILED == 0) begin $display("Testul este PASSED"); end n_tests_passed = n_tests_passed + 1; end else begin $display("Testul este FAILED"); $display("EXP E3: %b_%b_%b_%b =/= ACTUAL E3: %b_%b_%b_%b", out_1_tb_exp[15:12], out_1_tb_exp[11:8], out_1_tb_exp[7:4], out_1_tb_exp[3:0], out_1_tb_actual[15:12], out_1_tb_actual[11:8], out_1_tb_actual[7:4], out_1_tb_actual[3:0]); end $display("============================================================================================================="); $display(""); $display(""); end end $display("Teste passed: %d / %d", n_tests_passed, n_tests_total); end endmodule
Excess 3 Adder: Add 2 three digits numbers in excess 3.
Started by ●December 14, 2022
Reply by ●December 14, 20222022-12-14
On Wednesday, December 14, 2022 at 8:49:14 AM UTC-4, Virulog_X wrote:> Excess 3 Adder: Add 2 three digits numbers in excess 3. > ex. 998+345 in excess 3. > > i don't have any idea on how to continue, please help. > thx ! > > module Decimal_to_E3(input[10:0] dec, output reg[15:0] E3); > reg[10:0] aux; > reg[1:0] counter; > always @ (dec) begin > aux = dec; > E3 = {4{4'b0011}}; > counter = 2'b00; > while(aux != 0) begin > E3[counter * 4 +: 4] = aux % 10 + 3; > aux = aux / 10; > counter = counter + 1; > end > end > endmodule > > > //E3_Adder > > module E3_Adder(input [11:0] in_1, in_2, > output [15:0] out_1); > > PA v1(in_1[3:0],in_2[3:0], out_1[3:0], cout); > //how do i continue ???? > > endmodule > > > > module PA(a,b,sum,cout); > input [3:0]a, b; > output cout; > output [3:0]sum; > wire c0,c1,c2; > HA u1(a[0], b[0], sum[0], c0); > FA u2(a[1], b[1], c0, sum[1], c1); > FA u3(a[2], b[2], c1, sum[2], c2); > FA u4(a[3], b[3], c2, sum[3], cout); > endmodule > > > > module FA(a, b, cin, sum, carry); > input a, b, cin; > output sum, carry; > wire sum, carry; > assign sum = a^b^cin;//sum bit > assign carry = ((a&b) | (b&cin) | (a&cin));//carry bit > endmodule > > > module HA(a, b, sum, carry); > input a, b; > output sum, carry; > wire sum, carry; > assign sum = a^b; > assign carry = a&b; > endmodule > > > /* > module P_Adder(a,b,sum, cin, cout); > input a > */ > > > module Decimal_to_E3_tb(); > reg[10:0] dec_tb; > wire[15:0] E3_tb; > > Decimal_to_E3 DUT(.dec(dec_tb), .E3(E3_tb)); > initial begin > for(dec_tb = 0; dec_tb <= 2000; dec_tb = dec_tb + 1) begin > #1; > $display("For value = %d, the output is = %0X", dec_tb, E3_tb); > end > end > endmodule > > /* > Arhitectura lui E3_Adder_tb este: > ______________________________ ________________________ > | | | | > test_input_1 --.------>|>dec E3>|---in_1_tb---->|>in_1 | > | | Decimal_to_E3 | | | > | |_____________________________| | | ___________ > | | E3_Adder | | | > | ______________________________ | [DUT] out_1>|----out_1_tb_actual-------------------------------->| | > | | | | | | | > test_input_2 - ( --.-->|>dec E3>|---in_2_tb---->|>in_2 | | | > | | | Decimal_to_E3 | | | | | > | | |_____________________________| |________________________| | | > | | _________ ______________________________ | Comparare |----REZULTAT_TEST-------> > | |---------------------test_input_2-------->| | | | | | > | | | | | | | > | | + |-----test_output_1--->|>dec E3>|---out_1_tb_exp---->| | > | | | | Decimal_to_E3 | | | > |-------------------------test_input_1-------->|_________| |______________________________| |___________| > */ > module E3_Adder_tb(); > /* > Urmatorii parametrii ai testului pot fi modificati: > DISPLAY_ALL: 0 sau 1. Daca DISPLAY_ALL este 1, atunci mai multe detalii despre fiecare test vor fi afisate pe ecran. > Altfel, doar rezultatul testului va fi tiparit, cu diferenta dintre rezultatul corect si cel caclulat de E3_Adder, in cazul in care difera. > DISPLAY_FAILED: 0 sau 1. Daca DISPLAY_FAILED este 1, atunci doar testele failed vor fi afisate pe ecran. Altfel, si rezultatele passed se vor afisa. > NAX_VAL_in1: Valoarea maxima la care poate ajunge intrarea in_1, exprimata in decimal. > MAX_VAL_in2: Valoarea maxima la care poate ajunge intrare in_2, exprimata in decimal. > Testul va lua toate perechile de (in_1, in_2) din intervalul MAX_VAL_in1 X MAX_VAL_in2 si va compara rezultatul obtinut de E3_Adder cu cel corect > > IMPORTANT: Nota pentru testbenchul public va fi acordata pentru testele care ruleaza cu MAX_VAL_in1 = 500 si MAX_VAL_in2 = 500 > */ > > wire[11:0] in_1_tb, in_2_tb; > reg[10:0] test_input_1, test_input_2, test_output_1; > wire[15:0] out_1_tb_actual, out_1_tb_exp; > > > reg[10:0] MAX_VAL_in1, MAX_VAL_in2; > reg DISPLAY_ALL, DISPLAY_ONLY_FAILED; > integer n_tests_passed, n_tests_total; > /* Modul ajutator de convertire din decimal in E3 */ > Decimal_to_E3 convert_input_1(.dec(test_input_1), .E3(in_1_tb)); > Decimal_to_E3 convert_input_2(.dec(test_input_2), .E3(in_2_tb)); > Decimal_to_E3 convert_output_1(.dec(test_output_1), .E3(out_1_tb_exp)); > > /* Modulul testat */ > E3_Adder DUT(.in_1(in_1_tb), .in_2(in_2_tb), .out_1(out_1_tb_actual)); > > initial begin > /* parametrii configurabili */ > DISPLAY_ALL = 1'b1; > DISPLAY_ONLY_FAILED = 1'b1; > MAX_VAL_in1 = 11'd500; > MAX_VAL_in2 = 11'd500; > /* ======================== */ > n_tests_total = (MAX_VAL_in1 + 1) * (MAX_VAL_in2 + 1); > n_tests_passed = 0; > if(MAX_VAL_in1 > 999 || MAX_VAL_in2 > 999) begin > $display("[WARNING] Testul nu va functiona cum trebuie! Valorile maxime NU trebuie sa fie mai mari de 999"); > end > for(test_input_1 = 0; test_input_1 <= MAX_VAL_in1; test_input_1 = test_input_1 + 1) begin > for(test_input_2 = 0; test_input_2 <= MAX_VAL_in2; test_input_2 = test_input_2 + 1) begin > test_output_1 = test_input_1 + test_input_2; > #1; > $display("Test nr: %d", test_input_1 * (MAX_VAL_in2 + 1) + test_input_2 + 1); > if(DISPLAY_ALL == 1'b1) begin > $display("Pentru urmatoarele intrari:\nin_1(decimal) = %d, in_1(E3) = %b \nin_2(decimal) = %d, in_2(E3) = %b \n", test_input_1, in_1_tb, test_input_2, in_2_tb); > $display("Rezultatul asteptat: out_1(decimal) = %d, out_1(E3) = %b", test_output_1, out_1_tb_exp); > $display("Rezultatul obtinut: out_1(E3) = %b", out_1_tb_actual); > end > if(out_1_tb_exp == out_1_tb_actual) begin > if(DISPLAY_ONLY_FAILED == 0) begin > $display("Testul este PASSED"); > end > n_tests_passed = n_tests_passed + 1; > end > else begin > $display("Testul este FAILED"); > $display("EXP E3: %b_%b_%b_%b =/= ACTUAL E3: %b_%b_%b_%b", out_1_tb_exp[15:12], out_1_tb_exp[11:8], out_1_tb_exp[7:4], out_1_tb_exp[3:0], out_1_tb_actual[15:12], out_1_tb_actual[11:8], out_1_tb_actual[7:4], out_1_tb_actual[3:0]); > end > $display("============================================================================================================="); > $display(""); > $display(""); > end > end > $display("Teste passed: %d / %d", n_tests_passed, n_tests_total); > end > endmoduleWhat is wrong? Does it not work? What do you see? Do you expect people to run your code and find the fault without you looking at it or explaining what it is doing wrong? -- Rick C. - Get 1,000 miles of free Supercharging - Tesla referral code - https://ts.la/richard11209
Reply by ●December 17, 20222022-12-17
On Wednesday, December 14, 2022 at 9:09:36 AM UTC-5, gnuarm.del...@gmail.com wrote:> On Wednesday, December 14, 2022 at 8:49:14 AM UTC-4, Virulog_X wrote:> What is wrong? Does it not work? What do you see? > > Do you expect people to run your code and find the fault without you looking at it or explaining what it is doing wrong? >I think his code is doing exactly what he wrote it to do. "Works as designed" is always true. "Works as intended", well that's another thing. Kevin Jennings