Mercurial > hg > svcore
comparison data/model/PowerOfSqrtTwoZoomConstraint.cpp @ 935:f960d67ce842 tonioni
Merge from branch warnfix_no_size_t
author | Chris Cannam |
---|---|
date | Wed, 18 Jun 2014 13:42:01 +0100 |
parents | 59e7fe1b1003 |
children | cc27f35aa75c |
comparison
equal
deleted
inserted
replaced
925:3efc20c59a94 | 935:f960d67ce842 |
---|---|
17 | 17 |
18 #include <iostream> | 18 #include <iostream> |
19 #include <cmath> | 19 #include <cmath> |
20 | 20 |
21 | 21 |
22 size_t | 22 int |
23 PowerOfSqrtTwoZoomConstraint::getNearestBlockSize(size_t 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 size_t 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 size_t | 31 int |
32 PowerOfSqrtTwoZoomConstraint::getNearestBlockSize(size_t 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 size_t minCachePower = getMinCachePower(); | 39 int minCachePower = getMinCachePower(); |
40 | 40 |
41 if (blockSize < (1U << 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 *= sqrt(2.f); | 47 val *= sqrt(2.f); |
48 } | 48 } |
49 size_t rval; | 49 int rval; |
50 if (dir == RoundUp) rval = size_t(val + 0.01); | 50 if (dir == RoundUp) rval = int(val + 0.01); |
51 else if (dir == RoundDown) rval = size_t(prevVal + 0.01); | 51 else if (dir == RoundDown) rval = int(prevVal + 0.01); |
52 else if (val - blockSize < blockSize - prevVal) rval = size_t(val + 0.01); | 52 else if (val - blockSize < blockSize - prevVal) rval = int(val + 0.01); |
53 else rval = size_t(prevVal + 0.01); | 53 else rval = int(prevVal + 0.01); |
54 // SVDEBUG << "returning " << rval << endl; | 54 // SVDEBUG << "returning " << rval << endl; |
55 return rval; | 55 return rval; |
56 } | 56 } |
57 | 57 |
58 unsigned int prevBase = (1 << minCachePower); | 58 int prevBase = (1 << minCachePower); |
59 unsigned int prevPower = minCachePower; | 59 int prevPower = minCachePower; |
60 unsigned int prevType = 0; | 60 int prevType = 0; |
61 | 61 |
62 size_t result = 0; | 62 int result = 0; |
63 | 63 |
64 for (unsigned int i = 0; ; ++i) { | 64 for (unsigned int i = 0; ; ++i) { |
65 | 65 |
66 power = minCachePower + i/2; | 66 power = minCachePower + i/2; |
67 type = i % 2; | 67 type = i % 2; |
68 | 68 |
69 unsigned int base; | 69 int base; |
70 if (type == 0) { | 70 if (type == 0) { |
71 base = (1 << power); | 71 base = (1 << power); |
72 } else { | 72 } else { |
73 base = (((unsigned int)((1 << minCachePower) * sqrt(2.) + 0.01)) | 73 base = (((unsigned int)((1 << minCachePower) * sqrt(2.) + 0.01)) |
74 << (power - minCachePower)); | 74 << (power - minCachePower)); |