我正在尝试对像素列表进行增量压缩并将它们存储在二进制文件中。我设法做到了这一点,但是我发现的方法每帧大约需要 4 分钟。
def getByte_List(self):
values = BitArray("")
for I in range(len(self.delta_values)):
temp = Bits(int= self.delta_values[I], length=self.num_bits_pixel)
values.append(temp)
##start_time = time.time()
bit_stream = pack("uint:16, uint:5, bits", self.intial_value, self.num_bits_pixel, values)
##end_time = time.time()
##print(end_time - start_time)
# Make sure that the list of bits contains a multiple of 8 values
if (len(bit_stream) % 8):
bit_stream.append(Bits(uint=0, length = (8-(len(bit_stream) % 8)))) #####Append? On a pack? (Only work on bitarray? bit_stream = BitArray("")
# Create a list of unsigned integer values to represent each byte in the stream
fmt = (len(bit_stream)/8) * ["uint:8"]
return bit_stream.unpack(fmt)
这是我的代码。我取初始值、每个像素的位数和增量值并将它们转换为位。然后我进行字节对齐并采用字节的整数表示并在其他地方使用它。问题区域是我将每个增量值转换为位(3 分钟)和打包(1 分钟)的位置。是否可以更快地完成我正在做的事情或以另一种方式将它们直接打包成表示字节的整数。