Compare commits
	
		
			7 Commits
		
	
	
		
			a856b7f634
			...
			v0.1.0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 9a1fda087c | |||
| c5a0cf7ecc | |||
| 9a6973fb89 | |||
| d8094384ad | |||
| 86ca91920f | |||
| 64d6635d5f | |||
| 6a6ae96a96 | 
							
								
								
									
										63
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										63
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,3 +1,64 @@ | |||||||
| # circuiteria | # circuiteria | ||||||
|  |  | ||||||
| Drawing block circuits with Typst made easy, using CeTZ | Circuiteria is a [Typst](https://typst.app) package for drawing block circuit diagrams using the [CeTZ](https://typst.app/universe/package/cetz) package. | ||||||
|  |  | ||||||
|  | <p align="center"> | ||||||
|  |   <img src="./gallery/platypus.png" alt="Perry the platypus"> | ||||||
|  | </p> | ||||||
|  |  | ||||||
|  | ## Examples | ||||||
|  | <table> | ||||||
|  |   <tr> | ||||||
|  |     <td colspan="2"> | ||||||
|  |       <a href="./gallery/test.typ"> | ||||||
|  |         <img src="./gallery/test.png" width="500px"> | ||||||
|  |       </a> | ||||||
|  |     </td> | ||||||
|  |   </tr> | ||||||
|  |   <tr> | ||||||
|  |     <td colspan="2">A bit of eveything</td> | ||||||
|  |   </tr> | ||||||
|  |   <tr> | ||||||
|  |     <td colspan="2"> | ||||||
|  |       <a href="./gallery/test5.typ"> | ||||||
|  |         <img src="./gallery/test5.png" width="500px"> | ||||||
|  |       </a> | ||||||
|  |     </td> | ||||||
|  |   </tr> | ||||||
|  |   <tr> | ||||||
|  |     <td colspan="2">Wires everywhere</td> | ||||||
|  |   </tr> | ||||||
|  |   <tr> | ||||||
|  |     <td> | ||||||
|  |       <a href="./gallery/test4.typ"> | ||||||
|  |         <img src="./gallery/test4.png" width="250px"> | ||||||
|  |       </a> | ||||||
|  |     </td> | ||||||
|  |     <td> | ||||||
|  |       <a href="./gallery/test6.typ"> | ||||||
|  |         <img src="./gallery/test6.png" width="250px"> | ||||||
|  |       </a> | ||||||
|  |     </td> | ||||||
|  |   </tr> | ||||||
|  |   <tr> | ||||||
|  |     <td>Groups</td> | ||||||
|  |     <td>Rotated</td> | ||||||
|  |   </tr> | ||||||
|  | </table> | ||||||
|  |  | ||||||
|  | > **Note**\ | ||||||
|  | > These circuit layouts were copied from a digital design course given by prof. S. Zahno and recreated using this package | ||||||
|  |  | ||||||
|  | *Click on the example image to jump to the code.* | ||||||
|  |  | ||||||
|  | ## Usage | ||||||
|  | For more information, see the [manual](manual.pdf) | ||||||
|  |  | ||||||
|  | To use this package, simply import [circuiteria](https://typst.app/universe/package/circuiteria) and call the `circuit` function: | ||||||
|  | ```typ | ||||||
|  | #import "@preview/circuiteria:0.1.0" | ||||||
|  | #circuiteria.circuit({ | ||||||
|  |   import circuiteria: * | ||||||
|  |   ... | ||||||
|  | }) | ||||||
|  | ``` | ||||||
							
								
								
									
										
											BIN
										
									
								
								gallery/platypus.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gallery/platypus.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								gallery/platypus.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gallery/platypus.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 45 KiB | 
							
								
								
									
										77
									
								
								gallery/platypus.typ
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								gallery/platypus.typ
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | |||||||
|  | #import "../src/lib.typ": * | ||||||
|  |  | ||||||
|  | #set page(width: auto, height: auto, margin: .5cm) | ||||||
|  |  | ||||||
|  | #let teal = rgb(37, 155, 166) | ||||||
|  | #let orange = rgb(254, 160, 93) | ||||||
|  | #let brown = rgb(97, 54, 60) | ||||||
|  |  | ||||||
|  | #circuit({ | ||||||
|  |   element.group(id: "platypus", name: "A platypus", { | ||||||
|  |     element.block( | ||||||
|  |       x: 0, y: 0, w: 2, h: 3, id: "body", | ||||||
|  |       fill: teal, | ||||||
|  |       ports: ( | ||||||
|  |         east: ( | ||||||
|  |           (id: "out"), | ||||||
|  |         ) | ||||||
|  |       ), | ||||||
|  |       ports-margins: ( | ||||||
|  |         east: (50%, 10%) | ||||||
|  |       ) | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     element.block( | ||||||
|  |       x: 2.5, y: 1.5, w: 1.5, h: 1, id: "beak", | ||||||
|  |       fill: orange, | ||||||
|  |       ports: ( | ||||||
|  |         south: ( | ||||||
|  |           (id: "in"), | ||||||
|  |         ) | ||||||
|  |       ) | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     wire.wire("w1", ("body-port-out", "beak-port-in"), style: "zigzag", zigzag-ratio: 100%) | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   let O = (rel: (2, 0), to: "platypus.south-east") | ||||||
|  |    | ||||||
|  |   element.group(id: "perry", name: "Perry the platypus", { | ||||||
|  |     element.block( | ||||||
|  |       x: (rel: 0, to: O), y: 0, w: 2, h: 3, id: "body", | ||||||
|  |       fill: teal, | ||||||
|  |       ports: ( | ||||||
|  |         east: ( | ||||||
|  |           (id: "out"), | ||||||
|  |         ) | ||||||
|  |       ), | ||||||
|  |       ports-margins: ( | ||||||
|  |         east: (50%, 10%) | ||||||
|  |       ) | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     element.block( | ||||||
|  |       x: (rel: 2.5, to: O), y: 1.5, w: 1.5, h: 1, id: "beak", | ||||||
|  |       fill: orange, | ||||||
|  |       ports: ( | ||||||
|  |         south: ( | ||||||
|  |           (id: "in"), | ||||||
|  |         ) | ||||||
|  |       ) | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     element.block( | ||||||
|  |       x: (rel: 0.25, to: O), y: 3.2, w: 1.5, h: 0.5, id: "hat", | ||||||
|  |       fill: brown | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |     wire.wire("w2", ("body-port-out", "beak-port-in"), style: "zigzag", zigzag-ratio: 100%) | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   wire.wire( | ||||||
|  |     "w3", | ||||||
|  |     ("platypus.east", (horizontal: "perry.west", vertical: ())), | ||||||
|  |     directed: true, | ||||||
|  |     bus: true | ||||||
|  |   ) | ||||||
|  | }) | ||||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 66 KiB After Width: | Height: | Size: 66 KiB | 
										
											Binary file not shown.
										
									
								
							| @@ -18,7 +18,7 @@ | |||||||
|         name: "Datapath", |         name: "Datapath", | ||||||
|         ports: ( |         ports: ( | ||||||
|           north: ( |           north: ( | ||||||
|             (id: "clk", clock: true), |             (id: "clk", clock: true, small: true), | ||||||
|             (id: "Zero"), |             (id: "Zero"), | ||||||
|             (id: "Regsrc"), |             (id: "Regsrc"), | ||||||
|             (id: "PCSrc"), |             (id: "PCSrc"), | ||||||
| @@ -104,7 +104,7 @@ | |||||||
|       name: "Data\n Memory", |       name: "Data\n Memory", | ||||||
|       ports: ( |       ports: ( | ||||||
|         north: ( |         north: ( | ||||||
|           (id: "clk", clock: true), |           (id: "clk", clock: true, small: true), | ||||||
|           (id: "WE", name: "WE") |           (id: "WE", name: "WE") | ||||||
|         ), |         ), | ||||||
|         west: ( |         west: ( | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								gallery/test6.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gallery/test6.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								gallery/test6.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gallery/test6.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 76 KiB | 
							
								
								
									
										194
									
								
								gallery/test6.typ
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								gallery/test6.typ
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,194 @@ | |||||||
|  | #import "@preview/cetz:0.2.2": draw, vector | ||||||
|  | #import "../src/lib.typ": * | ||||||
|  |  | ||||||
|  | #set page(width: auto, height: auto, margin: .5cm) | ||||||
|  |  | ||||||
|  | #circuit({ | ||||||
|  |   element.multiplexer( | ||||||
|  |     x: 10, y: 0, w: 1, h: 6, id: "ResMux", | ||||||
|  |     entries: ("000", "001", "010", "011", "101"), | ||||||
|  |     h-ratio: 90%, | ||||||
|  |     fill: util.colors.blue | ||||||
|  |   ) | ||||||
|  |   element.extender( | ||||||
|  |     x: (rel: -3, to: "ResMux.west"), | ||||||
|  |     y: (from: "ResMux-port-in4", to: "out"), | ||||||
|  |     w: 2, h: 1, id: "Ext", | ||||||
|  |     name: "Zero Ext", | ||||||
|  |     name-anchor: "south", | ||||||
|  |     fill: util.colors.green | ||||||
|  |   ) | ||||||
|  |   gates.gate-or( | ||||||
|  |     x: (rel: -2, to: "ResMux.west"), | ||||||
|  |     y: (from: "ResMux-port-in3", to: "out"), | ||||||
|  |     w: 1, h: 1, id: "Or" | ||||||
|  |   ) | ||||||
|  |   gates.gate-and( | ||||||
|  |     x: (rel: -2, to: "ResMux.west"), | ||||||
|  |     y: (from: "ResMux-port-in2", to: "out"), | ||||||
|  |     w: 1, h: 1, id: "And" | ||||||
|  |   ) | ||||||
|  |   element.alu( | ||||||
|  |     x: (rel: -2.5, to: "Ext.west"), | ||||||
|  |     y: (from: "ResMux-port-in0", to: "out"), | ||||||
|  |     w: 1.5, h: 3, id: "Add", | ||||||
|  |     name: text("+", size: 1.5em), | ||||||
|  |     name-anchor: "name", | ||||||
|  |     fill: util.colors.pink | ||||||
|  |   ) | ||||||
|  |   element.multiplexer( | ||||||
|  |     x: (rel: -1.5, to: "Add.west"), | ||||||
|  |     y: (from: "Add-port-in1", to: "out"), | ||||||
|  |     w: 0.5, h: 1.5, id: "NotMux", | ||||||
|  |     h-ratio: 80%, | ||||||
|  |     fill: util.colors.blue | ||||||
|  |   ) | ||||||
|  |   gates.gate-not( | ||||||
|  |     x: (rel: -2, to: "NotMux.west"), | ||||||
|  |     y: (from: "NotMux-port-in1", to: "out"), | ||||||
|  |     w: 1, h: 1, id: "Not" | ||||||
|  |   ) | ||||||
|  |    | ||||||
|  |   draw.hide( | ||||||
|  |     draw.line(name: "l1", | ||||||
|  |       "Not-port-in0", | ||||||
|  |       (rel: (-2, 0), to: ()), | ||||||
|  |       (horizontal: (), vertical: "NotMux-port-in0") | ||||||
|  |     ) | ||||||
|  |   ) | ||||||
|  |   let b = "l1.end" | ||||||
|  |   draw.hide( | ||||||
|  |     draw.line(name: "l2", | ||||||
|  |       b, | ||||||
|  |       (horizontal: (), vertical: "Add-port-in2") | ||||||
|  |     ) | ||||||
|  |   ) | ||||||
|  |   let a = "l2.end" | ||||||
|  |  | ||||||
|  |   wire.wire("wB0", (b, "NotMux-port-in0"), bus: true) | ||||||
|  |   wire.wire( | ||||||
|  |     "wB1", (b, "Not-port-in0"), | ||||||
|  |     style: "zigzag", | ||||||
|  |     zigzag-ratio: 1.5, | ||||||
|  |     bus: true | ||||||
|  |   ) | ||||||
|  |   wire.wire( | ||||||
|  |     "wB2", (b, "And-port-in0"), | ||||||
|  |     style: "zigzag", | ||||||
|  |     zigzag-ratio: 1, | ||||||
|  |     bus: true | ||||||
|  |   ) | ||||||
|  |   wire.wire( | ||||||
|  |     "wB3", (b, "Or-port-in0"), | ||||||
|  |     style: "zigzag", | ||||||
|  |     zigzag-ratio: 1, | ||||||
|  |     bus: true | ||||||
|  |   ) | ||||||
|  |   wire.intersection("wB1.zig") | ||||||
|  |   wire.intersection("wB2.zig") | ||||||
|  |   wire.intersection("wB2.zag") | ||||||
|  |  | ||||||
|  |   wire.wire("wNot", ("Not-port-out", "NotMux-port-in1"), bus: true) | ||||||
|  |   wire.wire("wAddA", ("NotMux-port-out", "Add-port-in1"), bus: true) | ||||||
|  |  | ||||||
|  |   wire.wire("wA0", (a, "Add-port-in2"), bus: true) | ||||||
|  |   wire.wire( | ||||||
|  |     "wA1", (a, "And-port-in1"), | ||||||
|  |     style: "zigzag", | ||||||
|  |     zigzag-ratio: 0.5, | ||||||
|  |     bus: true | ||||||
|  |   ) | ||||||
|  |   wire.wire( | ||||||
|  |     "wA2", (a, "Or-port-in1"), | ||||||
|  |     style: "zigzag", | ||||||
|  |     zigzag-ratio: 0.5, | ||||||
|  |     bus: true | ||||||
|  |   ) | ||||||
|  |   wire.intersection("wA1.zig") | ||||||
|  |   wire.intersection("wA1.zag") | ||||||
|  |  | ||||||
|  |   wire.wire("wMux0", ("Add-port-out", "ResMux-port-in0"), bus: true) | ||||||
|  |   wire.wire( | ||||||
|  |     "wMux1", ("Add-port-out", "ResMux-port-in1"), | ||||||
|  |     style: "zigzag", | ||||||
|  |     zigzag-ratio: 2, | ||||||
|  |     bus: true | ||||||
|  |   ) | ||||||
|  |   wire.wire("wMux2", ("And-port-out", "ResMux-port-in2"), bus: true) | ||||||
|  |   wire.wire("wMux3", ("Or-port-out", "ResMux-port-in3"), bus: true) | ||||||
|  |   wire.wire("wMux4", ("Ext-port-out", "ResMux-port-in4"), bus: true) | ||||||
|  |  | ||||||
|  |   wire.wire( | ||||||
|  |     "wAdd", ("Add-port-out", "Ext-port-in"), | ||||||
|  |     style: "zigzag", | ||||||
|  |     zigzag-ratio: 0.5, | ||||||
|  |     bus: true | ||||||
|  |   ) | ||||||
|  |  | ||||||
|  |   wire.intersection("wMux1.zig") | ||||||
|  |   wire.intersection("wAdd.zig") | ||||||
|  |  | ||||||
|  |   let c = (rel: (0, 2), to: "ResMux.north") | ||||||
|  |   wire.wire("wResCtrl", (c, "ResMux.north"), bus: true) | ||||||
|  |   wire.wire( | ||||||
|  |     "wAddCtrl", (c, "Add.north"), | ||||||
|  |     style: "zigzag", | ||||||
|  |     zigzag-dir: "horizontal" | ||||||
|  |   ) | ||||||
|  |  | ||||||
|  |   let d = (rel: (1, 0), to: "ResMux-port-out") | ||||||
|  |   wire.wire("wRes", ("ResMux-port-out", d), bus: true) | ||||||
|  |  | ||||||
|  |   draw.content( | ||||||
|  |     "wAddCtrl.zag", | ||||||
|  |     [ALUControl#sub("[1]")], | ||||||
|  |     anchor: "south-west", | ||||||
|  |     padding: 3pt | ||||||
|  |   ) | ||||||
|  |    | ||||||
|  |   wire.wire( | ||||||
|  |     "wCout", ("Add.south", (horizontal: (), vertical: "Ext.north-east")) | ||||||
|  |   ) | ||||||
|  |   draw.content( | ||||||
|  |     "wCout.end", | ||||||
|  |     [C#sub("out")], | ||||||
|  |     angle: 90deg, | ||||||
|  |     anchor: "east", | ||||||
|  |     padding: 3pt | ||||||
|  |   ) | ||||||
|  |   draw.content( | ||||||
|  |     a, | ||||||
|  |     [A], | ||||||
|  |     angle: 90deg, | ||||||
|  |     anchor: "south", | ||||||
|  |     padding: 3pt | ||||||
|  |   ) | ||||||
|  |   draw.content( | ||||||
|  |     b, | ||||||
|  |     [B], | ||||||
|  |     angle: 90deg, | ||||||
|  |     anchor: "south", | ||||||
|  |     padding: 3pt | ||||||
|  |   ) | ||||||
|  |   draw.content( | ||||||
|  |     c, | ||||||
|  |     [ALUControl#sub("[2:0]")], | ||||||
|  |     angle: 90deg, | ||||||
|  |     anchor: "west", | ||||||
|  |     padding: 3pt | ||||||
|  |   ) | ||||||
|  |   draw.content( | ||||||
|  |     d, | ||||||
|  |     [Result], | ||||||
|  |     angle: 90deg, | ||||||
|  |     anchor: "north", | ||||||
|  |     padding: 3pt | ||||||
|  |   ) | ||||||
|  |   draw.content( | ||||||
|  |     ("wAdd.zig", 0.2, "wAdd.zag"), | ||||||
|  |     text("[N-1]", size: 0.8em), | ||||||
|  |     angle: 90deg, | ||||||
|  |     anchor: "north-east", | ||||||
|  |     padding: 3pt | ||||||
|  |   ) | ||||||
|  | }) | ||||||
							
								
								
									
										
											BIN
										
									
								
								manual.pdf
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								manual.pdf
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -52,13 +52,13 @@ | |||||||
|   h: none, |   h: none, | ||||||
|   name: none, |   name: none, | ||||||
|   name-anchor: "center", |   name-anchor: "center", | ||||||
|   ports: (), |   ports: (:), | ||||||
|   ports-margins: (), |   ports-margins: (:), | ||||||
|   fill: none, |   fill: none, | ||||||
|   stroke: black + 1pt, |   stroke: black + 1pt, | ||||||
|   id: "", |   id: "", | ||||||
|   auto-ports: true, |   auto-ports: true, | ||||||
|   ports-y: (), |   ports-y: (:), | ||||||
|   debug: ( |   debug: ( | ||||||
|     ports: false |     ports: false | ||||||
|   ) |   ) | ||||||
|   | |||||||
| @@ -5,8 +5,8 @@ | |||||||
|   let (x, y) = bl |   let (x, y) = bl | ||||||
|   let (width, height) = (tr.at(0) - x, tr.at(1) - y) |   let (width, height) = (tr.at(0) - x, tr.at(1) - y) | ||||||
|  |  | ||||||
|   let t = (x + width / 4, y + height) |   let t = (x + width / 2, y + height) | ||||||
|   let b = (x + width / 4, y) |   let b = (x + width / 2, y) | ||||||
|  |  | ||||||
|   let f = draw.group(name: id, { |   let f = draw.group(name: id, { | ||||||
|     draw.merge-path( |     draw.merge-path( | ||||||
| @@ -16,7 +16,7 @@ | |||||||
|       name: id + "-path", |       name: id + "-path", | ||||||
|       close: true, { |       close: true, { | ||||||
|         draw.line(bl, tl, t) |         draw.line(bl, tl, t) | ||||||
|         draw.bezier((), b, tr, br) |         draw.arc-through((), (tr , 50%, br), b) | ||||||
|         draw.line((), b) |         draw.line((), b) | ||||||
|       } |       } | ||||||
|     ) |     ) | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| #let version = version((0,0,3)) | #let version = version(0, 1, 0) | ||||||
|  |  | ||||||
| #import "circuit.typ": circuit | #import "circuit.typ": circuit | ||||||
| #import "element.typ" | #import "element.typ" | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| [package] | [package] | ||||||
| name = "circuiteria" | name = "circuiteria" | ||||||
| version = "0.0.3" | version = "0.1.0" | ||||||
| compiler = "0.11.0" | compiler = "0.11.0" | ||||||
| repository = "https://git.kb28.ch/HEL/circuiteria" | repository = "https://git.kb28.ch/HEL/circuiteria" | ||||||
| entrypoint = "src/lib.typ" | entrypoint = "src/lib.typ" | ||||||
| @@ -11,4 +11,4 @@ categories = [ "visualization" ] | |||||||
| license = "Apache-2.0" | license = "Apache-2.0" | ||||||
| description = "Drawing block circuits with Typst made easy, using CeTZ" | description = "Drawing block circuits with Typst made easy, using CeTZ" | ||||||
| keywords = [ "circuit", "block", "draw" ] | keywords = [ "circuit", "block", "draw" ] | ||||||
| exclude = [ "/gallery/*" ] | exclude = [ "gallery", "gallery.bash", "doc" ] | ||||||
		Reference in New Issue
	
	Block a user