about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--80.pgm58
-rw-r--r--img.mu82
2 files changed, 106 insertions, 34 deletions
diff --git a/80.pgm b/80.pgm
index 4495f46f..55e80e1d 100644
--- a/80.pgm
+++ b/80.pgm
@@ -1,7 +1,55 @@
 P2
-4 4
+16 16
 255
-128 128 128 128
-128 128 128 128
-128 128 128 128
-128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
+128 128 128 128 128 128 128 128 128 128 128 128 128 128 128 128
diff --git a/img.mu b/img.mu
index b3c061af..fa98fd6d 100644
--- a/img.mu
+++ b/img.mu
@@ -442,7 +442,17 @@ fn _unordered-monochrome-dither src: (addr array byte), width: int, height: int,
   }
 }
 
-fn show-errors buf: (addr array int), width: int, height: int {
+fn show-errors buf: (addr array int), width: int, height: int, x: int, y: int {
+  compare y, 1
+  {
+    break-if-=
+    return
+  }
+  compare x, 0
+  {
+    break-if-=
+    return
+  }
   var y/edx: int <- copy 0
   {
     compare y, height
@@ -487,66 +497,80 @@ fn _diffuse-monochrome-dithering-errors buf: (addr array int), x: int, y: int, w
     break-if-!=
     return
   }
-  decrement width
-  decrement height
+  var width-1/esi: int <- copy width
+  width-1 <- decrement
+  var height-1/edi: int <- copy height
+  height-1 <- decrement
   # delta = error/16
-#?   show-errors buf, width, height
-#?   draw-int32-decimal-wrapping-right-then-down-from-cursor-over-full-screen 0/screen, error, 3/fg 0/bg
-#?   move-cursor-to-left-margin-of-next-line 0/screen
+  show-errors buf, width, height, x, y
+  {
+    compare y, 1
+    break-if-!=
+    compare x, 0
+    break-if-!=
+    draw-int32-decimal-wrapping-right-then-down-from-cursor-over-full-screen 0/screen, error, 3/fg 0/bg
+    move-cursor-to-left-margin-of-next-line 0/screen
+  }
   var delta/ecx: int <- copy error
   delta <- shift-right-signed 4
-#?   draw-int32-decimal-wrapping-right-then-down-from-cursor-over-full-screen 0/screen, delta, 2/fg 0/bg
-#?   move-cursor-to-left-margin-of-next-line 0/screen
+  {
+    compare y, 1
+    break-if-!=
+    compare x, 0
+    break-if-!=
+    draw-int32-decimal-wrapping-right-then-down-from-cursor-over-full-screen 0/screen, delta, 2/fg 0/bg
+    move-cursor-to-left-margin-of-next-line 0/screen
+  }
   # In Floyd-Steinberg, each pixel X transmits its errors to surrounding
   # pixels in the following proportion:
   #           X     7/16
   #     3/16  5/16  1/16
-  var x/esi: int <- copy x
+  var x/edx: int <- copy x
   {
-    compare x, width
+    compare x, width-1
     break-if->=
-    var tmp/eax: int <- copy delta
-    var seven/edx: int <- copy 7
-    tmp <- multiply seven
+    var tmp/eax: int <- copy 7
+    tmp <- multiply delta
     var xright/edx: int <- copy x
     xright <- increment
     _accumulate-error buf, xright, y, width, tmp
   }
-#?   show-errors buf, width, height
-  var y/edi: int <- copy y
+#?   show-errors buf, width, height, x, y
+  var y/ebx: int <- copy y
   {
-    compare y, height
+    compare y, height-1
     break-if-<
     return
   }
-  var ybelow/edi: int <- copy y
-  ybelow <- increment
+  var ybelow: int
+  copy-to ybelow, y
+  increment ybelow
+#?   var ybelow/edi: int <- copy y
+#?   ybelow <- increment
   {
     compare x, 0
     break-if-<=
-    var tmp/eax: int <- copy delta
-    var three/edx: int <- copy 3
-    tmp <- multiply three
-    var xleft/ebx: int <- copy x
+    var tmp/eax: int <- copy 3
+    tmp <- multiply delta
+    var xleft/edx: int <- copy x
     xleft <- decrement
     _accumulate-error buf, xleft, ybelow, width, tmp
   }
-#?   show-errors buf, width, height
+#?   show-errors buf, width, height, x, y
   {
-    var tmp/eax: int <- copy delta
-    var five/edx: int <- copy 5
-    tmp <- multiply five
+    var tmp/eax: int <- copy 5
+    tmp <- multiply delta
     _accumulate-error buf, x, ybelow, width, tmp
   }
-#?   show-errors buf, width, height
+#?   show-errors buf, width, height, x, y
   {
-    compare x, width
+    compare x, width-1
     break-if->=
     var xright/edx: int <- copy x
     xright <- increment
     _accumulate-error buf, xright, ybelow, width, delta
   }
-#?   show-errors buf, width, height
+  show-errors buf, width, height, x, y
 }
 
 fn _accumulate-error buf: (addr array int), x: int, y: int, width: int, error: int {