aboutsummaryrefslogtreecommitdiff
path: root/aoc-2022-dotnet/Common/Vec2.fs
diff options
context:
space:
mode:
Diffstat (limited to 'aoc-2022-dotnet/Common/Vec2.fs')
-rw-r--r--aoc-2022-dotnet/Common/Vec2.fs17
1 files changed, 17 insertions, 0 deletions
diff --git a/aoc-2022-dotnet/Common/Vec2.fs b/aoc-2022-dotnet/Common/Vec2.fs
index 11c94aa..8835a5a 100644
--- a/aoc-2022-dotnet/Common/Vec2.fs
+++ b/aoc-2022-dotnet/Common/Vec2.fs
@@ -1,14 +1,21 @@
namespace Common
+[<StructuralEquality; StructuralComparison>]
type Vec2 =
| Vec2 of int * int
+ static member x(Vec2 (x, _)) = x
+ static member y(Vec2 (_, y)) = y
+
static member zero = Vec2(0, 0)
static member up = Vec2(0, 1)
static member right = Vec2(1, 0)
static member down = Vec2(0, -1)
static member left = Vec2(-1, 0)
+ static member downLeft = Vec2(-1, -1)
+ static member downRight = Vec2(1, -1)
+
static member directions4 =
[ Vec2.up
Vec2.right
@@ -28,6 +35,16 @@ type Vec2 =
static member chebyshevDist (Vec2 (x1, y1)) (Vec2 (x2, y2)) = max (abs <| x2 - x1) (abs <| y2 - y1)
static member neighbours4 v = List.map ((+) v) Vec2.directions4
+ static member lineBetween(Vec2 (x1, y1), Vec2 (x2, y2)) =
+ if x1 = x2 then
+ seq { min y1 y2 .. max y1 y2 }
+ |> Seq.map (fun y -> Vec2(x1, y))
+ elif y1 = y2 then
+ seq { min x1 x2 .. max x1 x2 }
+ |> Seq.map (fun x -> Vec2(x, y1))
+ else
+ failwith "Points must be in a vertical or horizontal line!"
+
static member inMatrix matrix (Vec2 (col, row)) =
col >= 0
&& col < Array2D.length2 matrix