=按位分隔符壓縮算法=
把數據進行按一定位數進行分割,比如素數位二進制數據,比如素數位十六進制數據,素數一般取較大值,比如11,13,17,19,23,29;
然后進行統計,為了快速壓縮,可以把數據進行檢索模糊化。
比如使用2,3,5,7。
比如:使用11位的檢索方式,那么就從00000000000到11111111111全部檢索各有多少個(使用了分隔符)比如把
00000000000111111111110000000000011111111111,使用分隔符(編程自定義分隔符,比如使用#),然后就把數據分割為#00000000000#11111111111#00000000000#11111111111#
這樣就不會統計出錯,比如不會把0101和1010都統計成存有101的錯誤,分隔符是為了避免這種檢索錯誤,所以數據分段需要使用分隔符來分割。
分割完畢之后,就進行統計,先是數位統計,統計出從#00000000000#→#00000000001#→#00000000010#→一直到#11111111111#,各有多少個,然后就可以在解壓縮時,生成同樣多的數據,然后進行位移就行了。
數據可以通過統計的方式來得知其長度和數據內容,然而其排列順序完全損失了,就需要通過另外一種方式來記錄順序。
因為是使用11位的二進制來分割統計,那么就可以簡單的劃分為5位+6位的方式來進行順序排列:
比如把?用于取一個模糊值(也就是說#1?1?1#有多種有效可能性,#10101#和#10111#和#11101#和#11111#都可以記錄為#1?1?1#,這里為了減少篇幅,就沒有使用#1?1?1?1?1?1#來作為說明),然后把#1?1?1?1?1?1#記錄為A(沒錯就只是一個字母)→把#1?1?1?1?1?0#記錄為B→#1?1?1?1?0?0#記錄為C→以此類推,當然,如果數位足夠多,那么五十二個英文字母的ASCII碼可能就不夠用了,就需要使用其他的方式來簡寫了,然后把所有的#(特定二進制數)+?+(特定二進制數)+?+(特定二進制數)#都記錄為一個個的字母的方式進行排列。
當然了,也可以把一個11位二進制的數,分為多個數位順序表,比如#11111111111#,分別在第一個數位順序表中,記錄為A,在第二個數位順序表中,記錄為A,在第三個數位順序表中,記錄為A,在第四個數位順序表中記錄為D
#111????????#=A
#110????????#=B
#101????????#=C
#100????????#=D
#011????????#=E
#010????????#=F
#001????????#=G
#000????????#=H
然后進行記錄數位順序表1;
然后定義
#???111?????#=A
#???110?????#=B
#???101?????#=C
#???100?????#=D
#???011?????#=E
#???010?????#=F
#???001?????#=G
#???000?????#=H
然后記錄為數位順序表2;
然后定義
#??????111??#=A
#??????110??#=B
#??????101??#=C
#??????100??#=D
#??????011??#=E
#??????010??#=F
#??????001??#=G
#??????000??#=H
然后記錄為數位順序表3;
然后定義
#?????????00#=A
#?????????01#=B
#?????????10#=C
#?????????11#=D
然后解壓縮時,把N個數位順序表一一重合,就能還原出數據的數位順序(帶分隔符的版本),然后使用全部替換的方式,把分隔符全部去掉,就能還原出原數據的順序了。
壓縮快,解壓縮也快。
片段組合方式,來避免進行重復的整體加一,整體減一的方式來逆推出原先的數據,而是通過拼圖的方式,把數位順序表附帶源數據的一部分數據,然后再把數位順序表合并,就還原出源數據了,這種方式,也可以向前通用到進制碰撞方式中。
=對于另一種可能需要用到人工智能,或者請數學高手來了=
作者還在思考,如何使用一種特定算法,把有N個同樣長度的特定進制的數,通過加法,減法,乘法,除法,階乘,次方號的方式,來生成一個遠遠小于整個算式的結果:
比如:123?339?585?123?234?345?567?678?987?123?234?345?……468?246?=754844625,然后通過結果和運算符號,就能逆推出所有的數,從123,339,到585……468,246;也就是唯一缺失片段只能唯一等式。
數據壓縮算法,本身就是對一個特定長度,使用特定進制的數據,如何使用特定算法,以及算法所需要帶入的數據,來還原成源文件,而這個過程中,要足夠快(這樣壓縮快,解壓縮也快),要盡可能減少試錯次數(也就是使用有缺失的方式,因為有缺失,所以需要一部分的窮舉,然后進行校驗,才能得出沒有錯誤的源文件),要盡可能只有一個碰撞結果(也就是不能一個壓縮后的文件,可以解壓縮出N個不同的版本)。
網頁版章節內容慢,請下載好閱小說app閱讀最新內容
請退出轉碼頁面,請下載好閱小說app 閱讀最新章節。