Sur.Modulus11
1.1.0
dotnet add package Sur.Modulus11 --version 1.1.0
NuGet\Install-Package Sur.Modulus11 -Version 1.1.0
<PackageReference Include="Sur.Modulus11" Version="1.1.0" />
paket add Sur.Modulus11 --version 1.1.0
#r "nuget: Sur.Modulus11, 1.1.0"
// Install Sur.Modulus11 as a Cake Addin #addin nuget:?package=Sur.Modulus11&version=1.1.0 // Install Sur.Modulus11 as a Cake Tool #tool nuget:?package=Sur.Modulus11&version=1.1.0
Modulus11
For a Chilean Rut wrapper implementation please check Modulus 11.Rut
Para la implementación de un wrapper del Rut Chileno por favor revise Modulus 11.Rut
Purpose
"To facilitate the creation, validation, and sharing of numbers with their associated Modulo 11 checksums."
It is achieved by:
- Making an easy-to-use library
- Providing easy personalisation with default parameters
- Leaving implementation-specifics, like min and max numbers, to the developer
- Bringing an independent record focused on storing and formatting the modulo 11 object
Modulo 11 is an arithmetical algorithm used to validate integer numbers. It is widely used in cryptography and input validation of document numeric codes.
As an example, Chile's national ID, RUT, uses an integer number to identify people, institutions and companies. To reduce mistakes, the modulus 11 of that number is added at the end.
ID: 12345678
Modulus 11 of ID: 9
National ID: 12345678-9
ID: 11222333
Modulus 11 of ID: 8
National ID: 11222333-8
If the modulo 11 do not match, we know for sure there is a mistake in either the number or the checksum.
It helps to verify the integrity of the number, it is not intended to correct it.\
The algorithm
I will provide a short explanation- Please search in Wikipedia for details.\
Basically, we have to multiply each digit, from right to left, with a circular buffer of six digits (2,3,4,5,6,7), rolling up if you have more than 6 digits in your code.
We sum them all and get modulus 11 (number mod 11). It gives the reminder.
Then, we calculate a difference, DIF=11-reminder:
If the result is 10, 1
If the result is 11, 0
else, DIF /* between 0-9 */
In some implementations, instead of using 0 when the remainder is 11, the verification code is replaced by a special character. One example is the chilean rut, where 10 is replaced by a 'k' and not a zero.
Example 1: 987654321
Circular buffer | 4 | 3 | 2 | 7 | 6 | 5 | 4 | 3 | 2 |
---|---|---|---|---|---|---|---|---|---|
Number | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
Multiplication | 4x9 | 3x8 | 2x7 | 7x6 | 6x5 | 5x4 | 4x3 | 3x2 | 2x1 |
Result | 36 | 24 | 14 | 42 | 30 | 20 | 12 | 6 | 2 |
The sum is 186 and remainder is 10 (186%11 = 10)
DIF = 11-10=1
Code = 1, 987654321 / 1
Example 2: 44261539
Circular buffer | 4 | 3 | 2 | 7 | 6 | 5 | 4 | 3 | 2 |
---|---|---|---|---|---|---|---|---|---|
Number | 4 | 4 | 2 | 6 | 1 | 5 | 3 | 9 | |
Multiplication | 4x | 3x4 | 2x4 | 7x2 | 6x6 | 5x1 | 4x5 | 3x3 | 2x9 |
Result | 0 | 12 | 8 | 14 | 36 | 5 | 20 | 9 | 18 |
The sum is 122 and remainder is 1 (122%11 = 1)
DIF = 11-1=10 // Rule: if 10 ⇒ 1
Code = 1, 44261539 / 1
If it is a chilean rut, then 10=>'k', 44261539 / k or 44261539-k
How to use Modulus 11
long iNumber = 12345678;
Modulus11 m11 = new Modulus11();
// To specify hyphen/group separator, set Hyphen and NumberGroupSeparator parameters
// when calling to GetModulusRecord. Defaults to '-' and no group separator.
var m = m11.GetModulusRecord(iNumber);
// Uses provided configuration
string formattedWithHyphen = m.ToString();
Console.WriteLine("The self-checked number is {0}", formattedWithHyphen);
Public record ModulusRecord
/// <param name="Number">The number</param>
/// <param name="Digit">The already calculated digit</param>
/// <param name="Hyphen">Number and digit separator</param>
/// <param name="UseThousandsSeparator">If to use thousands separator</param>
public record ModulusRecord(long Number, string Digit, string Hyphen = "-", string NumberGroupSeparator = "")
{
/// <summary>
/// In format Number-dv like 12.345.678-9
/// </summary>
/// <returns>12.345.678-9</returns>
public override string ToString()
}
Public class Modulus11
/// <remarks>Accepts values between 0 and max, tested up to 9 digits
/// Returns the modulus character, using digits 0-9 plus the '10' character
/// </remarks>
public class Modulus11
{
/// <summary>
/// Digit or character to use when the checksum is 10
/// </summary>
public string CharFor10Value { get; set; }
/// <param name="charFor10Value">Character to use for 11-remainder=10, defaults to 1</param>
public Modulus11(string charFor10Value = "1")
/// <param name="input"></param>
/// <returns>ModulusRecord</returns>
public ModulusRecord GetModulusRecord(long input, string Hyphen = "-", string NumberGroupSeparator = "")
/// <param name="input">Numeric-format ID (without checksum digit)</param>
/// <returns>Checksum digit</returns>
/// <exception cref="ArgumentException"></exception>
public string GetModulus(long input)
}
Jorge Rojas @ 2024 under MIT license
jorge.rojasmata@outlook.com / +56(9)94328521
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net7.0
- No dependencies.
-
net8.0
- No dependencies.
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Sur.Modulus11:
Package | Downloads |
---|---|
Sur.Modulus11.Rut
Wrapper para generar, validar y formatear un rut chileno |
GitHub repositories
This package is not used by any popular GitHub repositories.
First release