OpenCores
URL https://opencores.org/ocsvn/sudoku/sudoku/trunk

Subversion Repositories sudoku

[/] [sudoku/] [trunk/] [rtl/] [minPiece.v] - Blame information for rev 4

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 dsheffie
module minPiece(/*AUTOARG*/
2
   // Outputs
3
   minPoss, minIdx,
4
   // Inputs
5
   clk, rst, inGrid
6
   );
7
 
8
   input clk;
9
   input rst;
10
 
11
   input [728:0] inGrid;
12
 
13
   output [3:0]  minPoss;
14
   output [6:0]  minIdx;
15
 
16
   reg [3:0]      r_minPoss;
17
   reg [6:0]      r_minIdx;
18
 
19
   assign minPoss = r_minPoss;
20
   assign minIdx = r_minIdx;
21
 
22
 
23
   wire [8:0]     grid2d [80:0];
24
 
25
   wire [6:0]     gridIndices [80:0];
26
   wire [3:0]     gridPoss [80:0];
27
 
28
   genvar        i;
29
 
30
   /* unflatten */
31
   generate
32
      for(i=0;i<81;i=i+1)
33
        begin: unflatten
34
           assign grid2d[i] = inGrid[(9*(i+1))-1:9*i];
35
           assign gridIndices[i] = i;
36
           countPoss cP (.clk(clk), .rst(rst), .in(grid2d[i]), .out(gridPoss[i]));
37
        end
38
   endgenerate
39
 
40
   wire [6:0]     stage1_gridIndices [39:0];
41
   wire [3:0]     stage1_gridPoss [39:0];
42
 
43
   generate
44
      for(i=0;i<40;i=i+1)
45
        begin: stage1
46
           cmpPiece cP_stage1
47
            (
48
             .outPoss(stage1_gridPoss[i]),
49
             .outIdx(stage1_gridIndices[i]),
50
             .inPoss_0(gridPoss[2*i]),
51
             .inIdx_0(gridIndices[2*i]),
52
             .inPoss_1(gridPoss[2*i+1]),
53
             .inIdx_1(gridIndices[2*i+1])
54
             );
55
        end
56
   endgenerate
57
 
58
   wire [6:0]     stage2_gridIndices [19:0];
59
   wire [3:0]     stage2_gridPoss [19:0];
60
 
61
   generate
62
      for(i=0;i<20;i=i+1)
63
        begin: stage2
64
           cmpPiece cP_stage2
65
            (
66
             .outPoss(stage2_gridPoss[i]),
67
             .outIdx(stage2_gridIndices[i]),
68
             .inPoss_0(stage1_gridPoss[2*i]),
69
             .inIdx_0(stage1_gridIndices[2*i]),
70
             .inPoss_1(stage1_gridPoss[2*i+1]),
71
             .inIdx_1(stage1_gridIndices[2*i+1])
72
             );
73
        end
74
   endgenerate
75
 
76
   wire [6:0]     stage3_gridIndices [9:0];
77
   wire [3:0]     stage3_gridPoss [9:0];
78
 
79
   generate
80
      for(i=0;i<10;i=i+1)
81
        begin: stage3
82
           cmpPiece cP_stage3
83
            (
84
             .outPoss(stage3_gridPoss[i]),
85
             .outIdx(stage3_gridIndices[i]),
86
             .inPoss_0(stage2_gridPoss[2*i]),
87
             .inIdx_0(stage2_gridIndices[2*i]),
88
             .inPoss_1(stage2_gridPoss[2*i+1]),
89
             .inIdx_1(stage2_gridIndices[2*i+1])
90
             );
91
        end
92
   endgenerate
93
 
94
   wire [6:0]     stage4_gridIndices [4:0];
95
   wire [3:0]     stage4_gridPoss [4:0];
96
 
97
   generate
98
      for(i=0;i<5;i=i+1)
99
        begin: stage4
100
           cmpPiece cP_stage4
101
            (
102
             .outPoss(stage4_gridPoss[i]),
103
             .outIdx(stage4_gridIndices[i]),
104
             .inPoss_0(stage3_gridPoss[2*i]),
105
             .inIdx_0(stage3_gridIndices[2*i]),
106
             .inPoss_1(stage3_gridPoss[2*i+1]),
107
             .inIdx_1(stage3_gridIndices[2*i+1])
108
             );
