Advent-of-Nix-2024/utils.nix

38 lines
1.2 KiB
Nix
Raw Normal View History

2024-12-01 15:50:11 +01:00
{ lib, ... }:
with lib;
with builtins; rec {
2024-12-02 10:00:36 +01:00
readLines = f: init (filter isString (split "\n" (readFile f)));
2024-12-03 10:51:06 +01:00
reSplit = re: s: filter isString (split re s);
matchAll = re: s: filter isList (split re s);
splitWhitespace = reSplit "[[:space:]]+";
2024-12-01 15:50:11 +01:00
abs = i: if i >= 0 then i else i * -1;
delta = x: y: abs (x - y);
listSum = foldl' add 0;
2024-12-04 13:12:45 +01:00
listSumWith = f: l: foldl' add 0 (map f l);
2024-12-02 10:05:27 +01:00
deleteAt = l: i: (take i l) ++ (drop (i + 1) l);
2024-12-01 15:59:47 +01:00
eq = x: y: x == y;
2024-12-02 10:00:36 +01:00
greaterThan = x: y: x > y;
2024-12-04 13:12:45 +01:00
listRange = l: range 0 ((length l) - 1);
invert = f: x: !(f x);
2024-12-05 11:21:11 +01:00
elemAtMid = l: elemAt l ((length l) / 2);
removeAll = rl: (flip pipe) (map remove rl);
2024-12-05 17:32:08 +01:00
pipe' = flip pipe;
2024-12-07 00:34:32 +01:00
inRange = i: l: (i >= 0) && (i < length l);
transpose = l: map (i: map ((flip elemAt) i) l) (listRange (head l));
matVecMul = m: v: map (r: foldl' add 0 (zipListsWith mul v r)) m;
vecSum = zipListsWith add;
matIndex = i: pipe' (map (flip elemAt) i);
inRangeMatrix = i: m:
if i == [ ] then
true
else
(isList m) && (inRange (head i) m)
&& (inRangeMatrix (tail i) (elemAt m (head i)));
getMatrixIndices = m:
crossLists (x: y: [ x y ]) [
(listRange m)
(listRange (head m))
]; # fixme: only 2d, not arbitrary tensors.
2024-12-01 15:50:11 +01:00
}