X-Git-Url: http://git.joshuawise.com/mandelfpga.git/blobdiff_plain/7af9813c1d9279fad20ebad595348c8a665c4967..b74034985eac122e8a47ca5800af22ab777f07a0:/Main.v diff --git a/Main.v b/Main.v index 0eba781..0c1e6dc 100644 --- a/Main.v +++ b/Main.v @@ -69,19 +69,19 @@ module NaiveMultiplier( always @(posedge clk) begin {ovf,out} <= - (((y[12] ? (x ) : 0) + - (y[11] ? (x >> 1) : 0) + - (y[10] ? (x >> 2) : 0)) + - (((y[9] ? (x >> 3) : 0) + - (y[8] ? (x >> 4) : 0)) + - ((y[7] ? (x >> 5) : 0) + - (y[6] ? (x >> 6) : 0))))+ - (((y[5] ? (x >> 7) : 0) + - (y[4] ? (x >> 8) : 0) + - (y[3] ? (x >> 9) : 0)) + - ((y[2] ? (x >> 10): 0) + - (y[1] ? (x >> 11): 0) + - (y[0] ? (x >> 12): 0))); + (((y[12] ? (x ) : 0) + + (y[11] ? (x[12:1]) : 0) + + (y[10] ? (x[12:2]) : 0)) + + (((y[9] ? (x[12:3]) : 0) + + (y[8] ? (x[12:4]) : 0)) + + ((y[7] ? (x[12:5]) : 0) + + (y[6] ? (x[12:6]) : 0))))+ + (((y[5] ? (x[12:7]) : 0) + + (y[4] ? (x[12:8]) : 0) + + (y[3] ? (x[12:9]) : 0)) + + ((y[2] ? (x[12:10]): 0) + + (y[1] ? (x[12:11]): 0) + + (y[0] ? (x[12]): 0))); sign <= xsign ^ ysign; end @@ -117,7 +117,7 @@ module MandelUnit( wire [14:0] ri, diff; wire [15:0] twocdiff; wire r2sign, i2sign, risign, dsign; - wire [13:0] bigsum; + wire [14:0] bigsum; wire bigsum_ovf; reg [12:0] xd, yd; @@ -131,9 +131,11 @@ module MandelUnit( Multiplier i2m(clk, i[12:0], i[12:0], isign, isign, i2[12:0], i2sign, i2[13]); Multiplier rim(clk, r[12:0], i[12:0], rsign, isign, ri[13:1], risign, ri[14]); - //assign bigsum = r2[12:0] + i2[12:0]; - //wire shnasto = bigsum[13]; - wire shnasto = // o shi + assign bigsum = r2[13:0] + i2[13:0]; + wire shnasto = bigsum[14]; + wire shnasto2 = // o shi + ((r[13] & i[13]) | + ((r[13] ^ i[13]) & ((r[12] & i[12]) | ((r[12] ^ i[12]) & ((r[11] & i[11]) | @@ -159,8 +161,8 @@ module MandelUnit( ((r[ 1] & i[ 1]) | ((r[ 1] ^ i[ 1]) & (r[ 0] & i[ 0]) - )))))))))))))))))))))))); - assign bigsum_ovf = shnasto | r2[13] | i2[13]; + )))))))))))))))))))))))))); + assign bigsum_ovf = shnasto; assign twocdiff = r2 - i2; assign diff = twocdiff[15] ? -twocdiff : twocdiff;