| Commit message (Collapse) | Author | Age | |
|---|---|---|---|
| * | test: up 'random' dependency | Tom Smeding | 2025-04-23 | 
| | | |||
| * | arith: Better typing of enum stats_binary_id | Tom Smeding | 2025-04-15 | 
| | | |||
| * | arith: Don't use C23 features | Tom Smeding | 2025-04-15 | 
| | | |||
| * | Dotprod: Optimise reversed and replicated dimensions | Tom Smeding | 2025-03-25 | 
| | | |||
| * | bench: Dot product benchmarks | Tom Smeding | 2025-03-25 | 
| | | |||
| * | bench: Move comparison benchmarks to separate function | Tom Smeding | 2025-03-25 | 
| | | |||
| * | Improve an error message | Tom Smeding | 2025-03-25 | 
| | | |||
| * | Compatibility liftVEltwise1 (TODO remove) | Tom Smeding | 2025-03-20 | 
| | | |||
| * | Fix typo in error message | Tom Smeding | 2025-03-20 | 
| | | |||
| * | Some re-exports for compatibility | Tom Smeding | 2025-03-20 | 
| | | |||
| * | Separate arith routines into a library | Tom Smeding | 2025-03-20 | 
| | | | | | The point is that this separate library does not depend on orthotope. | ||
| * | arith stats: Print timings with 3 digits precision | Tom Smeding | 2025-03-18 | 
| | | | | | | If you render microseconds timings as milliseconds, you _have_ only 3 digits behind the decimal point. | ||
| * | arith stats: Improve output format | Tom Smeding | 2025-03-18 | 
| | | | | | | | This makes it nicer to process using unix tools. Try: $ sed -n '/ox-arrays-arith-stats start/,/ox-arrays-arith-stats end/ !d; /===/ !p' | sort -n -k4,4 -k6,6 | ||
| * | Arith statistics collection from C | Tom Smeding | 2025-03-18 | 
| | | |||
| * | arith: Don't FFI-import unused dotprod_*_strided ops | Tom Smeding | 2025-03-18 | 
| | | |||
| * | Optimise reductions and dotprod with more vectorisation | Tom Smeding | 2025-03-14 | 
| | | | | | | | | | | Turns out that if you don't supply -ffast-math, the C compiler will faithfully reproduce your linear reduction order, which is rather disastrous for parallelisation with vector units. This changes the summation order, so numerical results might differ slightly. To wit: the test suite needed adjustment. | ||
| * | Provide +nonportable-simd flag | Tom Smeding | 2025-03-14 | 
| | | |||
| * | bench: Update with recent renames | Tom Smeding | 2025-03-14 | 
| | | |||
| * | arith: Remove CASE1, add restrict | Tom Smeding | 2025-03-14 | 
| | | | | | | | | | | Turns out that GCC already splits generates separate code for an inner stride of 1 automatically, so no need to do fancy stuff in C. Also, GCC generated a whole bunch of superfluous code to correctly handle the case where output and input arrays overlap; since this never happens in our case, let's add `restrict` and save some binary size. | ||
| * | arith: Correct rank arguments to C wrapper functions | Tom Smeding | 2025-03-13 | 
| | | |||
| * | Export IntElt | Tom Smeding | 2025-03-13 | 
| | | |||
| * | Rename arithPromote* to lift* (unrelated to arith ops, really) | Tom Smeding | 2025-03-13 | 
| | | |||
| * | Add atan2 | Tom Smeding | 2025-03-13 | 
| | | |||
| * | arith: Fix enum typing typos | Tom Smeding | 2025-03-13 | 
| | | |||
| * | Implement quot/rem | Tom Smeding | 2025-03-13 | 
| | | |||
| * | Remove redundant constraints on arith instances | Tom Smeding | 2025-03-12 | 
| | | |||
| * | Slight cleanup of arith instances for Mixed/Ranked/Shaped | Tom Smeding | 2025-03-12 | 
| | | | | | Reformulate error messages; add NumElt superclass to FloatElt | ||
| * | Binary ops without normalisation | Tom Smeding | 2025-03-12 | 
| | | | | | | | | | | Before: > sum(*) Double [1e6] stride 1; -1: OK > 68.9 ms ± 4.7 ms After: > sum(*) Double [1e6] stride 1; -1: OK > 1.44 ms ± 50 μs | ||
| * | bench: Measure binary op on mismatched strides | Tom Smeding | 2025-03-12 | 
| | | |||
| * | More consistent equality functions on shapes | Tom Smeding | 2025-03-11 | 
| | | |||
| * | C: Simplify DOTPROD_STRIDED_OP signature | Tom Smeding | 2025-03-05 | 
| | | |||
| * | arith: Unary float ops on strided arrays without normalisation | Tom Smeding | 2025-03-05 | 
| | | |||
| * | Orthotope has been updated: less hacks | Tom Smeding | 2025-03-03 | 
| | | |||
| * | All arrays are Eq and Ord (they compare shape first, then values) | Tom Smeding | 2025-02-18 | 
| | | | | | | This comparison policy is lifted straight from orthotope (and indeed the instances are all just auto-derived). | ||
| * | Less pointless standalone Ord instances | Tom Smeding | 2025-02-18 | 
| | | |||
| * | arith: Fix unary op stride bugs | Tom Smeding | 2025-02-18 | 
| | | |||
| * | arith: Some negate tests (to check stride handling) | Tom Smeding | 2025-02-18 | 
| | | |||
| * | Fix a typo in an error message | Mikolaj Konarski | 2025-02-17 | 
| | | |||
| * | arith: Only strided unary int ops | Tom Smeding | 2025-02-16 | 
| | | | | | | This should have negligible overhead and will save a whole bunch of C code duplication when the FUnops are also converted to strided form. | ||
| * | arith: Unary int ops on strided arrays without normalisation | Tom Smeding | 2025-02-16 | 
| | | |||
| * | arith: Fix cover calculation in stridesDense | Tom Smeding | 2025-02-16 | 
| | | | | | | The calculation was incorrect for windowed arrays (as produced by RS.window) | ||
| * | Remove 'type data' for now (GHC 9.10 breaks) | Tom Smeding | 2025-02-15 | 
| | | |||
| * | mcastSafe, castCastable | Tom Smeding | 2025-02-01 | 
| | | |||
| * | Up ghc to 9.8.4 | Tom Smeding | 2025-02-01 | 
| | | |||
| * | Eliminate the lame shaped fromInteger implementation | Mikolaj Konarski | 2025-01-24 | 
| | | |||
| * | Export IShX from Nested | Mikolaj Konarski | 2025-01-09 | 
| | | |||
| * | Export ListX from Nested | Mikolaj Konarski | 2025-01-07 | 
| | | |||
| * | Pull orthotope from git | Tom Smeding | 2025-01-04 | 
| | | |||
| * | Add some spuriously missing Eq/Generic instances | Tom Smeding | 2024-12-18 | 
| | | |||
| * | Uniformise NFData instance (by putting rnf in Elt) | Tom Smeding | 2024-12-18 | 
| | | | | | | | This now depends on: https://github.com/augustss/orthotope/pull/14 My sincere apologies. | ||
