[Haskell-cafe] Bit string

Lennart Augustsson lennart at augustsson.net
Thu Sep 14 21:48:49 EDT 2006


It's hard to tell what the best representation is if you don't know  
what the operations that you are going to perform are.  If all you  
are going to do is I/O of bitstrings, then [Bool] could be great.  If  
you need to do bitwise boolean ops then Integer is a wise choice.

	-- Lennart


On Sep 14, 2006, at 21:35 , Thomas Conway wrote:

> Hi all,
>
> I'm doing some work with ASN.1, and I'm thinking about how to
> represent the type "BIT STRING".
>
> The obvious, and inefficient representation would be
>> type BitString = [Bool]
>
> A reasonable sparse representation might be
>> type BitString = [Integer]
> where the integers represent the positions of the non-zero bits, but
> other implementations (e.g. C & C++ based ones) mostly seem to use
> dense representations, and there are certain predictability advantages
> to be had by following existing implementations in this regard.
>
> But given that a value of type BIT STRING is allowed to have leading 0
> bits, which have no semantic effect, another representation would be
>> type BitString = [Word64]
> (I'm a modern type, and believe in 64bit computing ;-), but you could
> use Word32 if you liked).
>
> However, after a few moments' consideration, I realized, that if I was
> going to use a representation like that, I could probably use
>> type BitString = Integer
> which already has [I assume] a carefully optimized implementation.
> Also, it ends up being significantly more strict than a list
> representation, which is probably a good thing in most situations.
>
> My question for all present is: Have I missed either a problem with
> using Integer, or have I overlooked a better representation?
>
> T.
> _______________________________________________
> Haskell-Cafe mailing list
> Haskell-Cafe at haskell.org
> http://www.haskell.org/mailman/listinfo/haskell-cafe



More information about the Haskell-Cafe mailing list