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;

    }

相关推荐
AI进化营-智能译站38 分钟前
ROS2 C++开发系列17-多线程驱动多传感器|chrono高精度计时实现机器人同步控制
java·c++·ai·机器人
一切皆是因缘际会4 小时前
从概率拟合到内生心智:2026 下一代 AI 架构演进与落地实践
人工智能·深度学习·算法·架构
Java成神之路-4 小时前
【LeetCode 刷题笔记】34. 在排序数组中查找元素的第一个和最后一个位置 | 二分查找经典刷题题解
算法·leetcode
qq_589568104 小时前
springbootweb案例,出现访问 http://localhost:8080/list 一直处于浏览器运转阶段
java·网络协议·http·list·springboot
不忘不弃4 小时前
用BFS方法求解平分汽油问题
算法·宽度优先
AI科技星4 小时前
全域数学·72分册·射影原本 无穷维射影几何卷细化子目录【乖乖数学】
人工智能·线性代数·算法·机器学习·数学建模·数据挖掘·量子计算
风落无尘4 小时前
《智能重生:从垃圾堆到AI工程师》——第四章 变化的艺术
人工智能·线性代数·算法
JAVA面经实录9174 小时前
计算机基础(完整版·超详细可背诵)
java·linux·数据结构·算法
AC赳赳老秦5 小时前
知识产权辅助:用 OpenClaw 批量生成专利交底书 / 软著申请材料,自动校验格式与内容合规性
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
WBluuue5 小时前
Codeforces 1093 Div2(ABCD1D2)
c++·算法