c 实现jpeg中的ALI(可变长度整数转换)正反向转换

用于DC的ALI表:DIFF 就是前后两个8X8块DC的差值,ssss就是DIFF值用二进制表示的位数

亮度,与色度的DC都是这种处理的。两个相邻的亮度与亮度比差,色度与色度比差产生DIFF,

扫描开始DIFF等于0。

用于AC ALI表:表中的AC 就是Z变换后(a,b)对中的b。ssss 是b值用2进制表示的位数

亮度与色度的AC都是这样处理的

对比,两者就是少了0的处理。因为AC中的0已经被(a,b)对中的a处理了。

1.把DC转换为 二进制位数加二进制的中间格式

复制代码
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/ioctl.h>
#include <linux/videodev2.h>  
#include <string.h>
#include <sys/mman.h>
#include <linux/fb.h>
#include <math.h>

int main(void) {
	int i=-5;
	int o=-1;      //如果输出负数无意义
	char len=-1;   //如果输出负数无意义
	
	if(i==0){
		len=0;
	}
	if(i==-1){
		len=1;
		o=0;
	}
	if(i==1){
		len=1;
		o=1;
	}

	if((i>=2)&&(i<=32767)){             //二进制位数0-16位
		for(int a=0;a<16;a++){
			if((i>=pow(2,a))&&(i<pow(2,(a+1)))){
				len=a+1;
				o=i;
			}
		}
	}
	if((i>=-32767)&&(i<=-2)){
		for(int a=0;a<16;a++){
			if((i<=-pow(2,a))&&(i>-pow(2,(a+1)))){
				len=a+1;
				o=i+pow(2,(a+1))-1;
			}
		}
	}
	
	printf("len:%d  o:%d\n",len,o);

	return 0;
}
  1. ALI逆向转换

    #include <stdlib.h>
    #include <string.h>
    #include <stdio.h>
    #include <sys/types.h>
    #include <sys/stat.h>
    #include <fcntl.h>
    #include <stdlib.h>
    #include <unistd.h>
    #include <sys/ioctl.h>
    #include <linux/videodev2.h>
    #include <string.h>
    #include <sys/mman.h>
    #include <linux/fb.h>
    #include <math.h>

    int main(void) {
    int len = 4;
    int i = 7;
    int o;

    复制代码
     if (len == 0) {
     	o = 0;
     }
     if ((len == 1) && (i == 0)) {
     	o = -1;
     }
     if ((len == 1) && (i == 1)) {
     	o = 1;
     }
     //--------------------------
     if ((i >= pow(2, len - 1)) && (i <= pow(2, len))) {
     	o = i;
     }
     if ((i >= 0) && (i < pow(2, len - 1))) {
     	o = i - pow(2, len) + 1;
     }
    
    
     printf("o:%d ", o);
     return 0;

    }

相关推荐
登登登__2 分钟前
MongoDB
java
知星小度S10 分钟前
算法训练之贪心
算法
ππ记录26 分钟前
java面试题带答案2025最新整理
java·开发语言
PHASELESS41128 分钟前
Java栈与队列深度解析:结构、实现与应用指南
java·开发语言·算法
Nigori7_1 小时前
day33-动态规划__62.不同路径__63. 不同路径 II __343. 整数拆分__343. 整数拆分
算法·动态规划
SeasonedDriverDG1 小时前
C语言编写的线程池
linux·c语言·开发语言·算法
2401_872945091 小时前
【补题】Codeforces Round 857 (Div. 1) A. The Very Beautiful Blanket
算法
LAOLONG-C1 小时前
C语言 栈 的 描述 和 详解
c语言·数据结构·算法
辛姜_千尘红回1 小时前
AT_abc398_e [ABC398E] Tree Game 题解
c语言·c++·笔记·算法
Huazie1 小时前
flea-cache使用之Redis哨兵模式接入
java·redis·开源