speedy-stdio ~tablefmttest
A faster replacement for a subset of std.stdio
To use this package, run the following command in your project's root directory:
Manual usage
Put the following dependency into your project's dependences section:
speedy-stdio
Note: it's a very new library in its eary days and may contain bugs. Bugreports are welcome!
Do you have a program implemented in D programming language, which somehow needs to read and parse gigantic amounts of text from stdin and then write gigantic amounts of text to stdout? If the answer is "yes", then this library may be interesting for you.
The speedy.stdio module extends std.stdio by substituting functions write, writeln, writef and writefln with faster replacements. These replacements are optimized to handle only the most basic format variants (decimal integers and non-escaped strings), but do it very fast. They are also compatible with the @nogc attribute as an extra bonus. More complicated format variants are still handled transparently via having a fallback to std.format.write.formattedWrite for full compatibility with Phobos (but whenever such fallbacks are used, the performance and @nogc compatibility is lost).
Another bundled speedy.fakestdio module only imitates the API of std.stdio, but cuts some extra corners for additional speed. It is not thread-safe and it also assumes that it has exclusive monopoly to access stdout (doesn't play nice together with printf or with the original functions from the real std.stdio inside of the same program). Also it only imitates stdout.flush and has no support for the other methods of std.stdio.File. Use with caution! But this is good enough for use in solutions submitted to competitive programming platforms, such as Codeforces or AtCoder.
Example
A 99 bottles of beer example code, intentionally using different varieties of functions:
/+dub.sdl:
dependency "speedy-stdio" version="~>0.2.0"
+/
@safe @nogc: // note: remove @nogc to compile with the standard "std.stdio"
import speedy.stdio; // this can be also "std.stdio" or "speedy.fakestdio"
const repeats = 1; // change this to something much larger when benchmarking
void main() {
foreach (i ; 0 .. repeats) {
auto bottles(int n) { return n == 1 ? " bottle" : " bottles"; }
foreach_reverse(n ; 1 .. 100) {
writefln!"%d%s of beer on the wall, %d%s of beer."(n, bottles(n), n, bottles(n));
static immutable a = ["Take", "one", "down", "and", "pass", "it", "around"];
a.writef!"%-(%s %), ";
if (n - 1 <= 0)
write("no more bottles");
else
write(n - 1, bottles(n - 1));
writeln(" of beer on the wall.");
writeln;
}
writeln("No more bottles of beer on the wall, no more bottles of beer.");
writeln("Go to the store and buy some more, 99 bottles of beer on the wall.");
}
}
Install the DUB package manager and run the example in a script-like fashion:
$ dub bottles.d
Or compile an optimized binary using the LDC compiler:
$ dub build --build release --single --compiler=ldc2 bottles.d
Performance
Changing "repeats" to 100000 in the "99 bottles of beer" example above and running it on a 64-bit Linux system with Intel Core i7-860 @2.8GHz processor produces the following results (redirected to /dev/null):
used module | test code | repeats | DMD 2.099.1 | LDC 1.30.0 | GDC 9.5.0 | GDC 12.2.0 |
---|---|---|---|---|---|---|
std.stdio | 99 bottles of beer | 100000 | 34.777s | 17.874s | 13.146s | 26.120s |
speedy.stdio | 99 bottles of beer | 100000 | 9.132s | 4.749s | 4.124s | 4.757s |
speedy.fakestdio | 99 bottles of beer | 100000 | 5.403s | 1.749s | 2.057s | 3.310s |
Another benchmark is just printing numbers from 0 to 100M on each line (redirected to /dev/null):
/+dub.sdl:
dependency "speedy-stdio" version="~>0.2.0"
+/
@safe @nogc: // note: remove @nogc to compile with the standard "std.stdio"
import speedy.stdio; // this can be also "std.stdio" or "speedy.fakestdio"
void main() {
import std.range;
100000001.iota.writefln!"%(%d\n%)";
}
used module | test code | compiler | LDC 1.30.0 |
---|---|---|---|
std.stdio | count to 100M | LDC 1.30.0 | 17.520s |
speedy.stdio | count to 100M | LDC 1.30.0 | 2.349s |
speedy.fakestdio | count to 100M | LDC 1.30.0 | 1.809s |
- Registered by Siarhei Siamashka
- ~tablefmttest released 2 years ago
- ssvb/speedy-stdio
- BSL-1.0
- Authors:
- Dependencies:
- none
- Versions:
-
0.2.0 2022-Dec-11 0.1.2 2022-Dec-05 0.1.0 2022-Dec-05 ~xxx 2022-Dec-11 ~wip 2022-Dec-15 - Download Stats:
-
-
0 downloads today
-
1 downloads this week
-
1 downloads this month
-
89 downloads total
-
- Score:
- 0.4
- Short URL:
- speedy-stdio.dub.pm