Added value range assertions to QrCode.getPenaltyScore(), in all language ports.

pull/134/head
Project Nayuki 3 years ago
parent 97b2d9d71c
commit c7ab2582aa

@ -704,7 +704,9 @@ static long getPenaltyScore(const uint8_t qrcode[]) {
int total = qrsize * qrsize; // Note that size is odd, so dark/total != 1/2 int total = qrsize * qrsize; // Note that size is odd, so dark/total != 1/2
// Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)% // Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)%
int k = (int)((labs(dark * 20L - total * 10L) + total - 1) / total) - 1; int k = (int)((labs(dark * 20L - total * 10L) + total - 1) / total) - 1;
assert(0 <= k && k <= 9);
result += k * PENALTY_N4; result += k * PENALTY_N4;
assert(0 <= result && result <= 2568888L); // Non-tight upper bound based on default values of PENALTY_N1, ..., N4
return result; return result;
} }

@ -663,7 +663,11 @@ long QrCode::getPenaltyScore() const {
int total = size * size; // Note that size is odd, so dark/total != 1/2 int total = size * size; // Note that size is odd, so dark/total != 1/2
// Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)% // Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)%
int k = static_cast<int>((std::abs(dark * 20L - total * 10L) + total - 1) / total) - 1; int k = static_cast<int>((std::abs(dark * 20L - total * 10L) + total - 1) / total) - 1;
if (!(0 <= k && k <= 9))
throw std::logic_error("Assertion error");
result += k * PENALTY_N4; result += k * PENALTY_N4;
if (!(0 <= result && result <= 2568888L)) // Non-tight upper bound based on default values of PENALTY_N1, ..., N4
throw std::logic_error("Assertion error");
return result; return result;
} }

@ -594,7 +594,9 @@ public final class QrCode {
int total = size * size; // Note that size is odd, so dark/total != 1/2 int total = size * size; // Note that size is odd, so dark/total != 1/2
// Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)% // Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)%
int k = (Math.abs(dark * 20 - total * 10) + total - 1) / total - 1; int k = (Math.abs(dark * 20 - total * 10) + total - 1) / total - 1;
assert 0 <= k && k <= 9;
result += k * PENALTY_N4; result += k * PENALTY_N4;
assert 0 <= result && result <= 2568888; // Non-tight upper bound based on default values of PENALTY_N1, ..., N4
return result; return result;
} }

@ -470,7 +470,9 @@ class QrCode:
total: int = size**2 # Note that size is odd, so dark/total != 1/2 total: int = size**2 # Note that size is odd, so dark/total != 1/2
# Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)% # Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)%
k: int = (abs(dark * 20 - total * 10) + total - 1) // total - 1 k: int = (abs(dark * 20 - total * 10) + total - 1) // total - 1
assert 0 <= k <= 9
result += k * QrCode._PENALTY_N4 result += k * QrCode._PENALTY_N4
assert 0 <= result <= 2568888 # Non-tight upper bound based on default values of PENALTY_N1, ..., N4
return result return result

@ -678,7 +678,9 @@ impl QrCode {
let total: i32 = size * size; // Note that size is odd, so dark/total != 1/2 let total: i32 = size * size; // Note that size is odd, so dark/total != 1/2
// Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)% // Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)%
let k: i32 = ((dark * 20 - total * 10).abs() + total - 1) / total - 1; let k: i32 = ((dark * 20 - total * 10).abs() + total - 1) / total - 1;
assert!(0 <= k && k <= 9);
result += k * PENALTY_N4; result += k * PENALTY_N4;
assert!(0 <= result && result <= 2568888); // Non-tight upper bound based on default values of PENALTY_N1, ..., N4
result result
} }

@ -531,7 +531,11 @@ namespace qrcodegen {
const total: int = this.size * this.size; // Note that size is odd, so dark/total != 1/2 const total: int = this.size * this.size; // Note that size is odd, so dark/total != 1/2
// Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)% // Compute the smallest integer k >= 0 such that (45-5k)% <= dark/total <= (55+5k)%
const k: int = Math.ceil(Math.abs(dark * 20 - total * 10) / total) - 1; const k: int = Math.ceil(Math.abs(dark * 20 - total * 10) / total) - 1;
if (!(0 <= k && k <= 9))
throw "Assertion error";
result += k * QrCode.PENALTY_N4; result += k * QrCode.PENALTY_N4;
if (!(0 <= result && result <= 2568888)) // Non-tight upper bound based on default values of PENALTY_N1, ..., N4
throw "Assertion error";
return result; return result;
} }

Loading…
Cancel
Save