fvid/fvid/fvid_cython.pyx

69 lines
1.8 KiB
Cython

# distutils: language=c++
# cython: boundscheck=False
# cython: cdivision=True
# cython: wraparound=False
# cython: nonecheck=False
# cython: c_string_type=unicode, c_string_encoding=ascii
from tqdm import tqdm
from zfec import easyfec as ef
from libcpp.string cimport string
cpdef str cy_gbfi(image):
cdef int width, height, x, y
cdef string bits = b''
cdef (int, int, int) pixel
width, height = image.size
px = image.load()
for y in range(height):
for x in range(width):
pixel = px[x, y]
# if the white difference is smaller (comparison part 1), that means the pixel is closer
# to white, otherwise, the pixel must be black
bits.append(b'1' if abs(pixel[0] - 255) < abs(pixel[0] - 0) and abs(pixel[1] - 255) < abs(pixel[1] - 0) and abs(pixel[2] - 255) < abs(pixel[2] - 0) else b'0')
return bits
cpdef str cy_gbfi_h265(image):
cdef int width, height, x, y
cdef string bits = b''
width, height = image.size
px = image.load()
for y in range(height):
for x in range(width):
bits.append(b'1' if px[x, y] == 255 else b'0')
return bits
cpdef str cy_encode_zfec(string bits):
cdef int b, KVAL = 4, MVAL = 5, BLOCK = 16
cdef string ecc_bytes = b'', byte
cdef tuple byte_tuple
# cdef (string, string, string, string, string) temp
byte_tuple = split_string_by_n(bits, BLOCK)
print("Applying Zfec Error Correction...")
encoder = ef.Encoder(KVAL, MVAL)
for b in tqdm(range(len(byte_tuple))):
for byte in encoder.encode(byte_tuple[b].encode('utf-8')):
ecc_bytes.append(byte)
return ecc_bytes
cdef tuple split_string_by_n(str bitstring, int n):
cdef list bit_list = []
for i in range(0, len(bitstring), n):
bit_list.append(bitstring[i:i+n])
return tuple(bit_list)