现在的位置: 首页 > 综合 > 正文

历史不是简单的重复,但却有惊人的相似——mid格式30年后

2018年10月30日 ⁄ 综合 ⁄ 共 771字 ⁄ 字号 评论关闭


一个字节有8位,如果仅使用7位,它可以表示0~127这128个数,而剩下的一位,则用来作为标志。如果要表示的数在以上范围,则这个标志为0,这时,一个7位的字节可以表示0~127tick。如果要表示的数超出了这个范围(比如240),则把标志设置成1,然后记录下高7位,剩下的留给下一个字节,在该例中240可以分解成128*1+112,这里的1就是第一个字节要记录的,加上标志位,应该为10000001,即十六进制的81;而112是下一个字节记录的,它的十六进制为70:所以要表示240这个时间,要写成81 70。同理,如果要表示65535tick,则可以先计算出65535=1282*3+1281*127+1280*127,然后得出结果:83
FF 7F。由此,我们反过来也可以知道如何确定时间差:只要标志位为0,则表示结束读取时间差。比如82 C0 03表示1282*2+1281*64+1280*3=40963,如果基本时间为120,则有341:043个四分音符。

以这种方式记录整数的字节称为动态字节,它根据记录的整数改变自身的长度

这是midi中关于“动态字节”的定义成文定型于1983~85年。我们来和一段压缩算法描述做比较一下:

What is varint? 根据官方解释可以很清晰的了解到,它是一种用 1 个或多个字节序列化 integer 的一种方法, Smaller numbers take a smaller number of bytes. 传统的 integer 是以 32 位来表示的,存储需要 4 个字节,当如果整数大小在 256 以内,那么只需要用一个字节就可以存储这个整数,这样就可以节省 3 个字节的存储空间

发现了吗?思想正相反!
Google 的Group varint 是对 varint 的一种优化

历史不是简单的重复,但却有惊人的相似


MIDI,Group varint。相差近30年

抱歉!评论已关闭.