uint16 в xx.x float - самый быстрый алгоритм? - PullRequest
0 голосов
/ 01 октября 2019

Я получаю данные от датчика температуры, который отформатирован как два байта, которые представляют собой двоичное кодирование данных с фиксированной шириной и плавающей запятой. Схема кодирования может быть продемонстрирована в следующей таблице:

| temperature | hexadecimal | int16 |
| 0.1 *F      | 0x00 0x01   | 01    |
| 10.0 *F     | 0x00 0x64   | 100   |

Чтобы восстановить значение с плавающей запятой, я написал следующую короткую программу:

package main

import (
    "encoding/binary"
    "fmt"
    "strconv"
)

func main() {
    b1 := byte(0x02)
    b2 := byte(0xBC)
    b := []byte{b1, b2}
    intgr := binary.BigEndian.Uint16(b)
    str := fmt.Sprint(intgr)
    l := len(str)
    front := str[:l-1]
    decimal := str[l-1:]
    str = fmt.Sprintf("%v.%v", front, decimal)
    float, _ := strconv.ParseFloat(str, 64)
    fmt.Println(float)
}

Однако это немного слишкоммедленно для моих нужд, что я думаю, потому что я использовал Sprint / Sprintf. Есть ли более быстрый (и, возможно, более чистый) алгоритм для этого?

1 Ответ

1 голос
/ 01 октября 2019

Преобразование байтов в число и деление на 10:

b := []byte{0x02, 0xBC}
f := float64(binary.BigEndian.Uint16(b)) / 10.0

Обратное преобразование:

p := make([]byte, 2)
binary.BigEndian.PutUint16(p, uint16(math.Round(f*10.0)))

Для обработки отрицательных чисел, преобразуйте uint16 в int16 передпреобразование в число с плавающей точкой:

f := float64(int16(binary.BigEndian.Uint16(p))) / 10.0
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...