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 | ||||
|  | ||||
| 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", | ||||
|         ports: ( | ||||
|           north: ( | ||||
|             (id: "clk", clock: true), | ||||
|             (id: "clk", clock: true, small: true), | ||||
|             (id: "Zero"), | ||||
|             (id: "Regsrc"), | ||||
|             (id: "PCSrc"), | ||||
| @@ -104,7 +104,7 @@ | ||||
|       name: "Data\n Memory", | ||||
|       ports: ( | ||||
|         north: ( | ||||
|           (id: "clk", clock: true), | ||||
|           (id: "clk", clock: true, small: true), | ||||
|           (id: "WE", name: "WE") | ||||
|         ), | ||||
|         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, | ||||
|   name: none, | ||||
|   name-anchor: "center", | ||||
|   ports: (), | ||||
|   ports-margins: (), | ||||
|   ports: (:), | ||||
|   ports-margins: (:), | ||||
|   fill: none, | ||||
|   stroke: black + 1pt, | ||||
|   id: "", | ||||
|   auto-ports: true, | ||||
|   ports-y: (), | ||||
|   ports-y: (:), | ||||
|   debug: ( | ||||
|     ports: false | ||||
|   ) | ||||
|   | ||||
| @@ -5,8 +5,8 @@ | ||||
|   let (x, y) = bl | ||||
|   let (width, height) = (tr.at(0) - x, tr.at(1) - y) | ||||
|  | ||||
|   let t = (x + width / 4, y + height) | ||||
|   let b = (x + width / 4, y) | ||||
|   let t = (x + width / 2, y + height) | ||||
|   let b = (x + width / 2, y) | ||||
|  | ||||
|   let f = draw.group(name: id, { | ||||
|     draw.merge-path( | ||||
| @@ -16,7 +16,7 @@ | ||||
|       name: id + "-path", | ||||
|       close: true, { | ||||
|         draw.line(bl, tl, t) | ||||
|         draw.bezier((), b, tr, br) | ||||
|         draw.arc-through((), (tr , 50%, br), 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 "element.typ" | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| [package] | ||||
| name = "circuiteria" | ||||
| version = "0.0.3" | ||||
| version = "0.1.0" | ||||
| compiler = "0.11.0" | ||||
| repository = "https://git.kb28.ch/HEL/circuiteria" | ||||
| entrypoint = "src/lib.typ" | ||||
| @@ -11,4 +11,4 @@ categories = [ "visualization" ] | ||||
| license = "Apache-2.0" | ||||
| description = "Drawing block circuits with Typst made easy, using CeTZ" | ||||
| keywords = [ "circuit", "block", "draw" ] | ||||
| exclude = [ "/gallery/*" ] | ||||
| exclude = [ "gallery", "gallery.bash", "doc" ] | ||||
		Reference in New Issue
	
	Block a user