mirror of https://bitbucket.org/ausocean/av.git
82 lines
1.3 KiB
Go
82 lines
1.3 KiB
Go
/*
|
|
|
|
|
|
AUTHORS
|
|
Saxon Nelson-Milton <saxon@ausocean.org>, The Australian Ocean Laboratory (AusOcean)
|
|
*/
|
|
|
|
// Package provides general helper utilities to the h264 package.
|
|
package h264dec
|
|
|
|
import (
|
|
"errors"
|
|
"math"
|
|
)
|
|
|
|
// binToSlice is a helper function to convert a string of binary into a
|
|
// corresponding byte slice, e.g. "0100 0001 1000 1100" => {0x41,0x8c}.
|
|
// Spaces in the string are ignored.
|
|
func binToSlice(s string) ([]byte, error) {
|
|
var (
|
|
a byte = 0x80
|
|
cur byte
|
|
bytes []byte
|
|
)
|
|
|
|
for i, c := range s {
|
|
switch c {
|
|
case ' ':
|
|
continue
|
|
case '1':
|
|
cur |= a
|
|
case '0':
|
|
default:
|
|
return nil, errors.New("invalid binary string")
|
|
}
|
|
|
|
a >>= 1
|
|
if a == 0 || i == (len(s)-1) {
|
|
bytes = append(bytes, cur)
|
|
cur = 0
|
|
a = 0x80
|
|
}
|
|
}
|
|
return bytes, nil
|
|
}
|
|
|
|
// binToInt converts a binary string provided as a string and returns as an int.
|
|
// White spaces are ignored.
|
|
func binToInt(s string) (int, error) {
|
|
var sum int
|
|
var nSpace int
|
|
for i := len(s) - 1; i >= 0; i-- {
|
|
if s[i] == ' ' {
|
|
nSpace++
|
|
continue
|
|
}
|
|
sum += int(math.Pow(2, float64(len(s)-1-i-nSpace))) * int(s[i]-'0')
|
|
}
|
|
return sum, nil
|
|
}
|
|
|
|
func maxi(a, b int) int {
|
|
if a > b {
|
|
return a
|
|
}
|
|
return b
|
|
}
|
|
|
|
func mini(a, b int) int {
|
|
if a < b {
|
|
return a
|
|
}
|
|
return b
|
|
}
|
|
|
|
func absi(a int) int {
|
|
if a < 0 {
|
|
return -a
|
|
}
|
|
return a
|
|
}
|