PHP Функция распаковки двоичных файлов LZW

Я искал в Интернете и не смог найти реализацию распаковки LZW в PHP, которая работает с данными, выводимыми этими функции javascript:

function lzw_encode(s) {
    var dict = {};
    var data = (s + "").split("");
    var out = [];
    var currChar;
    var phrase = data[0];
    var code = 256;
    for (var i=1; i<data.length; i++) {
        currChar=data[i];
        if (dict[phrase + currChar] != null) {
            phrase += currChar;
        }
        else {
            out.push(phrase.length > 1 ? dict[phrase] : phrase.charCodeAt(0));
            dict[phrase + currChar] = code;
            code++;
            phrase=currChar;
        }
    }
    out.push(phrase.length > 1 ? dict[phrase] : phrase.charCodeAt(0));
    for (var i=0; i<out.length; i++) {
        out[i] = String.fromCharCode(out[i]);
    }
    return out.join("");
}

function lzw_decode(s) {
    var dict = {};
    var data = (s + "").split("");
    var currChar = data[0];
    var oldPhrase = currChar;
    var out = [currChar];
    var code = 256;
    var phrase;
    debugger;
    for (var i=1; i<data.length; i++) {
        var currCode = data[i].charCodeAt(0);
        if (currCode < 256) {
            phrase = data[i];
        }
        else {
           phrase = dict[currCode] ? dict[currCode] : (oldPhrase + currChar);
        }
        out.push(phrase);
        currChar = phrase.charAt(0);
        dict[code] = oldPhrase + currChar;
        code++;
        oldPhrase = phrase;
    }
    return out.join("");
}

Мне просто нужен алгоритм распаковки в PHP, который может работать с функцией сжатия javascript, описанной выше.

Приведенная выше функция кодирования lzw _кодирует «Это тест функции сжатия» как «Это тест функции сжатия»

Библиотеки, которые я нашел, содержат ошибки(http://code.google.com/p/php-lzw/)или не вводите символы UTC.

Будем признательны за любую помощь.

Спасибо!

8
задан xd44 26 April 2012 в 23:47
поделиться