Skip to content

Commit

Permalink
feat: add multiple logic gates
Browse files Browse the repository at this point in the history
- buf (buffer)
- not (invert)
- mux (multiplexer)
- dec (decoder)
- add (fulladder)
  • Loading branch information
Bnyro committed Feb 8, 2024
1 parent c6b4f4d commit 52cfc9a
Show file tree
Hide file tree
Showing 2 changed files with 170 additions and 2 deletions.
43 changes: 42 additions & 1 deletion components.typ
Original file line number Diff line number Diff line change
Expand Up @@ -178,6 +178,21 @@

/// Logic gates

// BUF gate
// type: node, fillable
#let buf-gate = {
parts.buf-gate-body
parts.logic-gate-legs-single
}

// NOT gate
// type: node, fillable
#let not-gate = {
parts.buf-gate-body
parts.not-circle
parts.logic-gate-legs-single
}

/// AND gate
/// type: node, fillable
#let and-gate = {
Expand Down Expand Up @@ -227,6 +242,27 @@
parts.xor-bar
}

/// MUX gate
/// type: node, fillable
#let mux-gate = {
parts.mux-gate-body
parts.logic-gate-legs-mux
}

/// DEC gate
/// type: node, fillable
#let dec-gate = {
parts.dec-gate-body
parts.logic-gate-legs-dec
}

/// ADD gate
/// type: node, fillable
#let add-gate = {
parts.add-gate-body
parts.logic-gate-legs-add
}

#let path = (
// Resistive bipoles
"short": short,
Expand All @@ -250,10 +286,15 @@
"op amp": op-amp,

// Logic gates
"buf gate": buf-gate,
"not gate": not-gate,
"and gate": and-gate,
"nand gate": nand-gate,
"or gate": or-gate,
"nor gate": nor-gate,
"xor gate": xor-gate,
"xnor gate": xnor-gate
"xnor gate": xnor-gate,
"mux gate": mux-gate,
"dec gate": dec-gate,
"add gate": add-gate
)
129 changes: 128 additions & 1 deletion parts.typ
Original file line number Diff line number Diff line change
@@ -1,5 +1,116 @@
#import "../typst-canvas/draw.typ": *
#import "utils.typ": anchors

#let add-gate-body = {
line(
(-0.5, 0.8),
(-0.5, 0.3),
(-0.2, 0),
(-0.5, -0.3),
(-0.5, -0.8),
(0.5, -0.6),
(0.5, 0.6),
(-0.5, 0.8)
)
line(
(0, 0),
(0.3, 0)
)
line(
(0.15, 0.15),
(0.15, -0.15)
)
anchors((
"bin 1": (-0.5, 0.55),
"in 1": (rel: (-0.5, 0)),
"bin 2": (-0.5, -0.55),
"in 2": (rel: (-0.5, 0)),
"bcin": (0, -0.7),
"cin": (rel: (0, -0.3)),
"bcout": (0, 0.7),
"cout": (rel: (0, 0.3)),
"bout": (0.5, 0),
"out": (rel: (0.5, 0)),
"north": (0, 1),
"south": (rel: (0, -1)),
"east": "out",
"west": ("in 1", "|-", "center"),
"left": ("bin 1", "|-", "center"),
"right": "bout"
))
}

#let mux-gate-body = {
line(
(-0.5, 0.8),
(-0.5, -0.8),
(0.5, -0.6),
(0.5, 0.6),
(-0.5, 0.8)
)
anchors((
"bin 1": (-0.5, 0.25),
"in 1": (rel: (-0.5, 0)),
"bin 2": (-0.5, -0.25),
"in 2": (rel: (-0.5, 0)),
"bsel": (0, 0.7),
"sel": (rel: (0, 0.3)),
"bout": (0.5, 0),
"out": (rel: (0.5, 0)),
"north": (0, 1),
"south": (rel: (0, -1)),
"east": "out",
"west": ("in 1", "|-", "center"),
"left": ("bin 1", "|-", "center"),
"right": "bout"
))
}

#let dec-gate-body = {
line(
(-0.5, 0.6),
(-0.5, -0.6),
(0.5, -0.8),
(0.5, 0.8),
(-0.5, 0.6)
)
anchors((
"bin": (-0.5, 0),
"in": (rel: (-0.5, 0)),
"bout 1": (0.5, 0.25),
"out 1": (rel: (0.5, 0)),
"bout 2": (0.5, -0.25),
"out 2": (rel: (0.5, 0)),
"north": (0, 0.5),
"south": (rel: (0, -1)),
"east": (0.5, 0),
"west": ("in", "|-", "center"),
"left": ("bin", "|-", "center"),
"right": (0.5, 0)
))
}

#let buf-gate-body = {
line(
(-0.5, 0.5),
(-0.5, -0.5),
(0.5, 0),
(-0.5, 0.5)
)
anchors((
"bin": (-0.5, 0),
"in": (rel: (-0.5, 0)),
"bout": (0.5, 0),
"out": (rel: (0.5, 0)),
"north": (0, 0.5),
"south": (rel: (0, -1)),
"east": "out",
"west": ("in", "|-", "center"),
"left": ("bin", "|-", "center"),
"right": "bout"
))
}

#let and-gate-body = {
merge-path(close: true, {
arc((0,0), -90deg, 90deg, radius: 0.5, name: "curve", anchor: "origin")
Expand Down Expand Up @@ -75,4 +186,20 @@

#let logic-gate-legs = for a in ("in 1", "in 2", "out") {
line("b" + a, a)
}
}

#let logic-gate-legs-single = for a in ("in", "out") {
line("b" + a, a)
}

#let logic-gate-legs-mux = for a in ("in 1", "in 2", "out", "sel") {
line("b" + a, a)
}

#let logic-gate-legs-dec = for a in ("in", "out 1", "out 2") {
line("b" + a, a)
}

#let logic-gate-legs-add = for a in ("in 1", "in 2", "cin", "out", "cout") {
line("b" + a, a)
}

0 comments on commit 52cfc9a

Please sign in to comment.