namespace Gma.QrCodeNet.Encoding.Masking.Scoring;
///
/// ISO/IEC 18004:2000 Chapter 8.8.2 Page 52
///
internal class Penalty4 : Penalty
{
///
/// Calculate penalty value for Fourth rule.
/// Perform O(n) search for available x modules
///
internal override int PenaltyCalculate(BitMatrix matrix)
{
int width = matrix.Width;
int darkBitCount = 0;
for (int j = 0; j < width; j++)
{
for (int i = 0; i < width; i++)
{
if (matrix[i, j])
{
darkBitCount++;
}
}
}
int matrixCount = width * width;
double ratio = (double)darkBitCount / matrixCount;
return Math.Abs((int)((ratio * 100) - 50)) / 5 * 10;
}
}