109
        end
110
   endgenerate
111
 
112
   wire [6:0]     stage5_gridIndices [1:0];
113
   wire [3:0]     stage5_gridPoss [1:0];
114
 
115
 
116
   generate
117
      for(i=0;i<2;i=i+1)
118
        begin: stage5
119
           cmpPiece cP_stage5
120
            (
121
             .outPoss(stage5_gridPoss[i]),
122
             .outIdx(stage5_gridIndices[i]),
123
             .inPoss_0(stage4_gridPoss[2*i]),
124
             .inIdx_0(stage4_gridIndices[2*i]),
125
             .inPoss_1(stage4_gridPoss[2*i+1]),
126
             .inIdx_1(stage4_gridIndices[2*i+1])
127
             );
128
        end
129
   endgenerate
130
 
131
 
132
   wire [6:0] stage6_gridIndices_A;
133
   wire [3:0] stage6_gridPoss_A;
134
 
135
   cmpPiece cP_stage6_A
136
     (
137
      .outPoss(stage6_gridPoss_A),
138
      .outIdx(stage6_gridIndices_A),
139
      .inPoss_0(stage5_gridPoss[0]),
140
      .inIdx_0(stage5_gridIndices[0]),
141
      .inPoss_1(stage5_gridPoss[1]),
142
      .inIdx_1(stage5_gridIndices[1])
143
      );
144
 
145
   wire [6:0] stage6_gridIndices_B;
146
   wire [3:0] stage6_gridPoss_B;
147
 
148
   cmpPiece cP_stage6_B
149
     (
150
      .outPoss(stage6_gridPoss_B),
151
      .outIdx(stage6_gridIndices_B),
152
      .inPoss_0(stage4_gridPoss[4]),
153
      .inIdx_0(stage4_gridIndices[4]),
154
      .inPoss_1(gridPoss[80]),
155
      .inIdx_1(gridIndices[80])
156
      );
157
 
158
   wire [6:0] stage7_gridIndices;
159
   wire [3:0] stage7_gridPoss;
160
 
161
   cmpPiece cP_stage7
162
     (
163
      .outPoss(stage7_gridPoss),
164
      .outIdx(stage7_gridIndices),
165
      .inPoss_0(stage6_gridPoss_A),
166
      .inIdx_0(stage6_gridIndices_A),
167
      .inPoss_1(stage6_gridPoss_B),
168
      .inIdx_1(stage6_gridIndices_B)
169
      );
170
 
171
   always@(posedge clk)
172
     begin
173
        if(rst)
174
          begin
175
             r_minIdx <= 7'd0;
176
             r_minPoss <= 4'hf;
177
          end
178
        else
179
          begin
180
             r_minIdx <= stage7_gridIndices;
181
             r_minPoss <= stage7_gridPoss;
182
          end
183
     end // always@ (posedge clk)
184
 
185
endmodule
186
 
187
module cmpPiece(/*AUTOARG*/
188
   // Outputs
189
   outPoss, outIdx,
190
   // Inputs
191
   inPoss_0, inIdx_0, inPoss_1, inIdx_1
192
   );
193
   input [3:0] inPoss_0;
194
   input [6:0] inIdx_0;
195
 
196
   input [3:0] inPoss_1;
197
   input [6:0] inIdx_1;
198
 
199
   output [3:0] outPoss;
200
   output [6:0] outIdx;
201
 
202
   wire         w_cmp = (inPoss_0 < inPoss_1);
203
 
204
   assign outPoss = w_cmp ? inPoss_0 : inPoss_1;
205
   assign outIdx = w_cmp ? inIdx_0 : inIdx_1;
206
 
207
endmodule // cmpPiece
208
 
209
module countPoss(clk,rst,in,out);
210
   input [8:0] in;
211
   input       clk;
212
   input       rst;
213
 
214
   output [3:0] out;
215
   reg [3:0]     r_out;
216
   assign out = r_out;
217
 
218
   wire [3:0]    w_cnt;
219
 
220
   one_count9 c0(in, w_cnt);
221
   wire [3:0] w_out = (w_cnt == 4'd1) ? 4'd15 : w_cnt;
222
 
223
   always@(posedge clk)
224
     begin
225
        r_out <= rst ? 4'd15 : w_out;
226
     end
227
 
228
endmodule

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.