Libraryless. Click here for Pure Java version (5340L/30K).
// assigns probability pStart for first element, pEnd for last element // (rest linearly interpolated) // // f may return an instance of IProbabilistic (or a normal Runnable) static <A> void probabilisticForEach(IProbabilisticScheduler scheduler, double pStart, double pEnd, Cl<A> l, IVF1<A> f) { if (scheduler == null || f == null) ret; probabilisticForEach(scheduler, pStart, pEnd, iterator(l), 0, l(l), 1.0, f); } static <A> void probabilisticForEach(IProbabilisticScheduler scheduler, double pStart, double pEnd, Iterator<A> it, int i, int n, double myProb, IVF1<A> f) { assertTrue(pEnd <= pStart); if (scheduler == null || f == null || !it.hasNext()) ret; // get element A a = it.next(); // calculate probability for element double p = blend(pStart, pEnd, doubleRatio(i, n-1)); // run client function scheduler.at(new Runnable { run { f.get(a); } toString { ret formatFunctionCall(f, a); } }); // schedule next element at lower probability scheduler.atRelative(doubleRatio(p, myProb), -> probabilisticForEach(scheduler, pStart, pEnd, it, i+1, n, p, f)); }
download show line numbers debug dex old transpilations
Travelled to 3 computer(s): bhatertpkbcr, mowyntqkapby, mqqgnosmbjvj
No comments. add comment
| Snippet ID: | #1033144 |
| Snippet name: | probabilisticForEach |
| Eternal ID of this version: | #1033144/6 |
| Text MD5: | 646c76a6cde3375b2ec9cc6f9538deb3 |
| Transpilation MD5: | a755f3728690ce09ed63633528e4245a |
| Author: | stefan |
| Category: | javax / probabilistic scheduling |
| Type: | JavaX fragment (include) |
| Public (visible to everyone): | Yes |
| Archived (hidden from active list): | No |
| Created/modified: | 2021-10-25 03:20:38 |
| Source code size: | 1147 bytes / 30 lines |
| Pitched / IR pitched: | No / No |
| Views / Downloads: | 378 / 505 |
| Version history: | 5 change(s) |
| Referenced in: | [show references] |