Sur.Modulus11 1.1.0

dotnet add package Sur.Modulus11 --version 1.1.0                
NuGet\Install-Package Sur.Modulus11 -Version 1.1.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Sur.Modulus11" Version="1.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Sur.Modulus11 --version 1.1.0                
#r "nuget: Sur.Modulus11, 1.1.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • 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.

Version Downloads Last updated
1.1.0 165 2/20/2024
1.0.3 152 2/10/2024

First release