An open API service indexing awesome lists of open source software.

https://github.com/petoc/algo

Collection of algorithm implementations for Go.
https://github.com/petoc/algo

algorithm damm go golang luhn

Last synced: 7 days ago
JSON representation

Collection of algorithm implementations for Go.

Awesome Lists containing this project

README

          

# Algorithms

Collection of algorithm implementations for Go.

### Error detection

[Damm](https://github.com/petoc/algo/tree/master/damm)

[Damm64](https://github.com/petoc/algo/tree/master/damm64) (using quasigroups for character base from 3 to 64 characters)

[Luhn](https://github.com/petoc/algo/tree/master/luhn)

### Math

[Greatest common divisor](https://github.com/petoc/algo/tree/master/gcd) (Euclid)

## Usage

### Error detection

#### Damm

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

```go
import "github.com/petoc/algo/damm"
```

```go
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.

```go
import "github.com/petoc/algo/damm64"
```

```go
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.

```go
import "github.com/petoc/algo/luhn"
```

```go
luhn.Calculate("123456789") // 7
luhn.Validate("1234567897") // true
```

### Math

#### Greatest common divisor

```go
import "github.com/petoc/algo/gcd"
```

```go
gcd.Euclid(8, 12) // 4
```

## Sources

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

## License

Licensed under MIT license.