Skip to content
/ algo Public

Collection of algorithm implementations for Go.

License

Notifications You must be signed in to change notification settings

petoc/algo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Algorithms

Collection of algorithm implementations for Go.

Error detection

Damm
Damm64 (using quasigroups for character base from 3 to 64 characters)
Luhn

Math

Greatest common divisor (Euclid)

Usage

Error detection

Damm

Implementation of error detection algorithm for numeric codes from H. Michael Damm.

import "github.com/petoc/algo/damm"
damm.Calculate("123456789") // 4
damm.Validate("1234567894") // true

Damm64

Based on error detection algorithm from H. Michael Damm. Uses pre-generated quasigroups for character base from 3 to 64 characters.

import "github.com/petoc/algo/damm64"
base := "0123456789ABCDEFGHIJKLMNOPQRSTUV"
damm64.Calculate(base, "G12Q") // F
damm64.Validate(base, "G12QF") // true

Luhn

Implementation of error detection algorithm for numeric codes from Hans Peter Luhn.

import "github.com/petoc/algo/luhn"
luhn.Calculate("123456789") // 7
luhn.Validate("1234567897") // true

Math

Greatest common divisor

import "github.com/petoc/algo/gcd"
gcd.Euclid(8, 12) // 4

Sources

Damm Quasigroups (https://www.md-software.de/math/DAMM_Quasigruppen.txt)

License

Licensed under MIT license.

About

Collection of algorithm implementations for Go.

Topics

Resources

License

Stars

Watchers

Forks

Languages