close
Warning:
Can't synchronize with repository "(default)" (Unsupported version control system "darcs": Can't find an appropriate component, maybe the corresponding plugin was not enabled? ). Look in the Trac log for more information.
- Timestamp:
-
2010-03-12 07:00:12 (15 years ago)
- Author:
-
zooko
- Comment:
-
yay whee
Legend:
- Unmodified
- Added
- Removed
- Modified
-
v5
|
v6
|
|
16 | 16 | }}} |
17 | 17 | |
18 | | This work fine as long as the total amount of bytes accumulated and the number of separate {{{add_data()}}} events stay small, but it has O(N^2^) behavior and has bad performance if those numbers get large. Here are some benchmarks generated by running {{{python -OOu -c 'from stringchain.bench import bench; bench.quick_bench()'}}} as instructed by [source:README.txt the README.txt file]: |
| 18 | This work fine as long as the total amount of bytes accumulated and the number of separate {{{add_data()}}} events stay small, but it has O(N^2^) behavior and has bad performance if those numbers get large. Here are some benchmarks generated by running {{{python -OOu -c 'from stringchain.bench import bench; bench.quick_bench()'}}} as instructed by [source:README.txt the README.txt file]. |
| 19 | |
| 20 | The {{{N:}}} in the left-hand column is how many bytes were in the test dataset. The {{{ave rate:}}} number in the right-hand column is how many bytes per second were processed. "naive" means the string-based idiom sketched above and "strch" means using the !StringChain class. |
19 | 21 | |
20 | 22 | {{{ |
… |
… |
|
51 | 53 | }}} |
52 | 54 | |
53 | | The naive approach is slower than the !StringChain library, and the bigger the dataset the slower it goes. The !StringChain library is scalable (with regard to these benchmarks at least...). |
| 55 | The naive approach is slower than the !StringChain class, and the bigger the dataset the slower it goes. The !StringChain class is scalable (with regard to these benchmarks at least...). |
54 | 56 | |
55 | 57 | Okay how do you use it? It is very simple -- see [source:stringchain/stringchain.py] and let me know if that interface doesn't fit your use case. |