<< Previous Message Main Index Next Message >>
<< Previous Message in Thread This Month Next Message in Thread >>
Date   : Mon, 18 Sep 2006 09:22:51 +0100
From   : "Steve O'Leary" <navalenigma@...>
Subject: Re: Compressed ROMFS?

--_49da7632-128d-49f5-9b1c-02cc00dcf0c1_




From: navalenigma@... bbc-micro@cloud9.co.ukDate: Mon, 18 Sep 20
06 09:10:12 +0100Subject: RE: [BBC-Micro] Compressed ROMFS?




> From: info@...> To: bbc-micro@cloud9.co.uk> Date: Mon, 18 Sep 200
6 07:50:20 +0100> Subject: Re: [BBC-Micro] Compressed ROMFS?> > In article
<4e67ac7d89info@...>,>    Sprow <info@sprow.co.uk> wrote:> > In art
icle <20060916095434.53696.qmail@...>,> >    Greg C
ook <debounce@...> wrote:> > > Did anyone ever come up with a syste
m for compressing files in ROMFS> > > images?  I sketched out a dictionary
based algorithm yesterday but the> > > hard part is finding the repeating s
ubstrings.> >> > I had a quick bash this morning at Huffman coding some dat
a> >> > For tokenised BASIC you can save 21%> > For 6502 binaries you can s
ave 10%> > As a postscript to my own message, I tried some bitmapped data t
oo (very> high proportion of 0's for black) and that compressed by 61%.> >
Lastly I wrote an RLE compressor using the madness proposed in> <4e5b03df85
info@...> and that gave>   For 6502 binaries you can save just 1%>
  For tokenised BASIC you save -2% (ie.bigger!)>   For bitmap images with h
igh black content 41%> Sprow.I'm glad you've had a go and got some figures.
 I can't see LZW performing any better than Huffman on binaries and the sav
ings were not that brilliant. The thing is for the life in me I cannot actu
ally remember why I wanted to do this in the first place now. There was a r
eason to it all, perhaps images, I'm not sure. Maybe if we wrote LZW in nor
mal memory (not in a ROM) so we can use the normal full memory as workspace
 and just see if it performs any better. As Greg mentioned there could be i
ssues with the limited scratchspace you have unless you alter page but we w
ouldn't want to do that.  However as it's a fairly small algorythm I suppos
e it could run in sideways RAM and use what's left of it's 16K as dictionar
y space ? Limits it's usefulnes for those with SW-RAM though :( And as I've
 never actually written an LZW routine, would we need to check for running
out of dictionary space ? Obviously depends on the size of file to be compr
essed, do you know what the average dictionary size is as a percentage of o
riginal file size ?
The line;
 
Limits it's usefulnes for those with SW-RAM though :( 
 
should of course read;
 
Limits it's usefulnes for those WITHOUT SW-RAM though :( 
 
Doh !
_________________________________________________________________
Be one of the first to try Windows Live Mail.
http://ideas.live.com/programpage.aspx?versionId=5d21c51a-b161-4314-9b0e-
4911fb2b2e6d

--_49da7632-128d-49f5-9b1c-02cc00dcf0c1_


--_49da7632-128d-49f5-9b1c-02cc00dcf0c1_--



<< Previous Message Main Index Next Message >>
<< Previous Message in Thread This Month Next Message in Thread >>