压缩Java中的字节数组并在C中解压缩

前端之家收集整理的这篇文章主要介绍了压缩Java中的字节数组并在C中解压缩前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我目前在 Java程序中有以下数组,
byte[] data = new byte[800];

我想在通过串口(115200 Baud)将其发送到微控制器之前对其进行压缩.我想在C中用微控制器解压缩数组.但是,我不太确定最好的方法是什么.性能是一个问题,因为微控制器只是一个arduino所以它不能太存储器/ cpu密集型.数据或多或少是随机的(编辑我猜它不是那么随机,请看下面的编辑)我会说因为它代表每16位的rgb颜色值.

压缩这些数据的最佳方法是什么?知道我可以得到多少压缩?

编辑

对于缺乏信息感到抱歉.我需要压缩无损,我只打算一次发送800个字节.我的问题是800字节不能以我正在使用的115200波特率快速传输.我希望我能缩小一点尺寸以提高速度.

每两个字节看起来像:

0RRRRRGGGGGBBBBB

其中R G和B位分别代表红色,绿色和蓝色的颜色通道的值.然后,每两个字节就是20×20网格上的单个LED.我会想象很多两个字节都是相同的,因为我经常为多个LED分配相同的颜色代码.也可能是RGB值通常> 1的情况.因为我通常使用鲜艳的颜色(但是,这可能是一个没有实际意义的点,因为它们通常不是一次都是> 15).

解决方法@H_301_20@
如果数据“或多或少随机”,那么压缩它就不会有太多运气,我担心.

UPDATE

鉴于新信息,我敢打赌你的LED显示屏上不需要32k色.我想象一个1024或256色的调色板可能就足够了.因此,你可以通过一个简单的压缩方案(简单地通过查找表映射每个单词,或者可能只丢弃每个组件的lsbs),这甚至可以用于完全不相关的像素值.

原文链接:https://www.f2er.com/java/126971.html

猜你在找的Java相关文章