Mercurial > hg > svcore
comparison data/model/PowerOfSqrtTwoZoomConstraint.cpp @ 1450:a12fd0456f0c streaming-csv-writer
Merge from default branch
author | Chris Cannam |
---|---|
date | Tue, 17 Apr 2018 10:35:42 +0100 |
parents | 48e9f538e6e9 |
children | 710e6250a401 a7485c1bdba5 |
comparison
equal
deleted
inserted
replaced
1449:deabf9fd3d28 | 1450:a12fd0456f0c |
---|---|
19 #include <cmath> | 19 #include <cmath> |
20 | 20 |
21 | 21 |
22 int | 22 int |
23 PowerOfSqrtTwoZoomConstraint::getNearestBlockSize(int blockSize, | 23 PowerOfSqrtTwoZoomConstraint::getNearestBlockSize(int blockSize, |
24 RoundingDirection dir) const | 24 RoundingDirection dir) const |
25 { | 25 { |
26 int type, power; | 26 int type, power; |
27 int rv = getNearestBlockSize(blockSize, type, power, dir); | 27 int rv = getNearestBlockSize(blockSize, type, power, dir); |
28 return rv; | 28 return rv; |
29 } | 29 } |
30 | 30 |
31 int | 31 int |
32 PowerOfSqrtTwoZoomConstraint::getNearestBlockSize(int blockSize, | 32 PowerOfSqrtTwoZoomConstraint::getNearestBlockSize(int blockSize, |
33 int &type, | 33 int &type, |
34 int &power, | 34 int &power, |
35 RoundingDirection dir) const | 35 RoundingDirection dir) const |
36 { | 36 { |
37 // cerr << "given " << blockSize << endl; | 37 // cerr << "given " << blockSize << endl; |
38 | 38 |
39 int minCachePower = getMinCachePower(); | 39 int minCachePower = getMinCachePower(); |
40 | 40 |
41 if (blockSize < (1 << minCachePower)) { | 41 if (blockSize < (1 << minCachePower)) { |
42 type = -1; | 42 type = -1; |
43 power = 0; | 43 power = 0; |
44 float val = 1.0, prevVal = 1.0; | 44 float val = 1.0, prevVal = 1.0; |
45 while (val + 0.01 < blockSize) { | 45 while (val + 0.01 < blockSize) { |
46 prevVal = val; | 46 prevVal = val; |
47 val *= sqrtf(2.f); | 47 val *= sqrtf(2.f); |
48 } | 48 } |
49 int rval; | 49 int rval; |
50 if (dir == RoundUp) rval = int(val + 0.01f); | 50 if (dir == RoundUp) rval = int(val + 0.01f); |
51 else if (dir == RoundDown) rval = int(prevVal + 0.01f); | 51 else if (dir == RoundDown) rval = int(prevVal + 0.01f); |
52 else if (val - float(blockSize) < | 52 else if (val - float(blockSize) < |
53 float(blockSize) - prevVal) rval = int(val + 0.01f); | 53 float(blockSize) - prevVal) rval = int(val + 0.01f); |
54 else rval = int(prevVal + 0.01); | 54 else rval = int(prevVal + 0.01); |
55 // SVDEBUG << "returning " << rval << endl; | 55 // SVDEBUG << "returning " << rval << endl; |
56 return rval; | 56 return rval; |
57 } | 57 } |
58 | 58 |
59 int prevBase = (1 << minCachePower); | 59 int prevBase = (1 << minCachePower); |
60 int prevPower = minCachePower; | 60 int prevPower = minCachePower; |
61 int prevType = 0; | 61 int prevType = 0; |
62 | 62 |
63 int result = 0; | 63 int result = 0; |
64 | 64 |
65 for (unsigned int i = 0; ; ++i) { | 65 for (unsigned int i = 0; ; ++i) { |
66 | 66 |
67 power = minCachePower + i/2; | 67 power = minCachePower + i/2; |
68 type = i % 2; | 68 type = i % 2; |
69 | 69 |
70 int base; | 70 int base; |
71 if (type == 0) { | 71 if (type == 0) { |
72 base = (1 << power); | 72 base = (1 << power); |
73 } else { | 73 } else { |
74 base = (((unsigned int)((1 << minCachePower) * sqrt(2.) + 0.01)) | 74 base = (((unsigned int)((1 << minCachePower) * sqrt(2.) + 0.01)) |
75 << (power - minCachePower)); | 75 << (power - minCachePower)); |
76 } | 76 } |
77 | 77 |
78 // SVDEBUG << "Testing base " << base << endl; | 78 // SVDEBUG << "Testing base " << base << endl; |
79 | 79 |
80 if (base == blockSize) { | 80 if (base == blockSize) { |
81 result = base; | 81 result = base; |
82 break; | 82 break; |
83 } | 83 } |
84 | 84 |
85 if (base > blockSize) { | 85 if (base > blockSize) { |
86 if (dir == RoundNearest) { | 86 if (dir == RoundNearest) { |
87 if (base - blockSize < blockSize - prevBase) { | 87 if (base - blockSize < blockSize - prevBase) { |
88 dir = RoundUp; | 88 dir = RoundUp; |
89 } else { | 89 } else { |
90 dir = RoundDown; | 90 dir = RoundDown; |
91 } | 91 } |
92 } | 92 } |
93 if (dir == RoundUp) { | 93 if (dir == RoundUp) { |
94 result = base; | 94 result = base; |
95 break; | 95 break; |
96 } else { | 96 } else { |
97 type = prevType; | 97 type = prevType; |
98 power = prevPower; | 98 power = prevPower; |
99 result = prevBase; | 99 result = prevBase; |
100 break; | 100 break; |
101 } | 101 } |
102 } | 102 } |
103 | 103 |
104 prevType = type; | 104 prevType = type; |
105 prevPower = power; | 105 prevPower = power; |
106 prevBase = base; | 106 prevBase = base; |
107 } | 107 } |
108 | 108 |
109 if (result > getMaxZoomLevel()) result = getMaxZoomLevel(); | 109 if (result > getMaxZoomLevel()) result = getMaxZoomLevel(); |
110 return result; | 110 return result; |
111 } | 111 } |