@skillpet/circuit 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +131 -0
- package/dist/circuit.bundle.js +31103 -0
- package/dist/circuit.bundle.js.map +7 -0
- package/dist/circuit.bundle.min.js +273 -0
- package/dist/circuit.bundle.min.js.map +7 -0
- package/dist/circuit.esm.js +31069 -0
- package/dist/circuit.esm.js.map +7 -0
- package/dist/config.d.ts +26 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +23 -0
- package/dist/config.js.map +1 -0
- package/dist/container.d.ts +32 -0
- package/dist/container.d.ts.map +1 -0
- package/dist/container.js +101 -0
- package/dist/container.js.map +1 -0
- package/dist/drawing-gradient.d.ts +13 -0
- package/dist/drawing-gradient.d.ts.map +1 -0
- package/dist/drawing-gradient.js +39 -0
- package/dist/drawing-gradient.js.map +1 -0
- package/dist/drawing-stack.d.ts +16 -0
- package/dist/drawing-stack.d.ts.map +1 -0
- package/dist/drawing-stack.js +32 -0
- package/dist/drawing-stack.js.map +1 -0
- package/dist/drawing-transition.d.ts +34 -0
- package/dist/drawing-transition.d.ts.map +1 -0
- package/dist/drawing-transition.js +181 -0
- package/dist/drawing-transition.js.map +1 -0
- package/dist/drawing.d.ts +117 -0
- package/dist/drawing.d.ts.map +1 -0
- package/dist/drawing.js +337 -0
- package/dist/drawing.js.map +1 -0
- package/dist/element-label.d.ts +54 -0
- package/dist/element-label.d.ts.map +1 -0
- package/dist/element-label.js +377 -0
- package/dist/element-label.js.map +1 -0
- package/dist/element-style.d.ts +34 -0
- package/dist/element-style.d.ts.map +1 -0
- package/dist/element-style.js +51 -0
- package/dist/element-style.js.map +1 -0
- package/dist/element.d.ts +114 -0
- package/dist/element.d.ts.map +1 -0
- package/dist/element.js +514 -0
- package/dist/element.js.map +1 -0
- package/dist/element2term.d.ts +25 -0
- package/dist/element2term.d.ts.map +1 -0
- package/dist/element2term.js +245 -0
- package/dist/element2term.js.map +1 -0
- package/dist/elements/cables.d.ts +22 -0
- package/dist/elements/cables.d.ts.map +1 -0
- package/dist/elements/cables.js +100 -0
- package/dist/elements/cables.js.map +1 -0
- package/dist/elements/capacitor.d.ts +23 -0
- package/dist/elements/capacitor.d.ts.map +1 -0
- package/dist/elements/capacitor.js +93 -0
- package/dist/elements/capacitor.js.map +1 -0
- package/dist/elements/compound.d.ts +41 -0
- package/dist/elements/compound.d.ts.map +1 -0
- package/dist/elements/compound.js +266 -0
- package/dist/elements/compound.js.map +1 -0
- package/dist/elements/connectors.d.ts +81 -0
- package/dist/elements/connectors.d.ts.map +1 -0
- package/dist/elements/connectors.js +578 -0
- package/dist/elements/connectors.js.map +1 -0
- package/dist/elements/crystal.d.ts +8 -0
- package/dist/elements/crystal.d.ts.map +1 -0
- package/dist/elements/crystal.js +31 -0
- package/dist/elements/crystal.js.map +1 -0
- package/dist/elements/diode-more.d.ts +36 -0
- package/dist/elements/diode-more.d.ts.map +1 -0
- package/dist/elements/diode-more.js +233 -0
- package/dist/elements/diode-more.js.map +1 -0
- package/dist/elements/diode.d.ts +14 -0
- package/dist/elements/diode.d.ts.map +1 -0
- package/dist/elements/diode.js +58 -0
- package/dist/elements/diode.js.map +1 -0
- package/dist/elements/element-compound.d.ts +16 -0
- package/dist/elements/element-compound.d.ts.map +1 -0
- package/dist/elements/element-compound.js +68 -0
- package/dist/elements/element-compound.js.map +1 -0
- package/dist/elements/element-drawing.d.ts +10 -0
- package/dist/elements/element-drawing.d.ts.map +1 -0
- package/dist/elements/element-drawing.js +16 -0
- package/dist/elements/element-drawing.js.map +1 -0
- package/dist/elements/ground.d.ts +6 -0
- package/dist/elements/ground.d.ts.map +1 -0
- package/dist/elements/ground.js +30 -0
- package/dist/elements/ground.js.map +1 -0
- package/dist/elements/ic.d.ts +169 -0
- package/dist/elements/ic.d.ts.map +1 -0
- package/dist/elements/ic.js +816 -0
- package/dist/elements/ic.js.map +1 -0
- package/dist/elements/image.d.ts +9 -0
- package/dist/elements/image.d.ts.map +1 -0
- package/dist/elements/image.js +27 -0
- package/dist/elements/image.js.map +1 -0
- package/dist/elements/inductor.d.ts +15 -0
- package/dist/elements/inductor.d.ts.map +1 -0
- package/dist/elements/inductor.js +111 -0
- package/dist/elements/inductor.js.map +1 -0
- package/dist/elements/line.d.ts +8 -0
- package/dist/elements/line.d.ts.map +1 -0
- package/dist/elements/line.js +14 -0
- package/dist/elements/line.js.map +1 -0
- package/dist/elements/lines-arc-labels.d.ts +223 -0
- package/dist/elements/lines-arc-labels.d.ts.map +1 -0
- package/dist/elements/lines-arc-labels.js +822 -0
- package/dist/elements/lines-arc-labels.js.map +1 -0
- package/dist/elements/lines-elements.d.ts +89 -0
- package/dist/elements/lines-elements.d.ts.map +1 -0
- package/dist/elements/lines-elements.js +271 -0
- package/dist/elements/lines-elements.js.map +1 -0
- package/dist/elements/misc-elements.d.ts +25 -0
- package/dist/elements/misc-elements.d.ts.map +1 -0
- package/dist/elements/misc-elements.js +160 -0
- package/dist/elements/misc-elements.js.map +1 -0
- package/dist/elements/oneterm.d.ts +29 -0
- package/dist/elements/oneterm.d.ts.map +1 -0
- package/dist/elements/oneterm.js +163 -0
- package/dist/elements/oneterm.js.map +1 -0
- package/dist/elements/opamp.d.ts +11 -0
- package/dist/elements/opamp.d.ts.map +1 -0
- package/dist/elements/opamp.js +72 -0
- package/dist/elements/opamp.js.map +1 -0
- package/dist/elements/outlets.d.ts +39 -0
- package/dist/elements/outlets.d.ts.map +1 -0
- package/dist/elements/outlets.js +285 -0
- package/dist/elements/outlets.js.map +1 -0
- package/dist/elements/resistor-more.d.ts +42 -0
- package/dist/elements/resistor-more.d.ts.map +1 -0
- package/dist/elements/resistor-more.js +171 -0
- package/dist/elements/resistor-more.js.map +1 -0
- package/dist/elements/resistor.d.ts +6 -0
- package/dist/elements/resistor.d.ts.map +1 -0
- package/dist/elements/resistor.js +22 -0
- package/dist/elements/resistor.js.map +1 -0
- package/dist/elements/source-v.d.ts +3 -0
- package/dist/elements/source-v.d.ts.map +1 -0
- package/dist/elements/source-v.js +3 -0
- package/dist/elements/source-v.js.map +1 -0
- package/dist/elements/sources.d.ts +111 -0
- package/dist/elements/sources.d.ts.map +1 -0
- package/dist/elements/sources.js +519 -0
- package/dist/elements/sources.js.map +1 -0
- package/dist/elements/switches.d.ts +66 -0
- package/dist/elements/switches.d.ts.map +1 -0
- package/dist/elements/switches.js +328 -0
- package/dist/elements/switches.js.map +1 -0
- package/dist/elements/transformer.d.ts +17 -0
- package/dist/elements/transformer.d.ts.map +1 -0
- package/dist/elements/transformer.js +184 -0
- package/dist/elements/transformer.js.map +1 -0
- package/dist/elements/transistors.d.ts +197 -0
- package/dist/elements/transistors.d.ts.map +1 -0
- package/dist/elements/transistors.js +1009 -0
- package/dist/elements/transistors.js.map +1 -0
- package/dist/elements/tubes.d.ts +70 -0
- package/dist/elements/tubes.d.ts.map +1 -0
- package/dist/elements/tubes.js +386 -0
- package/dist/elements/tubes.js.map +1 -0
- package/dist/elements/twoports.d.ts +47 -0
- package/dist/elements/twoports.d.ts.map +1 -0
- package/dist/elements/twoports.js +231 -0
- package/dist/elements/twoports.js.map +1 -0
- package/dist/elements/twoterm-extras.d.ts +50 -0
- package/dist/elements/twoterm-extras.d.ts.map +1 -0
- package/dist/elements/twoterm-extras.js +243 -0
- package/dist/elements/twoterm-extras.js.map +1 -0
- package/dist/elements/twoterm.d.ts +4 -0
- package/dist/elements/twoterm.d.ts.map +1 -0
- package/dist/elements/twoterm.js +4 -0
- package/dist/elements/twoterm.js.map +1 -0
- package/dist/geometry/point.d.ts +28 -0
- package/dist/geometry/point.d.ts.map +1 -0
- package/dist/geometry/point.js +99 -0
- package/dist/geometry/point.js.map +1 -0
- package/dist/geometry/roundcorners.d.ts +7 -0
- package/dist/geometry/roundcorners.d.ts.map +1 -0
- package/dist/geometry/roundcorners.js +64 -0
- package/dist/geometry/roundcorners.js.map +1 -0
- package/dist/geometry/transform.d.ts +14 -0
- package/dist/geometry/transform.d.ts.map +1 -0
- package/dist/geometry/transform.js +33 -0
- package/dist/geometry/transform.js.map +1 -0
- package/dist/geometry/util.d.ts +12 -0
- package/dist/geometry/util.d.ts.map +1 -0
- package/dist/geometry/util.js +36 -0
- package/dist/geometry/util.js.map +1 -0
- package/dist/index.cjs +31456 -0
- package/dist/index.cjs.map +7 -0
- package/dist/index.d.ts +77 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +68 -0
- package/dist/index.js.map +1 -0
- package/dist/json/anchor-ref.d.ts +5 -0
- package/dist/json/anchor-ref.d.ts.map +1 -0
- package/dist/json/anchor-ref.js +35 -0
- package/dist/json/anchor-ref.js.map +1 -0
- package/dist/json/mount.d.ts +60 -0
- package/dist/json/mount.d.ts.map +1 -0
- package/dist/json/mount.js +369 -0
- package/dist/json/mount.js.map +1 -0
- package/dist/json/registry.d.ts +7 -0
- package/dist/json/registry.d.ts.map +1 -0
- package/dist/json/registry.js +323 -0
- package/dist/json/registry.js.map +1 -0
- package/dist/json/render.d.ts +59 -0
- package/dist/json/render.d.ts.map +1 -0
- package/dist/json/render.js +113 -0
- package/dist/json/render.js.map +1 -0
- package/dist/json/theme.d.ts +18 -0
- package/dist/json/theme.d.ts.map +1 -0
- package/dist/json/theme.js +57 -0
- package/dist/json/theme.js.map +1 -0
- package/dist/json/types.d.ts +42 -0
- package/dist/json/types.d.ts.map +1 -0
- package/dist/json/types.js +2 -0
- package/dist/json/types.js.map +1 -0
- package/dist/json/validate.d.ts +11 -0
- package/dist/json/validate.d.ts.map +1 -0
- package/dist/json/validate.js +77 -0
- package/dist/json/validate.js.map +1 -0
- package/dist/label-hint.d.ts +11 -0
- package/dist/label-hint.d.ts.map +1 -0
- package/dist/label-hint.js +2 -0
- package/dist/label-hint.js.map +1 -0
- package/dist/logic/and.d.ts +13 -0
- package/dist/logic/and.d.ts.map +1 -0
- package/dist/logic/and.js +63 -0
- package/dist/logic/and.js.map +1 -0
- package/dist/logic/bitfield.d.ts +32 -0
- package/dist/logic/bitfield.d.ts.map +1 -0
- package/dist/logic/bitfield.js +271 -0
- package/dist/logic/bitfield.js.map +1 -0
- package/dist/logic/buffer.d.ts +11 -0
- package/dist/logic/buffer.d.ts.map +1 -0
- package/dist/logic/buffer.js +46 -0
- package/dist/logic/buffer.js.map +1 -0
- package/dist/logic/extras.d.ts +36 -0
- package/dist/logic/extras.d.ts.map +1 -0
- package/dist/logic/extras.js +211 -0
- package/dist/logic/extras.js.map +1 -0
- package/dist/logic/kmap.d.ts +16 -0
- package/dist/logic/kmap.d.ts.map +1 -0
- package/dist/logic/kmap.js +163 -0
- package/dist/logic/kmap.js.map +1 -0
- package/dist/logic/or.d.ts +18 -0
- package/dist/logic/or.d.ts.map +1 -0
- package/dist/logic/or.js +117 -0
- package/dist/logic/or.js.map +1 -0
- package/dist/logic/timing.d.ts +44 -0
- package/dist/logic/timing.d.ts.map +1 -0
- package/dist/logic/timing.js +791 -0
- package/dist/logic/timing.js.map +1 -0
- package/dist/logic/tristate.d.ts +11 -0
- package/dist/logic/tristate.d.ts.map +1 -0
- package/dist/logic/tristate.js +48 -0
- package/dist/logic/tristate.js.map +1 -0
- package/dist/math-render.d.ts +9 -0
- package/dist/math-render.d.ts.map +1 -0
- package/dist/math-render.js +53 -0
- package/dist/math-render.js.map +1 -0
- package/dist/package-api.d.ts +20 -0
- package/dist/package-api.d.ts.map +1 -0
- package/dist/package-api.js +75 -0
- package/dist/package-api.js.map +1 -0
- package/dist/params.d.ts +6 -0
- package/dist/params.d.ts.map +1 -0
- package/dist/params.js +35 -0
- package/dist/params.js.map +1 -0
- package/dist/react/index.d.ts +22 -0
- package/dist/react/index.d.ts.map +1 -0
- package/dist/react/index.js +52 -0
- package/dist/react/index.js.map +1 -0
- package/dist/schemdraw-ts.bundle.js +30448 -0
- package/dist/schemdraw-ts.bundle.js.map +7 -0
- package/dist/segment.d.ts +267 -0
- package/dist/segment.d.ts.map +1 -0
- package/dist/segment.js +844 -0
- package/dist/segment.js.map +1 -0
- package/dist/style.d.ts +18 -0
- package/dist/style.d.ts.map +1 -0
- package/dist/style.js +230 -0
- package/dist/style.js.map +1 -0
- package/dist/subsystems/dsp.d.ts +65 -0
- package/dist/subsystems/dsp.d.ts.map +1 -0
- package/dist/subsystems/dsp.js +267 -0
- package/dist/subsystems/dsp.js.map +1 -0
- package/dist/subsystems/flow.d.ts +92 -0
- package/dist/subsystems/flow.d.ts.map +1 -0
- package/dist/subsystems/flow.js +315 -0
- package/dist/subsystems/flow.js.map +1 -0
- package/dist/subsystems/index.d.ts +22 -0
- package/dist/subsystems/index.d.ts.map +1 -0
- package/dist/subsystems/index.js +22 -0
- package/dist/subsystems/index.js.map +1 -0
- package/dist/subsystems/parsing.d.ts +41 -0
- package/dist/subsystems/parsing.d.ts.map +1 -0
- package/dist/subsystems/parsing.js +456 -0
- package/dist/subsystems/parsing.js.map +1 -0
- package/dist/subsystems/pictorial.d.ts +73 -0
- package/dist/subsystems/pictorial.d.ts.map +1 -0
- package/dist/subsystems/pictorial.js +469 -0
- package/dist/subsystems/pictorial.js.map +1 -0
- package/dist/svg/constants.d.ts +5 -0
- package/dist/svg/constants.d.ts.map +1 -0
- package/dist/svg/constants.js +5 -0
- package/dist/svg/constants.js.map +1 -0
- package/dist/svg/figure.d.ts +157 -0
- package/dist/svg/figure.d.ts.map +1 -0
- package/dist/svg/figure.js +634 -0
- package/dist/svg/figure.js.map +1 -0
- package/dist/svg/fmt.d.ts +2 -0
- package/dist/svg/fmt.d.ts.map +1 -0
- package/dist/svg/fmt.js +7 -0
- package/dist/svg/fmt.js.map +1 -0
- package/dist/svg/svg-style.d.ts +15 -0
- package/dist/svg/svg-style.d.ts.map +1 -0
- package/dist/svg/svg-style.js +46 -0
- package/dist/svg/svg-style.js.map +1 -0
- package/dist/types.d.ts +39 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +21 -0
- package/dist/types.js.map +1 -0
- package/dist/version.d.ts +3 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +3 -0
- package/dist/version.js.map +1 -0
- package/dist/vue/index.d.ts +43 -0
- package/dist/vue/index.d.ts.map +1 -0
- package/dist/vue/index.js +55 -0
- package/dist/vue/index.js.map +1 -0
- package/package.json +71 -0
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Buffer / inverter — aligned with Python `logic/logic.py` · `Buf`, `Not`.
|
|
3
|
+
*/
|
|
4
|
+
import { Element2Term } from "../element2term.js";
|
|
5
|
+
import { GAP, Segment, SegmentCircle } from "../segment.js";
|
|
6
|
+
const gateh = 1;
|
|
7
|
+
const gatel = 0.65;
|
|
8
|
+
const notbubble = 0.12;
|
|
9
|
+
export class Buf extends Element2Term {
|
|
10
|
+
constructor(userParams = {}) {
|
|
11
|
+
super(userParams);
|
|
12
|
+
this.segments.push(new Segment([
|
|
13
|
+
[0, 0],
|
|
14
|
+
GAP,
|
|
15
|
+
[gatel, 0],
|
|
16
|
+
]));
|
|
17
|
+
this.segments.push(new Segment([
|
|
18
|
+
[0, gateh / 2],
|
|
19
|
+
[gatel, 0],
|
|
20
|
+
[0, -gateh / 2],
|
|
21
|
+
[0, gateh / 2],
|
|
22
|
+
]));
|
|
23
|
+
this.anchors.out = [gatel, 0];
|
|
24
|
+
this.anchors.in1 = [0, 0];
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
export class Not extends Element2Term {
|
|
28
|
+
constructor(userParams = {}) {
|
|
29
|
+
super(userParams);
|
|
30
|
+
this.segments.push(new Segment([
|
|
31
|
+
[0, 0],
|
|
32
|
+
GAP,
|
|
33
|
+
[gatel + notbubble * 2, 0],
|
|
34
|
+
]));
|
|
35
|
+
this.segments.push(new Segment([
|
|
36
|
+
[0, gateh / 2],
|
|
37
|
+
[gatel, 0],
|
|
38
|
+
[0, -gateh / 2],
|
|
39
|
+
[0, gateh / 2],
|
|
40
|
+
]));
|
|
41
|
+
this.segments.push(new SegmentCircle([gatel + notbubble, 0], notbubble));
|
|
42
|
+
this.anchors.out = [gatel + notbubble * 2, 0];
|
|
43
|
+
this.anchors.in1 = [0, 0];
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=buffer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buffer.js","sourceRoot":"","sources":["../../src/logic/buffer.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAE5D,MAAM,KAAK,GAAG,CAAC,CAAC;AAChB,MAAM,KAAK,GAAG,IAAI,CAAC;AACnB,MAAM,SAAS,GAAG,IAAI,CAAC;AAEvB,MAAM,OAAO,GAAI,SAAQ,YAAY;IACnC,YAAY,aAAsC,EAAE;QAClD,KAAK,CAAC,UAAU,CAAC,CAAC;QAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,IAAI,OAAO,CAAC;YACV,CAAC,CAAC,EAAE,CAAC,CAAC;YACN,GAAG;YACH,CAAC,KAAK,EAAE,CAAC,CAAC;SACX,CAAC,CACH,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,IAAI,OAAO,CAAC;YACV,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC;YACd,CAAC,KAAK,EAAE,CAAC,CAAC;YACV,CAAC,CAAC,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC;SACf,CAAC,CACH,CAAC;QACF,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAC9B,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,CAAC;CACF;AAED,MAAM,OAAO,GAAI,SAAQ,YAAY;IACnC,YAAY,aAAsC,EAAE;QAClD,KAAK,CAAC,UAAU,CAAC,CAAC;QAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,IAAI,OAAO,CAAC;YACV,CAAC,CAAC,EAAE,CAAC,CAAC;YACN,GAAG;YACH,CAAC,KAAK,GAAG,SAAS,GAAG,CAAC,EAAE,CAAC,CAAC;SAC3B,CAAC,CACH,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,IAAI,OAAO,CAAC;YACV,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC;YACd,CAAC,KAAK,EAAE,CAAC,CAAC;YACV,CAAC,CAAC,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC;SACf,CAAC,CACH,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,aAAa,CAAC,CAAC,KAAK,GAAG,SAAS,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC;QACzE,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,CAAC,KAAK,GAAG,SAAS,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,CAAC;CACF"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Element } from "../element.js";
|
|
2
|
+
import { Element2Term } from "../element2term.js";
|
|
3
|
+
import { Buf, Not } from "./buffer.js";
|
|
4
|
+
import { And } from "./and.js";
|
|
5
|
+
export declare class Table extends Element {
|
|
6
|
+
constructor(userParams: Record<string, unknown> & {
|
|
7
|
+
table: string;
|
|
8
|
+
colfmt?: string;
|
|
9
|
+
fontsize?: number;
|
|
10
|
+
font?: string;
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
export declare class NotNot extends Element2Term {
|
|
14
|
+
constructor(userParams?: Record<string, unknown>);
|
|
15
|
+
}
|
|
16
|
+
export declare class Tgate extends Element2Term {
|
|
17
|
+
constructor(userParams?: Record<string, unknown>);
|
|
18
|
+
}
|
|
19
|
+
export declare class Schmitt extends Buf {
|
|
20
|
+
constructor(userParams?: Record<string, unknown>);
|
|
21
|
+
}
|
|
22
|
+
export declare class SchmittNot extends Not {
|
|
23
|
+
constructor(userParams?: Record<string, unknown>);
|
|
24
|
+
}
|
|
25
|
+
export declare class SchmittAnd extends And {
|
|
26
|
+
constructor(userParams?: Record<string, unknown> & {
|
|
27
|
+
inputs?: number;
|
|
28
|
+
nand?: boolean;
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
export declare function SchmittNand(userParams?: Record<string, unknown>): SchmittAnd;
|
|
32
|
+
export { TimingDiagram } from "./timing.js";
|
|
33
|
+
export type { SignalDef, WaveDict } from "./timing.js";
|
|
34
|
+
export { BitField } from "./bitfield.js";
|
|
35
|
+
export type { BitFieldItem, BitFieldConfig, BitFieldReg } from "./bitfield.js";
|
|
36
|
+
//# sourceMappingURL=extras.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extras.d.ts","sourceRoot":"","sources":["../../src/logic/extras.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAIlD,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AA4B/B,qBAAa,KAAM,SAAQ,OAAO;gBAE9B,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG;QACpC,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,IAAI,CAAC,EAAE,MAAM,CAAC;KACf;CA6JJ;AAED,qBAAa,MAAO,SAAQ,YAAY;gBAC1B,UAAU,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM;CAYrD;AAED,qBAAa,KAAM,SAAQ,YAAY;gBACzB,UAAU,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM;CAiBrD;AASD,qBAAa,OAAQ,SAAQ,GAAG;gBAClB,UAAU,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM;CAIrD;AAED,qBAAa,UAAW,SAAQ,GAAG;gBACrB,UAAU,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM;CAIrD;AAED,qBAAa,UAAW,SAAQ,GAAG;gBACrB,UAAU,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,OAAO,CAAA;KAAO;CAM3F;AAED,wBAAgB,WAAW,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,UAAU,CAE5E;AAED,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,YAAY,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,YAAY,EAAE,YAAY,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
import { Element } from "../element.js";
|
|
2
|
+
import { Element2Term } from "../element2term.js";
|
|
3
|
+
import { GAP, Segment, SegmentCircle, SegmentText } from "../segment.js";
|
|
4
|
+
import { getParam } from "../params.js";
|
|
5
|
+
import { textSize } from "../svg/figure.js";
|
|
6
|
+
import { Buf, Not } from "./buffer.js";
|
|
7
|
+
import { And } from "./and.js";
|
|
8
|
+
const gateh = 1;
|
|
9
|
+
const gatel = 0.65;
|
|
10
|
+
const notbubble = 0.12;
|
|
11
|
+
function parseColfmt(colfmt) {
|
|
12
|
+
let fmt = colfmt.replace(/\|\|/g, "ǁ");
|
|
13
|
+
for (;;) {
|
|
14
|
+
const out = fmt.replace(/([lcr])([lcr])/g, "$1.$2");
|
|
15
|
+
if (out === fmt)
|
|
16
|
+
break;
|
|
17
|
+
fmt = out;
|
|
18
|
+
}
|
|
19
|
+
if (!fmt.startsWith("|") && !fmt.startsWith("ǁ")) {
|
|
20
|
+
fmt = "." + fmt;
|
|
21
|
+
}
|
|
22
|
+
if (!fmt.endsWith("|") && !fmt.endsWith("ǁ")) {
|
|
23
|
+
fmt += ".";
|
|
24
|
+
}
|
|
25
|
+
let bars = "";
|
|
26
|
+
let justs = "";
|
|
27
|
+
for (let i = 0; i < fmt.length; i++) {
|
|
28
|
+
if (i % 2 === 0)
|
|
29
|
+
bars += fmt[i];
|
|
30
|
+
else
|
|
31
|
+
justs += fmt[i];
|
|
32
|
+
}
|
|
33
|
+
return { justs, bars };
|
|
34
|
+
}
|
|
35
|
+
export class Table extends Element {
|
|
36
|
+
constructor(userParams) {
|
|
37
|
+
super(userParams);
|
|
38
|
+
const tableStr = userParams.table;
|
|
39
|
+
const fontsize = userParams.fontsize ?? 12;
|
|
40
|
+
const font = userParams.font ?? "sans";
|
|
41
|
+
const doublebarsep = 0.03;
|
|
42
|
+
const rowpad = 0.3;
|
|
43
|
+
const colpad = 0.4;
|
|
44
|
+
const allRows = tableStr.trim().split("\n");
|
|
45
|
+
let rowfmt = "";
|
|
46
|
+
for (const row of allRows) {
|
|
47
|
+
if (row.includes("---"))
|
|
48
|
+
rowfmt += "|";
|
|
49
|
+
else if (row.includes("==="))
|
|
50
|
+
rowfmt += "ǁ";
|
|
51
|
+
else
|
|
52
|
+
rowfmt += "l";
|
|
53
|
+
}
|
|
54
|
+
const { justs: rowjusts, bars: rowbars } = parseColfmt(rowfmt);
|
|
55
|
+
const stripPipes = (s) => s.replace(/^\|?\s*|\s*\|?$/g, "");
|
|
56
|
+
const dataRows = allRows.filter((r) => !r.includes("---") && !r.includes("==="));
|
|
57
|
+
const ncols0 = stripPipes(dataRows[0]).split("|").length;
|
|
58
|
+
let colfmtStr = userParams.colfmt;
|
|
59
|
+
if (colfmtStr == null || colfmtStr === "") {
|
|
60
|
+
colfmtStr = "c".repeat(ncols0);
|
|
61
|
+
}
|
|
62
|
+
const { justs: coljusts, bars: colbars } = parseColfmt(colfmtStr);
|
|
63
|
+
const ncols = coljusts.length;
|
|
64
|
+
const nrows = rowjusts.length;
|
|
65
|
+
if (stripPipes(dataRows[0]).split("|").length !== ncols) {
|
|
66
|
+
throw new Error("Number of columns in table does not match colfmt string.");
|
|
67
|
+
}
|
|
68
|
+
const colwidths = new Array(ncols).fill(0);
|
|
69
|
+
const rowheights = new Array(nrows).fill(0);
|
|
70
|
+
for (let k = 0; k < dataRows.length; k++) {
|
|
71
|
+
const cells = stripPipes(dataRows[k])
|
|
72
|
+
.split("|")
|
|
73
|
+
.map((c) => c.trim());
|
|
74
|
+
for (let i = 0; i < cells.length; i++) {
|
|
75
|
+
const { width: txtw, height: txth } = textSize(cells[i], fontsize, font);
|
|
76
|
+
colwidths[i] = Math.max(colwidths[i], (txtw / 72) * 2 + colpad);
|
|
77
|
+
rowheights[k] = Math.max(rowheights[k], (txth / 72) * 2 + rowpad);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
const totheight = rowheights.reduce((a, b) => a + b, 0);
|
|
81
|
+
const totwidth = colwidths.reduce((a, b) => a + b, 0);
|
|
82
|
+
const sumArr = (arr, end) => arr.slice(0, end).reduce((a, b) => a + b, 0);
|
|
83
|
+
for (let i = 0; i < colbars.length; i++) {
|
|
84
|
+
const colx = sumArr(colwidths, i);
|
|
85
|
+
if (colbars[i] === "|") {
|
|
86
|
+
this.segments.push(new Segment([
|
|
87
|
+
[colx, 0],
|
|
88
|
+
[colx, -totheight],
|
|
89
|
+
], { lw: 1 }));
|
|
90
|
+
}
|
|
91
|
+
else if (colbars[i] === "ǁ") {
|
|
92
|
+
this.segments.push(new Segment([
|
|
93
|
+
[colx - doublebarsep, 0],
|
|
94
|
+
[colx - doublebarsep, -totheight],
|
|
95
|
+
], { lw: 1 }));
|
|
96
|
+
this.segments.push(new Segment([
|
|
97
|
+
[colx + doublebarsep, 0],
|
|
98
|
+
[colx + doublebarsep, -totheight],
|
|
99
|
+
], { lw: 1 }));
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
for (let i = 0; i < rowbars.length; i++) {
|
|
103
|
+
const rowy = -sumArr(rowheights, i);
|
|
104
|
+
if (rowbars[i] === "|") {
|
|
105
|
+
this.segments.push(new Segment([
|
|
106
|
+
[0, rowy],
|
|
107
|
+
[totwidth, rowy],
|
|
108
|
+
], { lw: 1 }));
|
|
109
|
+
}
|
|
110
|
+
else if (rowbars[i] === "ǁ") {
|
|
111
|
+
this.segments.push(new Segment([
|
|
112
|
+
[0, rowy - doublebarsep],
|
|
113
|
+
[totwidth, rowy - doublebarsep],
|
|
114
|
+
], { lw: 1 }));
|
|
115
|
+
this.segments.push(new Segment([
|
|
116
|
+
[0, rowy + doublebarsep],
|
|
117
|
+
[totwidth, rowy + doublebarsep],
|
|
118
|
+
], { lw: 1 }));
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
for (let r = 0; r < dataRows.length; r++) {
|
|
122
|
+
const cells = stripPipes(dataRows[r])
|
|
123
|
+
.split("|")
|
|
124
|
+
.map((c) => c.trim());
|
|
125
|
+
for (let c = 0; c < cells.length; c++) {
|
|
126
|
+
let cellx = sumArr(colwidths, c);
|
|
127
|
+
const celly = -sumArr(rowheights, r) - rowheights[r];
|
|
128
|
+
const halign = { c: "center", l: "left", r: "right" }[coljusts[c]] ?? "center";
|
|
129
|
+
if (halign === "center") {
|
|
130
|
+
cellx += colwidths[c] / 2;
|
|
131
|
+
}
|
|
132
|
+
else if (halign === "right") {
|
|
133
|
+
cellx += colwidths[c] - colpad / 2;
|
|
134
|
+
}
|
|
135
|
+
else {
|
|
136
|
+
cellx += colpad / 2;
|
|
137
|
+
}
|
|
138
|
+
this.segments.push(new SegmentText([cellx, celly + rowpad / 3], cells[c], {
|
|
139
|
+
fontfamily: font,
|
|
140
|
+
fontsize,
|
|
141
|
+
align: [halign, "bottom"],
|
|
142
|
+
}));
|
|
143
|
+
this.anchors[`cell${r}_${c}`] = [cellx, celly + rowheights[r] / 2];
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
export class NotNot extends Element2Term {
|
|
149
|
+
constructor(userParams = {}) {
|
|
150
|
+
super(userParams);
|
|
151
|
+
this.segments.push(new Segment([[-notbubble * 2, 0], GAP, [gatel + notbubble * 2, 0]]));
|
|
152
|
+
this.segments.push(new Segment([
|
|
153
|
+
[0, gateh / 2], [gatel, 0], [0, -gateh / 2], [0, gateh / 2],
|
|
154
|
+
]));
|
|
155
|
+
this.segments.push(new SegmentCircle([gatel + notbubble, 0], notbubble));
|
|
156
|
+
this.segments.push(new SegmentCircle([gatel + notbubble, 0], notbubble));
|
|
157
|
+
this.segments.push(new SegmentCircle([-notbubble, 0], notbubble));
|
|
158
|
+
this.anchors.out = [gatel + notbubble * 2, 0];
|
|
159
|
+
this.anchors.in1 = [0, 0];
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
export class Tgate extends Element2Term {
|
|
163
|
+
constructor(userParams = {}) {
|
|
164
|
+
super(userParams);
|
|
165
|
+
this.segments.push(new Segment([[0, 0], GAP, [gatel, 0]]));
|
|
166
|
+
this.segments.push(new Segment([
|
|
167
|
+
[0, 0], [0, -gateh / 2], [gatel, 0], [0, gateh / 2], [0, 0],
|
|
168
|
+
]));
|
|
169
|
+
this.segments.push(new Segment([
|
|
170
|
+
[gatel, 0], [gatel, -gateh / 2], [0, 0], [gatel, gateh / 2], [gatel, 0],
|
|
171
|
+
]));
|
|
172
|
+
this.segments.push(new SegmentCircle([gatel / 2, 0.28 + 0.08], 0.08));
|
|
173
|
+
this.segments.push(new Segment([[gatel / 2, 0.28 + 0.16], [gatel / 2, 0.7]]));
|
|
174
|
+
this.segments.push(new Segment([[gatel / 2, -0.28], [gatel / 2, -0.7]]));
|
|
175
|
+
this.anchors.out = [gatel, 0];
|
|
176
|
+
this.anchors.in1 = [0, 0];
|
|
177
|
+
this.anchors.c = [gatel / 2, -0.7];
|
|
178
|
+
this.anchors.cbar = [gatel / 2, 0.7];
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
const hysteresisSegment = (xOffset = 0) => new Segment([
|
|
182
|
+
[xOffset + 0.07, -0.15], [xOffset + 0.25, -0.15], [xOffset + 0.25, 0.15],
|
|
183
|
+
GAP,
|
|
184
|
+
[xOffset + 0.33, 0.15], [xOffset + 0.15, 0.15], [xOffset + 0.15, -0.15],
|
|
185
|
+
], { lw: 1 });
|
|
186
|
+
export class Schmitt extends Buf {
|
|
187
|
+
constructor(userParams = {}) {
|
|
188
|
+
super(userParams);
|
|
189
|
+
this.segments.push(hysteresisSegment());
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
export class SchmittNot extends Not {
|
|
193
|
+
constructor(userParams = {}) {
|
|
194
|
+
super(userParams);
|
|
195
|
+
this.segments.push(hysteresisSegment());
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
export class SchmittAnd extends And {
|
|
199
|
+
constructor(userParams = {}) {
|
|
200
|
+
super(userParams);
|
|
201
|
+
const leadin = getParam(this.params, "leadin", 0.35);
|
|
202
|
+
const xofst = leadin + gatel / 2;
|
|
203
|
+
this.segments.push(hysteresisSegment(xofst));
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
export function SchmittNand(userParams) {
|
|
207
|
+
return new SchmittAnd({ ...userParams, nand: true });
|
|
208
|
+
}
|
|
209
|
+
export { TimingDiagram } from "./timing.js";
|
|
210
|
+
export { BitField } from "./bitfield.js";
|
|
211
|
+
//# sourceMappingURL=extras.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extras.js","sourceRoot":"","sources":["../../src/logic/extras.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Element } from "../element.js";
|
|
2
|
+
export interface KmapGroupStyle {
|
|
3
|
+
color?: string;
|
|
4
|
+
fill?: string | boolean;
|
|
5
|
+
lw?: number;
|
|
6
|
+
ls?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare class Kmap extends Element {
|
|
9
|
+
constructor(userParams?: Record<string, unknown> & {
|
|
10
|
+
names?: string;
|
|
11
|
+
truthtable?: [string, string][];
|
|
12
|
+
groups?: Record<string, KmapGroupStyle>;
|
|
13
|
+
default?: string;
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=kmap.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kmap.d.ts","sourceRoot":"","sources":["../../src/logic/kmap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAGxC,MAAM,WAAW,cAAc;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IACxB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,EAAE,CAAC,EAAE,MAAM,CAAC;CACb;AAED,qBAAa,IAAK,SAAQ,OAAO;gBAE7B,UAAU,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG;QACpC,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;QAChC,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;QACxC,OAAO,CAAC,EAAE,MAAM,CAAC;KACb;CA+MT"}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { Element } from "../element.js";
|
|
2
|
+
import { Segment, SegmentText, SegmentPoly } from "../segment.js";
|
|
3
|
+
export class Kmap extends Element {
|
|
4
|
+
constructor(userParams = {}) {
|
|
5
|
+
const { names: rawNames, truthtable: rawTt, groups: rawGroups, default: defaultVal, ...rest } = userParams;
|
|
6
|
+
super(rest);
|
|
7
|
+
const names = rawNames ?? "ABCD";
|
|
8
|
+
const truthtable = rawTt ?? [];
|
|
9
|
+
const groups = rawGroups ?? {};
|
|
10
|
+
const dflt = defaultVal ?? "0";
|
|
11
|
+
const segLw = rest.lw ?? 1.25;
|
|
12
|
+
let rows;
|
|
13
|
+
let cols;
|
|
14
|
+
if (names.length === 4) {
|
|
15
|
+
rows = 4;
|
|
16
|
+
cols = 4;
|
|
17
|
+
}
|
|
18
|
+
else if (names.length === 3) {
|
|
19
|
+
rows = 2;
|
|
20
|
+
cols = 4;
|
|
21
|
+
}
|
|
22
|
+
else if (names.length === 2) {
|
|
23
|
+
rows = 2;
|
|
24
|
+
cols = 2;
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
throw new Error("Kmap requires 2 to 4 variable names");
|
|
28
|
+
}
|
|
29
|
+
const boxw = 1;
|
|
30
|
+
const w = cols * boxw;
|
|
31
|
+
const h = rows * boxw;
|
|
32
|
+
const order = [0, 1, 3, 2]; // Gray code: 00, 01, 11, 10
|
|
33
|
+
const segOpts = { lw: segLw };
|
|
34
|
+
// Frame
|
|
35
|
+
this.segments.push(new Segment([[0, 0], [w, 0], [w, h], [0, h], [0, 0]], segOpts));
|
|
36
|
+
for (let row = 0; row < rows; row++) {
|
|
37
|
+
this.segments.push(new Segment([[0, row * boxw], [w, row * boxw]], segOpts));
|
|
38
|
+
}
|
|
39
|
+
for (let col = 0; col < cols; col++) {
|
|
40
|
+
this.segments.push(new Segment([[col * boxw, 0], [col * boxw, h]], segOpts));
|
|
41
|
+
}
|
|
42
|
+
const diag = boxw / Math.SQRT2;
|
|
43
|
+
this.segments.push(new Segment([[0, h], [-diag, h + diag]], segOpts));
|
|
44
|
+
// Variable-name labels
|
|
45
|
+
const rowfmt = rows > 2 ? 2 : 1;
|
|
46
|
+
const colfmt = cols > 2 ? 2 : 1;
|
|
47
|
+
const topnames = names.length > 2 ? names.slice(0, 2) : names[0];
|
|
48
|
+
const leftnames = names.length > 2 ? names.slice(2) : names[1];
|
|
49
|
+
this.segments.push(new SegmentText([0, h + (3 * diag) / 4], topnames, {
|
|
50
|
+
align: ["right", "bottom"],
|
|
51
|
+
fontsize: 12,
|
|
52
|
+
}));
|
|
53
|
+
this.segments.push(new SegmentText([-(3 * diag) / 4, h], leftnames, {
|
|
54
|
+
align: ["right", "bottom"],
|
|
55
|
+
fontsize: 12,
|
|
56
|
+
}));
|
|
57
|
+
// Column header labels (Gray code)
|
|
58
|
+
for (let i = 0; i < cols; i++) {
|
|
59
|
+
const col = order[i];
|
|
60
|
+
this.segments.push(new SegmentText([col * boxw + boxw / 2, h + boxw / 20], toBin(i, colfmt), { align: ["center", "bottom"], fontsize: 10 }));
|
|
61
|
+
}
|
|
62
|
+
// Row header labels (Gray code)
|
|
63
|
+
for (let j = 0; j < rows; j++) {
|
|
64
|
+
const row = order[j];
|
|
65
|
+
this.segments.push(new SegmentText([-boxw / 10, h - row * boxw - boxw / 2], toBin(j, rowfmt), { align: ["right", "center"], fontsize: 10 }));
|
|
66
|
+
}
|
|
67
|
+
// Truth-table values
|
|
68
|
+
const ttIn = truthtable.map((k) => k[0]);
|
|
69
|
+
const ttOut = truthtable.map((k) => k[1]);
|
|
70
|
+
for (let i = 0; i < cols; i++) {
|
|
71
|
+
const col = order[i];
|
|
72
|
+
for (let j = 0; j < rows; j++) {
|
|
73
|
+
const row = order[j];
|
|
74
|
+
const invalue = toBin(i, colfmt) + toBin(j, rowfmt);
|
|
75
|
+
const idx = ttIn.indexOf(invalue);
|
|
76
|
+
const valstr = idx === -1 ? dflt : String(ttOut[idx]);
|
|
77
|
+
this.segments.push(new SegmentText([col * boxw + boxw / 2, h - row * boxw - boxw / 2], valstr, { align: ["center", "center"], fontsize: 12 }));
|
|
78
|
+
this.anchors[`cell${invalue}`] = [
|
|
79
|
+
col * boxw + boxw / 2,
|
|
80
|
+
h - row * boxw - boxw / 2,
|
|
81
|
+
];
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
// Group highlights
|
|
85
|
+
const gpad = 0.1;
|
|
86
|
+
const rowlookup = {
|
|
87
|
+
"0": 0, "1": 1, ".": 0,
|
|
88
|
+
"..": 0, "00": 0, "01": 1, "10": 3, "11": 2,
|
|
89
|
+
".0": 3, ".1": 1, "0.": 0, "1.": 2,
|
|
90
|
+
};
|
|
91
|
+
for (const [group, style] of Object.entries(groups)) {
|
|
92
|
+
const tlen = topnames.length;
|
|
93
|
+
const llen = leftnames.length;
|
|
94
|
+
const topPart = group.slice(0, tlen);
|
|
95
|
+
const leftPart = group.slice(tlen);
|
|
96
|
+
const gwidth = Math.pow(2, tlen - (count01(topPart)));
|
|
97
|
+
const gheight = Math.pow(2, llen - (count01(leftPart)));
|
|
98
|
+
const col = rowlookup[topPart] ?? 0;
|
|
99
|
+
const row = rowlookup[leftPart] ?? 0;
|
|
100
|
+
const x1 = col * boxw;
|
|
101
|
+
const x2 = x1 + gwidth * boxw;
|
|
102
|
+
const y1 = h - row * boxw;
|
|
103
|
+
const y2 = y1 - gheight * boxw;
|
|
104
|
+
let verts = [];
|
|
105
|
+
if (col + gwidth <= cols && row + gheight <= rows) {
|
|
106
|
+
verts = [
|
|
107
|
+
[[x1 + gpad, y1 - gpad], [x2 - gpad, y1 - gpad],
|
|
108
|
+
[x2 - gpad, y2 + gpad], [x1 + gpad, y2 + gpad]],
|
|
109
|
+
];
|
|
110
|
+
}
|
|
111
|
+
else if (row + gheight <= rows) {
|
|
112
|
+
verts = [
|
|
113
|
+
[[x1 + gpad, y1 - gpad], [x1 + boxw + gpad, y1 - gpad],
|
|
114
|
+
[x1 + boxw + gpad, y2 + gpad], [x1 + gpad, y2 + gpad]],
|
|
115
|
+
[[-gpad, y1 - gpad], [boxw - gpad, y1 - gpad],
|
|
116
|
+
[boxw - gpad, y2 + gpad], [-gpad, y2 + gpad]],
|
|
117
|
+
];
|
|
118
|
+
}
|
|
119
|
+
else if (col + gwidth <= cols) {
|
|
120
|
+
verts = [
|
|
121
|
+
[[x1 + gpad, y1 - gpad], [x2 - gpad, y1 - gpad],
|
|
122
|
+
[x2 - gpad, y1 - boxw - gpad], [x1 + gpad, y1 - boxw - gpad]],
|
|
123
|
+
[[x1 + gpad, h + gpad], [x2 - gpad, h + gpad],
|
|
124
|
+
[x2 - gpad, h - boxw + gpad], [x1 + gpad, h - boxw + gpad]],
|
|
125
|
+
];
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
verts = [
|
|
129
|
+
[[x1 + gpad, y1 - gpad], [x1 + boxw + gpad, y1 - gpad],
|
|
130
|
+
[x1 + boxw + gpad, y1 - boxw - gpad], [x1 + gpad, y1 - boxw - gpad]],
|
|
131
|
+
[[-gpad, y1 - gpad], [boxw - gpad, y1 - gpad],
|
|
132
|
+
[boxw - gpad, y1 - boxw - gpad], [-gpad, y1 - boxw - gpad]],
|
|
133
|
+
[[-gpad, h + gpad], [boxw - gpad, h + gpad],
|
|
134
|
+
[boxw - gpad, h - boxw + gpad], [-gpad, h - boxw + gpad]],
|
|
135
|
+
[[x1 + gpad, h + gpad], [x1 + boxw + gpad, h + gpad],
|
|
136
|
+
[x1 + boxw + gpad, h - boxw + gpad], [x1 + gpad, h - boxw + gpad]],
|
|
137
|
+
];
|
|
138
|
+
}
|
|
139
|
+
const polyLw = style.lw ?? 1;
|
|
140
|
+
for (const vert of verts) {
|
|
141
|
+
this.segments.push(new SegmentPoly(vert, {
|
|
142
|
+
cornerradius: 0.25,
|
|
143
|
+
color: style.color,
|
|
144
|
+
fill: style.fill,
|
|
145
|
+
lw: polyLw,
|
|
146
|
+
ls: style.ls,
|
|
147
|
+
}));
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
function toBin(n, width) {
|
|
153
|
+
return n.toString(2).padStart(width, "0");
|
|
154
|
+
}
|
|
155
|
+
function count01(s) {
|
|
156
|
+
let c = 0;
|
|
157
|
+
for (const ch of s) {
|
|
158
|
+
if (ch === "0" || ch === "1")
|
|
159
|
+
c++;
|
|
160
|
+
}
|
|
161
|
+
return c;
|
|
162
|
+
}
|
|
163
|
+
//# sourceMappingURL=kmap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kmap.js","sourceRoot":"","sources":["../../src/logic/kmap.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OR / NOR / XOR / XNOR — aligned with Python `logic/logic.py` · `Or`.
|
|
3
|
+
*/
|
|
4
|
+
import { Element } from "../element.js";
|
|
5
|
+
export declare class Or extends Element {
|
|
6
|
+
constructor(userParams?: Record<string, unknown> & {
|
|
7
|
+
inputs?: number;
|
|
8
|
+
nor?: boolean;
|
|
9
|
+
xor?: boolean;
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
/** NOR = `Or` with `nor: true`. */
|
|
13
|
+
export declare function nor(userParams?: Record<string, unknown>): Or;
|
|
14
|
+
/** XOR = `Or` with `xor: true`. */
|
|
15
|
+
export declare function xor(userParams?: Record<string, unknown>): Or;
|
|
16
|
+
/** XNOR = `Or` with `nor` and `xor`. */
|
|
17
|
+
export declare function xnor(userParams?: Record<string, unknown>): Or;
|
|
18
|
+
//# sourceMappingURL=or.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"or.d.ts","sourceRoot":"","sources":["../../src/logic/or.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAWxC,qBAAa,EAAG,SAAQ,OAAO;gBAE3B,UAAU,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,OAAO,CAAC;QAAC,GAAG,CAAC,EAAE,OAAO,CAAA;KAAO;CA2G/F;AAED,mCAAmC;AACnC,wBAAgB,GAAG,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,EAAE,CAE5D;AAED,mCAAmC;AACnC,wBAAgB,GAAG,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,EAAE,CAE5D;AAED,wCAAwC;AACxC,wBAAgB,IAAI,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,EAAE,CAE7D"}
|