]> git.armaanb.net Git - atreides.git/blobdiff - atreus.rkt
deck things.
[atreides.git] / atreus.rkt
index 62ed11850f158f37e267ab83aa344138b0dd5602..3783c5ae333ab4f743f2497d0b61245b32b15814 100644 (file)
@@ -9,7 +9,7 @@
 (define spacing 19)
 (define angle 10)
 
-(define column-offsets '(8 5 0 6 11 59 59 11 6 0 5 8))
+(define column-offsets '(8 5 0 6 11 53 53 11 6 0 5 8))
 
 (define (switch-module x y rotation label net-pos net-neg)
   ;; TODO: set timestamps?
@@ -28,9 +28,9 @@
              (layer F.SilkS) (width 0.381))
     (pad 0 np_thru_hole circle (at 0 0) (size 3.9878 3.9878)
          (drill 3.9878)) ; switch hole, no copper
-    (pad 0 thru_hole circle (at -5.08 0) (size 1.7018 1.7018)
+    (pad 0 np_thru_hole circle (at -5.08 0) (size 1.7018 1.7018)
          (drill 1.7018)) ; board-mount hole, no copper
-    (pad 0 thru_hole circle (at 5.08 0) (size 1.7018 1.7018)
+    (pad 0 np_thru_hole circle (at 5.08 0) (size 1.7018 1.7018)
          (drill 1.7018)) ; board-mount hole, no copper
     (pad 1 thru_hole circle (at 2.54 -5.08) (size 2.286 2.286) (drill 1.4986)
          (layers *.Cu *.SilkS *.Mask) ,net-pos)
 
 (define microcontroller-module
   `(module A_STAR (layer Front) (tedit 4FDC31C8) (tstamp 543EF800)
-    (at 134 70 270)
+    (at 134 65 270)
     (path /543EEB02)
-    (fp_text value A-STAR (at -3 0 270) (layer F.SilkS)
-             (effects (font (size 3.048 2.54) (thickness 0.4572))))
-    (fp_line (start -15.24 -7.62) (end -15.24 7.62) (layer F.SilkS) (width 0.381))
-    (fp_line (start -15.24 7.62) (end 10.1 7.62) (layer F.SilkS) (width 0.381))
     (fp_line (start 10.1 7.62) (end 10.1 -7.62) (layer F.SilkS) (width 0.381))
     (fp_line (start 10.1 -7.62) (end -15.24 -7.62) (layer F.SilkS) (width 0.381))
 
     (pad B7 thru_hole circle (at -6.35 -6.35 270) (size 1.7526 1.7526)
          (drill 1.0922) (layers *.Cu *.SilkS *.Mask) (net 15 N-col-10))
     (pad D6 thru_hole circle (at -3.81 -6.35 270) (size 1.7526 1.7526)
-         (drill 1.0922) (layers *.Cu *.SilkS *.Mask) (net 14 N-col-9))))
+         (drill 1.0922) (layers *.Cu *.SilkS *.Mask) (net 14 N-col-9))
+    (pad RST thru_hole circle (at -1.27 -6.35 270) (size 1.7526 1.7526)
+       (drill 1.0922) (layers *.Cu *.SilkS *.Mask) (net 0 ""))
+    (pad GND thru_hole circle (at 6.35 -6.35 270) (size 1.7526 1.7526)
+         (drill 1.0922) (layers *.Cu *.SilkS *.Mask) (net 0 ""))))
 
 (define nets
   `((net 0 "")
          [diode-net `(net ,(+ 16 diode)
                       ,(string->symbol (format "N-diode-~s" diode)))]
          [column-net `(net ,(+ net-col 5)
-                       ,(string->symbol (format "N-col-~s" net-col)))]
-         ;; rotate middle keys additional 90° after calculating position
-         [rotation (cond [(= 5 col) 80]
-                         [(= 6 col) 280]
-                         [true rotation])])
+                       ,(string->symbol (format "N-col-~s" net-col)))])
     (switch-module x′ y′ rotation label
                    (if left? diode-net column-net)
                    (if left? column-net diode-net))))
   (for/list ([col (in-range cols)]
              #:when true
              [row (if (or (= 5 col) (= 6 col))
-                      '(0) (in-range rows))])
+                      '(0 1) (in-range rows))])
     (list (switch row col) (diode row col))))
 
 (define edge-cuts
-  (for/list [(s '([31 22] [84 22] [128 30] [128 54] [140 54] [140 30] [185 22]
+  (for/list [(s '([31 22] [84 22] [127 30]
+                          [129 49] [129 75] [139 75]
+                  [139 49] [141 30] [185 22]
                   [237 22] [250 95] [161 112] [107 112] [18 95]))
-             (e '([84 22] [128 30] [128 54] [140 54] [140 30] [185 22]
+             (e '([84 22] [127 30]
+                          [129 49] [129 75] [139 75] [139 49]
+                  [141 30] [185 22]
                   [237 22] [250 95] [161 112] [107 112] [18 95] [31 22]))]
     `(gr_line (start ,@s) (end ,@e) (angle 90) (layer Edge.Cuts) (width 0.3))))
 
                  (curry read-string 999999)) op)
       (display ")" op))))
 
-(write-placement "/tmp/atreus.kicad_pcb")
+;; TODOs:
+
+;; controller traces
+;; middle switch traces
+;; middle switch diodes below
+
+(write-placement "atreus.kicad_pcb")