Serd is not intended to be a swiss-army knife of RDF syntax, but rather is suited to resource limited or performance critical applications (e.g. converting many gigabytes of NTriples to Turtle), or situations where a simple reader/writer with minimal dependencies is ideal (e.g. in LV2 implementations or embedded applications).
Small: Serd is implemented in around 3000 lines1 of standard C code. On a typical machine it compiles to about 90 KiB, but can be as small as 29 KiB when optimized for size. For comparison, on the same system raptor is 417 KiB and libxml2 is 2.1 MiB (not including dependencies), making serd roughly 5 and 25 times smaller, respectively.
Portable and Dependency Free: Serd uses only the C standard library, and has no external dependencies. It is known to compile with GCC, LLVM/CLang, and MSVC (as C++), and is tested on GNU/Linux, several BSD variants, Mac OS X, and Windows.
Fast and Lightweight: Serd (and the included
serditool) can be used to stream abbreviated Turtle, unlike many tools which must build an internal model to abbreviate. In other words, Serd can serialise an unbounded amount of abbreviated Turtle using a fixed amount of memory, and it does so very quickly: to the author's knowledge, serd is the fastest Turtle reader/writer by a wide margin (see Performance below).
Conformant and Well-Tested: Serd passes all tests in the Turtle and TRiG test suites, correctly handles all "normal" examples in the URI specification, and includes several additional tests, including some found via fuzz testing. The test suite has 100% code coverage (by line), and runs with zero memory errors or leaks2.
|Command||Memory||HDD Time||HDD Throughput||SSD Time||SSD Throughput|
||3.22 MiB||0:35||64.2 MiB/s||0:27||83.2 MiB/s|
||3.6 MiB||0:35||64.2 MiB/s||0:21||107.0 MiB/s|
||3.7 MiB||0:37||60.7 MiB/s||0:22||102.1 MiB/s|
||11124.2 MiB||3:02||12.3 MiB/s||3:03||12.3 MiB/s|
||10.6 MiB||1:26||26.1 MiB/s||1:08||33.0 MiB/s|
Input is mappingbased_properties_en.nt from DBPedia fetched on 2011-12-12 (~17.5M triples, 2247 MiB uncompressed).
System is Debian 7 on an Intel Core i7-2620M.
File system cache was flushed before each run with
echo 3 > /proc/sys/vm/drop_caches.
The variance between identical runs was less than 2 MiB/s, the best of 3 is shown.
Output was redirected to a file on the same disk.
These results show that Serdi is capable of converting NTriples to abbreviated Turtle using a small constant amount of memory.
Serd is fast enough that the process is I/O bound when reading from the hard disk.
Notice in particular that Serd can write abbreviated Turtle much faster than
rapper can perform the much simpler task of reading and writing ntriples.
2. According to valgrind