SUNNY CENTRAL - Notes for grounded operation of the PV generator
Computer notes - Maze Generator
-
Upload
ecomputernotes -
Category
Education
-
view
492 -
download
4
description
Transcript of Computer notes - Maze Generator
![Page 1: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/1.jpg)
Class No.31
Data Structures
http://ecomputernotes.com
![Page 2: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/2.jpg)
Timing with Optimization
Theorem: A sequence of m union and find operations, n of which are find operations, can be performed on a disjoint-set forest with union by rank (weight or height) and path compression in worst case time proportional to (m (n))
(n)is the inverse Ackermann’s function which grows extremely slowly. For all practical puposes, (n) 4.
Union-find is essentially proportional to m for a sequence of m operations, linear in m.
http://ecomputernotes.com
![Page 3: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/3.jpg)
Image Segmentation
• Inclusion criteria for pixels – use pixel intensity, – threshold of intensity,– threshold for difference in intensity
of neighbors, – texture (ie. a pattern of pixel
intensities)
http://ecomputernotes.com
![Page 4: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/4.jpg)
Image Segmentation
0 1 2 3 40 0 0 0 4 41 2 0 4 4 02 4 2 2 4 43 4 4 0 4 44 0 2 2 4 0
http://ecomputernotes.com
![Page 5: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/5.jpg)
Image Segmentation
0 1 2 3 40 0 0 0 4 41 2 0 4 4 02 4 2 2 4 43 4 4 0 4 44 0 2 2 4 0
0 1 2 3 40 0 0 0 1 11 0 0 1 1 02 1 0 0 1 13 1 1 0 1 14 0 0 0 1 0
Threshold=4
http://ecomputernotes.com
![Page 6: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/6.jpg)
0 1 2 3 40 0 0 0 1 11 1 0 1 1 02 1 1 1 1 13 1 1 0 1 14 0 1 1 1 0
Image Segmentation
0 1 2 3 40 0 0 0 4 41 2 0 4 4 02 4 2 2 4 43 4 4 0 4 44 0 2 2 4 0
Threshold=2
http://ecomputernotes.com
![Page 8: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/8.jpg)
Maze Generation
A random maze generator can use union-find. Consider a 5x5 maze:
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
http://ecomputernotes.com
![Page 9: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/9.jpg)
Maze Generator
• Initially, 25 cells, each isolated by walls from the others.
• This corresponds to an equivalence relation -- two cells are equivalent if they can be reached from each other (walls been removed so there is a path from one to the other).
http://ecomputernotes.com
![Page 10: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/10.jpg)
Maze Generator
To start, choose an entrance and an exit.
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
http://ecomputernotes.com
![Page 11: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/11.jpg)
Maze Generator
Randomly remove walls until the entrance and exit cells are in the same set.
Removing a wall is the same as doing a union operation.
Do not remove a randomly chosen wall if the cells it separates are already in the same set.
http://ecomputernotes.com
![Page 12: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/12.jpg)
MakeMaze
MakeMaze(int size) {
entrance = 0; exit = size-1;
while (find(entrance) != find(exit)) {
cell1 = randomly chosen cell
cell2 = randomly chosen adjacent cell
if (find(cell1) != find(cell2) {
knock down wall between cells
union(cell1, cell2)
}
}http://ecomputernotes.com
![Page 13: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/13.jpg)
Maze Generator
Cell 11, right wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
http://ecomputernotes.com
![Page 14: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/14.jpg)
Maze Generator
Cell 11, right wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12}
http://ecomputernotes.com
![Page 15: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/15.jpg)
Maze Generator
Cell 6, bottom wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12}
http://ecomputernotes.com
![Page 16: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/16.jpg)
Maze Generator
Cell 6, bottom wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12, 6}
http://ecomputernotes.com
![Page 17: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/17.jpg)
Maze Generator
Cell 8, top wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12, 6}
http://ecomputernotes.com
![Page 18: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/18.jpg)
Maze Generator
Cell 8, top wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12, 6}
S_8 = { 8,3}
http://ecomputernotes.com
![Page 19: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/19.jpg)
Maze Generator
Cell 14, top wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12, 6}
S_8 = { 8,3}
http://ecomputernotes.com
![Page 20: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/20.jpg)
Maze Generator
Cell 14, top wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12, 6}
S_8 = { 8,3}
S_14 = { 14,9}
http://ecomputernotes.com
![Page 21: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/21.jpg)
Maze Generator
Cell 0, bottom wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12, 6}
S_8 = { 8,3}
S_14 = { 14,9}
http://ecomputernotes.com
![Page 22: Computer notes - Maze Generator](https://reader033.fdocuments.us/reader033/viewer/2022061214/549a3920b47959b51e8b46fe/html5/thumbnails/22.jpg)
Maze Generator
Cell 0, bottom wall chosen randomly
0 1 2 3 4
5 6 7 8 9
10 11 12 13 14
15 16 17 18 19
20 21 22 23 24
S_11 = { 11,12, 6}
S_8 = { 8,3}
S_14 = { 14,9}
S_0 = { 0,5}
http://ecomputernotes.com