Optimization: New Algorithm for Patch Refinement

The testing results of the old/current algorithm for refinement patches which includes a bug can be found here:
https://clover.pas.rochester.edu/trac/astrobear/blog/bliu03052012

The new algorithm calculates the splitting cost at each position (along one direction for the time being) and finds the optimal (with lowest cost) position. The following shows the testing results of the new algorithm. It clearly shows that the new algorithm fixes the bug in the old one.

1. 16X16 Diagonal patch

http://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/diagonal.pnghttp://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/diagonal_refinement.png

2. 32X32 Diagonal patch

http://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/diagonal_refinement32.png

3. Random patch 1 =

http://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/random_1.pnghttp://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/random1_refinement.png

4. Random patch 2

http://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/random_2.pnghttp://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/random2_refinement.png

5. Random patch 3

http://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/random_3.pnghttp://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/random3_refinement.png

6. Random patch 4

http://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/random_4.pnghttp://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/random4_refinement.png

Comments

1. Jonathan -- 13 years ago

And you are still just splitting in the y direction at this point?

2. Jonathan -- 13 years ago

Whis is why random patch 4 has a large grid across the bottom

3. Jonathan -- 13 years ago

Also I thought of a very difficult case for the new algorithm to handle… What happens with the following array of ErrFlags? My guess is that the current algorithm will leave this as an 8x8 without considering whether 4 1x4 grids would be faster since you have to make 2 splits before you can do any shrinking… One solution would be to search for the two best split options - this would be a little more expensive (and might be easier to evaluate with a recursive subroutine) but I still think it would probably save more time in the advance stage…

1 1 1 1 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 1 1 1 1

4. Jonathan -- 13 years ago

That didn't format correctly previously… Here it is in table format

1 1 1 1 0 0 0 1
0 0 0 0 0 0 0 1
0 0 0 0 0 0 0 1
0 0 0 0 0 0 0 1
1 0 0 0 0 0 0 0
1 0 0 0 0 0 0 0
1 0 0 0 0 0 0 0
1 0 0 0 1 1 1 1
5. Baowei Liu -- 13 years ago

These results are just splitting in the y direction. The new algorithm won't split this array of ErrFlags

http://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/8X8.pnghttp://www.pas.rochester.edu/~bliu/Optimization/NewAlgo/8x8_refinement.png