unboxed VS bytestring

Compare unboxed vs bytestring and see what are their differences.

unboxed

experimenting with unlifted classes via backpack (by ekmett)

bytestring

An efficient compact, immutable byte string type (both strict and lazy) suitable for binary or 8-bit character data. (by haskell)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
unboxed bytestring
3 15
36 283
- 0.4%
0.0 7.9
over 1 year ago 20 days ago
Haskell Haskell
GNU General Public License v3.0 or later BSD 3-clause "New" or "Revised" License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

unboxed

Posts with mentions or reviews of unboxed. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-09-26.
  • How can Haskell programmers tolerate Space Leaks?
    5 projects | /r/haskell | 26 Sep 2021
    With Lev as defined here.
  • [ANNOUNCE] GHC 9.2.1-rc1 is now available!
    2 projects | /r/haskell | 23 Aug 2021
    Check out unboxed. I think that could be a good starting point. I recently updated it to the 9.2.1 alpha here: https://github.com/noughtmare/unboxed/commit/b6338e68540a2c62a6aae6ded0dcdc3b83106916. I should check again if the this issue is fixed in this rc.
  • Principles of Programming Languages - Robert Harper
    4 projects | /r/haskell | 29 Jul 2021
    I tried it out and it is really not usable yet unfortunately. There are several problems. I think the main issue is that you need two versions of all functions and data types. And currently classes like Num are not levity-polymorphic (there is a proposal about this), so you can't use + to add two "real" inductive peano naturals. One problem with making type classes levity-polymorphic is that top-level bindings can't be levity-polymorphic, so mempty cannot be levity-polymorphic. A workaround is to use a type class to levitate levity-polymorphic variables, but that has disadvantages too. Levitated values are not shared and must be recomputed at every call site.

bytestring

Posts with mentions or reviews of bytestring. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-07-01.
  • RunWithScissors() (2009)
    1 project | news.ycombinator.com | 5 Jul 2023
    The documentation is itself fairly funny, for those who don’t care to click ahead:

    > This "function" has a superficial similarity to ‘unsafePerformIO’ but it is in fact a malevolent agent of chaos. It unpicks the seams of reality (and the IO monad) so that the normal rules no longer apply. It lulls you into thinking it is reasonable, but when you are not looking it stabs you in the back and aliases all of your mutable buffers. The carcass of many a seasoned Haskell programmer lie strewn at its feet.

    > Witness the trail of destruction:

        https://github.com/haskell/bytestring/commit/71c4b438c675aa360c79d79acc9a491e7bbc26e7
  • Monthly Hask Anything (July 2022)
    6 projects | /r/haskell | 1 Jul 2022
    If you bring in efficient strings from bytestring, densely packed arrays from vector, and an in-place sort from vector-algorithms, you can bring it down to 275ms (uses 19MB of mem).
  • Some light investigation regarding ByteString's IsString instance, and its conclusions
    1 project | /r/haskell | 22 Jun 2022
  • Haskell - Important Libraries
    11 projects | /r/haskell | 24 Mar 2022
    bytestring
  • [ANNOUNCE] GHC 9.2.2 is now available!
    4 projects | /r/haskell | 7 Mar 2022
    Note that this release is broken for Windows.
  • Beginner level tutorial - bytestring
    1 project | /r/haskellquestions | 17 Dec 2021
    I've opened https://github.com/haskell/bytestring/issues/455 so the situation can be improved. You're very welcome to chime in on the discussion or to contribute some of the missing documentation yourself! :)
  • bytestring-0.11.2.0
    1 project | /r/haskell | 8 Dec 2021
    Highlights from the changelog:
  • [Haskell]
    1 project | /r/ProgrammerAnimemes | 28 Nov 2021
  • Dragging Haskell Kicking and Screaming into the Century of the Fruitbat :: Reasonably Polymorphic
    3 projects | /r/haskell | 13 Nov 2021
    Well, ByteString in particular should not have an IsString instance in a new report. That's pretty clear by https://github.com/haskell/bytestring/issues/140 : the concensus is that there is no good solution right now, but it should not have gotten an IsString instance in the first place. If a theoretical new Haskell Report 202x includes OverloadedStrings (as it should) to handle string literals analogously to numeric literals, I'd expect it to not give ByteString (which is really just a collection of octets) an IsString instance, with all it's issues and rattail due to the encoding question being implicitized.
  • How can Haskell programmers tolerate Space Leaks?
    5 projects | /r/haskell | 26 Sep 2021
    Standard streaming libraries. They are being written by people that make the effort to understand performance and I have a hope that they make sure their streams run in linear space under any optimizations. It is curious and unsettling that we have standard lazy text and byte streams at the same time — and the default lazy lists, of course. I have been doing some work on byte streams and what I found out is that there is no way to check that your folds are actually space constant even if the value in question is a primitive, like say a byte — thunks may explode and then collapse over the run time of a single computation, defying any effort at inspection.

What are some alternatives?

When comparing unboxed and bytestring you can also consider the following projects:

unboxed - experimenting with unlifted classes via backpack

bytestring-read - fast ByteString to number converting library

bytestring-typenats - Haskell ByteStrings annotated with type-level naturals for lengths

bytestring-builder - The new bytestring builder, packaged outside of GHC

bytestring-tree-builder - A very efficient ByteString builder implementation based on the binary tree

bytestring-delta - Simple binary diff/patch library for C and Haskell

bytestring-plain - Plain byte strings (`ForeignPtr`-less `ByteString`s)

streamly-bytestring

bsparse - bytestring parser

bytestring-arbitrary - Arbitrary instances for ByteString

pathological-bytestrings - Facilities for testing with ByteStrings

elm-format - elm-format formats Elm source code according to a standard set of rules based on the official Elm Style Guide