@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
package/dist/logic/or.js
ADDED
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OR / NOR / XOR / XNOR — aligned with Python `logic/logic.py` · `Or`.
|
|
3
|
+
*/
|
|
4
|
+
import { Element } from "../element.js";
|
|
5
|
+
import { linspace } from "../geometry/util.js";
|
|
6
|
+
import { getParam } from "../params.js";
|
|
7
|
+
import { Segment, SegmentCircle } from "../segment.js";
|
|
8
|
+
const gateh = 1;
|
|
9
|
+
const gatel = 0.65;
|
|
10
|
+
const notbubble = 0.12;
|
|
11
|
+
const orflat = 0.5;
|
|
12
|
+
const xorgap = 0.15;
|
|
13
|
+
export class Or extends Element {
|
|
14
|
+
constructor(userParams = {}) {
|
|
15
|
+
super(userParams);
|
|
16
|
+
Object.assign(this.defaults, { leadin: 0.35, leadout: 0.35 });
|
|
17
|
+
const inputs = userParams.inputs ?? 2;
|
|
18
|
+
const nor = userParams.nor ?? false;
|
|
19
|
+
const xor = userParams.xor ?? false;
|
|
20
|
+
const leadin = getParam(this.params, "leadin", 0.35);
|
|
21
|
+
const leadout = getParam(this.params, "leadout", 0.35);
|
|
22
|
+
const leadinIn = leadin - (xor ? xorgap : 0);
|
|
23
|
+
const xsLin = linspace(0, gatel + 0.05, 50);
|
|
24
|
+
let ys = xsLin.map((x0) => x0 * x0);
|
|
25
|
+
const maxY = Math.max(...ys);
|
|
26
|
+
ys = ys.map((y0) => y0 - maxY);
|
|
27
|
+
ys = [Math.min(...ys), ...ys];
|
|
28
|
+
const xs = [0, ...xsLin.map((x0) => x0 + orflat)];
|
|
29
|
+
const minYs = Math.min(...ys);
|
|
30
|
+
const y2 = linspace(minYs, -minYs, 50);
|
|
31
|
+
let x2 = y2.map((y0) => -y0 * y0);
|
|
32
|
+
const back = Math.min(...x2);
|
|
33
|
+
x2 = x2.map((x0) => x0 - back);
|
|
34
|
+
const xsLead = xs.map((x0) => x0 + leadin);
|
|
35
|
+
const x2Lead = x2.map((x0) => x0 + leadin);
|
|
36
|
+
const tip = Math.max(...xsLead);
|
|
37
|
+
const orheight = Math.abs(minYs);
|
|
38
|
+
const negy = ys.map((y0) => -y0);
|
|
39
|
+
const path = [
|
|
40
|
+
...xsLead.map((x, i) => [x, ys[i]]),
|
|
41
|
+
...[...xsLead].reverse().map((x, i) => {
|
|
42
|
+
const j = negy.length - 1 - i;
|
|
43
|
+
return [x, negy[j]];
|
|
44
|
+
}),
|
|
45
|
+
...[...x2Lead].reverse().map((x, i) => [x, y2[y2.length - 1 - i]]),
|
|
46
|
+
];
|
|
47
|
+
this.segments.push(new Segment(path));
|
|
48
|
+
this.anchors.out = [tip + leadout, 0];
|
|
49
|
+
this.anchors.end = this.anchors.out;
|
|
50
|
+
if (xor) {
|
|
51
|
+
const xxor = x2Lead.map((x0) => x0 - xorgap);
|
|
52
|
+
this.segments.push(new Segment(xxor.map((x, i) => [x, y2[i]])));
|
|
53
|
+
}
|
|
54
|
+
if (nor) {
|
|
55
|
+
this.segments.push(new SegmentCircle([tip + notbubble, 0], notbubble));
|
|
56
|
+
}
|
|
57
|
+
let dy;
|
|
58
|
+
let backlen = 0;
|
|
59
|
+
if (inputs === 2) {
|
|
60
|
+
dy = gateh * 0.5;
|
|
61
|
+
}
|
|
62
|
+
else if (inputs === 3) {
|
|
63
|
+
dy = gateh * 0.33;
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
dy = gateh * 0.4;
|
|
67
|
+
backlen = dy * (inputs - 1);
|
|
68
|
+
}
|
|
69
|
+
for (let i = 0; i < inputs; i++) {
|
|
70
|
+
const y = (i + 1 - (inputs / 2 + 0.5)) * dy;
|
|
71
|
+
let xback = leadinIn - y * y - back;
|
|
72
|
+
if (inputs > 3 && (y > orheight || y < -orheight)) {
|
|
73
|
+
xback = leadinIn;
|
|
74
|
+
}
|
|
75
|
+
const idx = inputs - i;
|
|
76
|
+
this.anchors[`in${idx}`] = [0, y];
|
|
77
|
+
this.segments.push(new Segment([[0, y], [xback, y]]));
|
|
78
|
+
}
|
|
79
|
+
if (inputs > 3) {
|
|
80
|
+
this.segments.push(new Segment([
|
|
81
|
+
[leadinIn, backlen / 2 + dy / 2],
|
|
82
|
+
[leadinIn, orheight],
|
|
83
|
+
]));
|
|
84
|
+
this.segments.push(new Segment([
|
|
85
|
+
[leadinIn, -backlen / 2 - dy / 2],
|
|
86
|
+
[leadinIn, -orheight],
|
|
87
|
+
]));
|
|
88
|
+
}
|
|
89
|
+
if (nor) {
|
|
90
|
+
this.segments.push(new Segment([
|
|
91
|
+
[tip + notbubble * 2, 0],
|
|
92
|
+
[tip + leadout, 0],
|
|
93
|
+
]));
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
this.segments.push(new Segment([[tip, 0], [tip + leadout, 0]]));
|
|
97
|
+
}
|
|
98
|
+
const last = this.segments[this.segments.length - 1];
|
|
99
|
+
if (last instanceof Segment) {
|
|
100
|
+
const lp = last.path[last.path.length - 1];
|
|
101
|
+
this.elmParams.drop = [lp[0], lp[1]];
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
/** NOR = `Or` with `nor: true`. */
|
|
106
|
+
export function nor(userParams) {
|
|
107
|
+
return new Or({ ...userParams, nor: true });
|
|
108
|
+
}
|
|
109
|
+
/** XOR = `Or` with `xor: true`. */
|
|
110
|
+
export function xor(userParams) {
|
|
111
|
+
return new Or({ ...userParams, xor: true });
|
|
112
|
+
}
|
|
113
|
+
/** XNOR = `Or` with `nor` and `xor`. */
|
|
114
|
+
export function xnor(userParams) {
|
|
115
|
+
return new Or({ ...userParams, nor: true, xor: true });
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=or.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"or.js","sourceRoot":"","sources":["../../src/logic/or.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { Element } from "../element.js";
|
|
2
|
+
export interface SignalDef {
|
|
3
|
+
name?: string;
|
|
4
|
+
wave?: string;
|
|
5
|
+
data?: string[] | string;
|
|
6
|
+
phase?: number;
|
|
7
|
+
period?: number;
|
|
8
|
+
color?: string;
|
|
9
|
+
lw?: number;
|
|
10
|
+
node?: string;
|
|
11
|
+
level?: string;
|
|
12
|
+
risetime?: number;
|
|
13
|
+
nodealign?: string;
|
|
14
|
+
}
|
|
15
|
+
export interface WaveDict {
|
|
16
|
+
signal?: unknown[];
|
|
17
|
+
config?: {
|
|
18
|
+
hscale?: number;
|
|
19
|
+
};
|
|
20
|
+
head?: Record<string, unknown>;
|
|
21
|
+
foot?: Record<string, unknown>;
|
|
22
|
+
edge?: string[];
|
|
23
|
+
}
|
|
24
|
+
export declare class TimingDiagram extends Element {
|
|
25
|
+
private readonly waveData;
|
|
26
|
+
private readonly yheight;
|
|
27
|
+
private readonly ygap;
|
|
28
|
+
private readonly risetime;
|
|
29
|
+
private readonly _fontSize;
|
|
30
|
+
private readonly namecolor;
|
|
31
|
+
private readonly datacolor?;
|
|
32
|
+
private readonly gridcolor;
|
|
33
|
+
private readonly tickcolor;
|
|
34
|
+
private readonly edgecolor;
|
|
35
|
+
private readonly hscale;
|
|
36
|
+
private readonly showGrid;
|
|
37
|
+
constructor(waved: WaveDict, userParams?: Record<string, unknown>);
|
|
38
|
+
private _drawGrid;
|
|
39
|
+
private _drawName;
|
|
40
|
+
private _drawWave;
|
|
41
|
+
private _drawEdges;
|
|
42
|
+
private _drawHeadFoot;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=timing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timing.d.ts","sourceRoot":"","sources":["../../src/logic/timing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAYxC,MAAM,WAAW,SAAS;IACxB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,QAAQ;IACvB,MAAM,CAAC,EAAE,OAAO,EAAE,CAAC;IACnB,MAAM,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAC7B,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;CACjB;AA0nBD,qBAAa,aAAc,SAAQ,OAAO;IACxC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAW;IACpC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAS;IAC9B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAU;gBAEvB,KAAK,EAAE,QAAQ,EAAE,UAAU,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM;IAmDrE,OAAO,CAAC,SAAS;IAejB,OAAO,CAAC,SAAS;IAYjB,OAAO,CAAC,SAAS;IAsFjB,OAAO,CAAC,UAAU;IAiGlB,OAAO,CAAC,aAAa;CAwCtB"}
|