Index: /trunk/3DEES/Paella.v
===================================================================
--- /trunk/3DEES/Paella.v	(revision 189)
+++ /trunk/3DEES/Paella.v	(revision 190)
@@ -94,5 +94,5 @@
 
 	wire			cls_flag;
-	wire	[7:0]	cls_data;
+	wire	[6:0]	cls_data;
 
 	wire	[1:0]	amp_mux_flag [2:0];
@@ -200,5 +200,5 @@
 			assign int_mux_data[j] = {
 				{4'd0, cls_flag, 7'd0},
-				{4'd0, cls_data},
+				{5'd0, cls_data},
 				{4'd0, amp_flag[j][0], 7'd0},
 				amp_data[j][11:0],
@@ -246,5 +246,5 @@
 		.trg_data(trg_mux_data),
 		.trg_flag(trg_flag));
-	
+
 	oscilloscope oscilloscope_unit (
 		.clock(sys_clock),
@@ -358,5 +358,5 @@
 		.reset(cfg_bits[0][5]),
 		.hst_good(cls_flag & cfg_bits[6][0]),
-		.hst_data(cls_data[6:0]),
+		.hst_data(cls_data),
 		.bus_ssel(bus_ssel[2]),
 		.bus_wren(bus_wren),
Index: /trunk/3DEES/classifier.v
===================================================================
--- /trunk/3DEES/classifier.v	(revision 189)
+++ /trunk/3DEES/classifier.v	(revision 190)
@@ -8,19 +8,23 @@
 		input	wire	[6*width-1:0]	inp_data, // {D3, D2, D1, S2, S1_S, S1_F}
 		input	wire	[5:0]			inp_flag,
-		output	wire	[7:0]			out_data,
+		output	wire	[6:0]			out_data,
 		output	wire					out_flag
 	);
 
-	reg					out_flag_reg [2:0], out_flag_next [2:0];
-	reg		[10:0]		out_data_reg [2:0], out_data_next [2:0];
+	reg					out_flag_reg [1:0], out_flag_next [1:0];
+	reg		[8:0]		out_data_reg [1:0], out_data_next [1:0];
 	reg		[5:0]		inp_flag_reg, inp_flag_next;
 	reg		[width-1:0]	inp_data_reg [5:0], inp_data_next [5:0];
-	reg		[15:0]		int_pipe_reg [23:0], int_pipe_next [23:0];
+	reg		[15:0]		int_pipe_reg [25:0], int_pipe_next [25:0];
 	reg		[2:0]		int_data_reg [3:0], int_data_next [3:0];
-	reg		[4:0]		int_temp_reg [1:0], int_temp_next [1:0];
+	reg		[3:0]		int_temp_reg [1:0], int_temp_next [1:0];
+	reg					int_flag_reg [1:0], int_flag_next [1:0];
 
 	wire	[width-1:0]	inp_data_wire [5:0];
-	wire	[3:0]		int_pipe_wire [5:0];
-	wire	[19:0]		int_comp_wire;
+	wire	[3:0]		int_pipe_wire [6:0];
+	wire	[20:0]		int_comp_wire;
+	
+	reg		[3:0]		add_data_reg [1:0], add_data_next [1:0];
+	wire	[2:0]		add_data_wire;
 
 	integer i;
@@ -34,11 +38,10 @@
 	endgenerate
 
+	assign int_comp_wire[0] = inp_flag_reg[0] & (inp_data_reg[0] < cfg_data[width-1:0]);
+	assign int_comp_wire[1] = inp_flag_reg[0] & (inp_data_reg[0] > cfg_data[2*width-1:1*width]) & (inp_data_reg[0] < cfg_data[3*width-1:2*width]);
+
+	assign int_comp_wire[2] = inp_flag_reg[1] & (inp_data_reg[1] < cfg_data[4*width-1:3*width]);
+	assign int_comp_wire[3] = inp_flag_reg[1] & (inp_data_reg[1] > cfg_data[5*width-1:4*width]) & (inp_data_reg[1] < cfg_data[6*width-1:5*width]);
 	generate
-		assign int_comp_wire[0] = inp_flag_reg[0] & (inp_data_reg[0] < cfg_data[width-1:0]);
-		assign int_comp_wire[1] = inp_flag_reg[0] & (inp_data_reg[0] > cfg_data[2*width-1:1*width]) & (inp_data_reg[0] < cfg_data[3*width-1:2*width]);
-
-		assign int_comp_wire[2] = inp_flag_reg[1] & (inp_data_reg[1] < cfg_data[4*width-1:3*width]);
-		assign int_comp_wire[3] = inp_flag_reg[1] & (inp_data_reg[1] > cfg_data[5*width-1:4*width]) & (inp_data_reg[1] < cfg_data[6*width-1:5*width]);
-
 		for (j = 0; j < 4; j = j + 1)
 		begin : CLASSIFIER_COMPARTORS
@@ -49,16 +52,27 @@
 		end
 	endgenerate
-
-	generate
-		for (j = 0; j < 4; j = j + 1)
-		begin : CLASSIFIER_PIPELINE
-		    assign int_pipe_wire[0][j] = (|int_pipe_reg[j]);
-		    assign int_pipe_wire[1][j] = (|int_pipe_reg[j+4]);
-			assign int_pipe_wire[j+2][0] = (|int_pipe_reg[j*4+0+8]);
-			assign int_pipe_wire[j+2][1] = (|int_pipe_reg[j*4+1+8]);
-			assign int_pipe_wire[j+2][2] = (|int_pipe_reg[j*4+2+8]);
-			assign int_pipe_wire[j+2][3] = (|int_pipe_reg[j*4+3+8]);
-		end
-	endgenerate
+	
+	assign int_comp_wire[20] = add_data_reg[1] > add_data_reg[0];
+
+	assign int_pipe_wire[0] = {|int_pipe_reg[3], |int_pipe_reg[2], |int_pipe_reg[1], |int_pipe_reg[0]};
+
+	assign int_pipe_wire[1] = {1'b0, 1'b0, |int_pipe_reg[5], |int_pipe_reg[4]};
+	assign int_pipe_wire[2] = {|int_pipe_reg[9], |int_pipe_reg[8], |int_pipe_reg[7], |int_pipe_reg[6]};
+
+	assign int_pipe_wire[3] = {|int_pipe_reg[13], |int_pipe_reg[12], |int_pipe_reg[11], |int_pipe_reg[10]};
+	assign int_pipe_wire[4] = {|int_pipe_reg[17], |int_pipe_reg[16], |int_pipe_reg[15], |int_pipe_reg[14]};
+	assign int_pipe_wire[5] = {|int_pipe_reg[21], |int_pipe_reg[20], |int_pipe_reg[19], |int_pipe_reg[18]};
+	assign int_pipe_wire[6] = {|int_pipe_reg[25], |int_pipe_reg[24], |int_pipe_reg[23], |int_pipe_reg[22]};
+
+	parallel_add #(
+		.msw_subtract("NO"),
+		.representation("UNSIGNED"),
+		.result_alignment("LSB"),
+		.shift(0),
+		.size(6),
+		.width(1),
+		.widthr(3)) parallel_add_unit (
+		.data({int_pipe_wire[2], int_pipe_wire[1][1:0]}),
+		.result(add_data_wire));
 
 	always @(posedge clock)
@@ -67,8 +81,11 @@
 		begin
 			inp_flag_reg <= {(6){1'b0}};
-			for (i = 0; i < 3; i = i + 1)
-			begin
-				out_data_reg[i] <= {(11){1'b0}};
-				out_flag_reg[i] <= 1'b0;
+			for (i = 0; i < 2; i = i + 1)
+			begin
+				out_data_reg[i] <= {(9){1'b0}};
+				out_flag_reg[i] <= {(1){1'b0}};
+				int_flag_reg[i] <= {(1){1'b0}};
+				int_temp_reg[i] <= {(4){1'b0}};
+				add_data_reg[i] <= {(3){1'b0}};
 			end
 			for (i = 0; i < 6; i = i + 1)
@@ -76,5 +93,5 @@
 				inp_data_reg[i] <= {(width){1'b0}};
 			end
-			for (i = 0; i < 24; i = i + 1)
+			for (i = 0; i < 26; i = i + 1)
 			begin
 				int_pipe_reg[i] <= {(16){1'b0}};
@@ -84,16 +101,15 @@
 				int_data_reg[i] <= {(3){1'b0}};
 			end
+		end
+		else
+		begin
+			inp_flag_reg <= inp_flag_next;
 			for (i = 0; i < 2; i = i + 1)
-			begin
-				int_temp_reg[i] <= {(5){1'b0}};
-			end
-		end
-		else
-		begin
-			inp_flag_reg <= inp_flag_next;
-			for (i = 0; i < 3; i = i + 1)
 			begin
 				out_data_reg[i] <= out_data_next[i];
 				out_flag_reg[i] <= out_flag_next[i];
+				int_flag_reg[i] <= int_flag_next[i];
+				int_temp_reg[i] <= int_temp_next[i];
+				add_data_reg[i] <= add_data_next[i];
 			end
 			for (i = 0; i < 6; i = i + 1)
@@ -101,5 +117,5 @@
 				inp_data_reg[i] <= inp_data_next[i];
 			end
-			for (i = 0; i < 24; i = i + 1)
+			for (i = 0; i < 26; i = i + 1)
 			begin
 				int_pipe_reg[i] <= int_pipe_next[i];
@@ -108,8 +124,4 @@
 			begin
 				int_data_reg[i] <= int_data_next[i];
-			end
-			for (i = 0; i < 2; i = i + 1)
-			begin
-				int_temp_reg[i] <= int_temp_next[i];
 			end
 		end
@@ -119,8 +131,11 @@
 	begin
 		inp_flag_next = inp_flag_reg;
-		for (i = 0; i < 3; i = i + 1)
+		for (i = 0; i < 2; i = i + 1)
 		begin
 			out_data_next[i] = out_data_reg[i];
 			out_flag_next[i] = out_flag_reg[i];
+			int_flag_next[i] = int_flag_reg[i];
+			int_temp_next[i] = int_temp_reg[i];
+			add_data_next[i] = add_data_reg[i];
 		end
 		for (i = 0; i < 6; i = i + 1)
@@ -128,5 +143,5 @@
 			inp_data_next[i] = inp_data_reg[i];
 		end
-		for (i = 0; i < 24; i = i + 1)
+		for (i = 0; i < 26; i = i + 1)
 		begin
 			int_pipe_next[i] = int_pipe_reg[i];
@@ -135,8 +150,4 @@
 		begin
 			int_data_next[i] = int_data_reg[i];
-		end
-		for (i = 0; i < 2; i = i + 1)
-		begin
-			int_temp_next[i] = int_temp_reg[i];
 		end
 
@@ -149,27 +160,32 @@
 			end
 
-			if (out_flag_reg[2])
-			begin
-				for (i = 0; i < 3; i = i + 1)
-				begin
-					out_data_next[i] = {(11){1'b0}};
-					out_flag_next[i] = 1'b0;
-				end
-				for (i = 0; i < 24; i = i + 1)
+			if (int_flag_reg[1])
+			begin
+				for (i = 0; i < 2; i = i + 1)
+				begin
+					out_data_next[i] = {(9){1'b0}};
+					out_flag_next[i] = {(1){1'b0}};
+					int_flag_next[i] = {(1){1'b0}};
+					int_temp_next[i] = {(4){1'b0}};
+					add_data_next[i] = {(3){1'b0}};
+				end
+				for (i = 0; i < 26; i = i + 1)
 				begin
 					int_pipe_next[i] = {(16){1'b0}};
 				end
-				int_temp_next[0] = {(5){1'b0}};
-				int_temp_next[1] = {(5){1'b0}};
 			end
 			else
 			begin
-				out_data_next[0] = {(11){1'b0}};		
-				out_data_next[1] = out_data_reg[0];
-				out_data_next[2] = {3'd0, out_data_reg[1][10:5], 2'd0} + {6'd0, out_data_reg[1][4:0]};
-
-				out_flag_next[0] = 1'b1;				
-				out_flag_next[1] = out_flag_reg[0];
-				out_flag_next[2] = out_flag_reg[1] & (out_data_reg[1] > out_data_reg[0]);
+				out_data_next[0] = {(9){1'b0}};		
+				out_data_next[1] = {out_data_reg[0][3:0], 2'd0} + out_data_reg[0][8:4];
+
+				out_flag_next[0] = int_flag_reg[0];				
+				out_flag_next[1] = out_flag_reg[0] & int_comp_wire[20];
+				
+				int_flag_next[0] = ^int_pipe_wire[1][1:0];
+				int_flag_next[1] = int_comp_wire[20];
+
+				add_data_next[0] = add_data_wire;
+				add_data_next[1] = add_data_reg[0];
 
 				for (i = 0; i < 4; i = i + 1)
@@ -177,16 +193,16 @@
 					int_pipe_next[i] = {int_pipe_reg[i][14:0], int_comp_wire[i]};
 				end
-				for (i = 4; i < 8; i = i + 1)
-				begin
-					int_pipe_next[i] = {int_pipe_reg[i][14:0], inp_flag_reg[i-2]};
-				end
-				for (i = 8; i < 24; i = i + 1)
-				begin
-					int_pipe_next[i] = {int_pipe_reg[i][14:0], int_comp_wire[i-4]};
+				for (i = 4; i < 10; i = i + 1)
+				begin
+					int_pipe_next[i] = {int_pipe_reg[i][14:0], inp_flag_reg[i-4]};
+				end
+				for (i = 10; i < 26; i = i + 1)
+				begin
+					int_pipe_next[i] = {int_pipe_reg[i][14:0], int_comp_wire[i-6]};
 				end
 
 				for (i = 0; i < 4; i = i + 1)
 				begin
-					case (int_pipe_wire[i+2][3:0])
+					case (int_pipe_wire[i+3][3:0])
 						4'b0000: int_data_next[i] = 3'b000;
 						4'b0001: int_data_next[i] = 3'b001;
@@ -198,27 +214,27 @@
 				end
 
-				int_temp_next[0] = {int_pipe_wire[1], ^int_pipe_wire[0]};
-				int_temp_next[1] = {1'b0, int_pipe_wire[0]};
-
-				case (int_temp_reg[0][4:0])
-					5'b00011: out_data_next[0][4:0] = int_data_next[0];
-					5'b00111: out_data_next[0][4:0] = int_data_next[1] + 4'd5;
-					5'b01111: out_data_next[0][4:0] = int_data_next[2] + 4'd10;
-					5'b11111: out_data_next[0][4:0] = int_data_next[3] + 4'd15;
+				int_temp_next[0] = int_pipe_wire[0];
+				int_temp_next[1] = int_pipe_wire[2];
+
+				case (int_temp_reg[1])
+					4'b0001: out_data_next[0][8:4] = int_data_reg[0] + 5'b00000;
+					4'b0011: out_data_next[0][8:4] = int_data_reg[1] + 5'b00101;
+					4'b0111: out_data_next[0][8:4] = int_data_reg[2] + 5'b01010;
+					4'b1111: out_data_next[0][8:4] = int_data_reg[3] + 5'b01111;
 					default: out_flag_next[0] = 1'b0;
 				endcase
 
-				case (int_temp_reg[1][3:0])
+				case (int_temp_reg[0])
 					// S1_F, electron
-					4'b0001: out_data_next[0][10:5] = 6'b100000;
+					4'b0001: out_data_next[0][3:0] = 4'b0000;
 
 					// S1_F, proton
-					4'b0010: out_data_next[0][10:5] = 6'b100101;
+					4'b0010: out_data_next[0][3:0] = 4'b0101;
 
 					// S1_S, electron
-					4'b0100: out_data_next[0][10:5] = 6'b101010;
+					4'b0100: out_data_next[0][3:0] = 4'b1010;
 
 					// S1_S, proton
-					4'b1000: out_data_next[0][10:5] = 6'b101111;
+					4'b1000: out_data_next[0][3:0] = 4'b1111;
 
 					default: out_flag_next[0] = 1'b0;
@@ -231,6 +247,6 @@
 //	assign out_data = {1'd0, int_comp_wire[0], int_temp_reg[1][3:0]};
 //	assign out_data = {1'd0, int_temp_reg[0][4:0]};
-	assign out_data = out_data_reg[2][7:0];
-	assign out_flag = out_flag_reg[2];
+	assign out_data = out_data_reg[1][6:0];
+	assign out_flag = out_flag_reg[1];
 
 endmodule
