早押しボタンを作ってみる
2021-12-04
状態を記憶する回路を作ります。
\[ \newcommand{dn}[3]{\frac{\mathrm{d}^{#3} #1}{\mathrm{d} #2^{#3}}}
\newcommand{\d}[2]{\frac{\mathrm{d} #1}{\mathrm{d} #2}}
\newcommand{\dd}[2]{\frac{\mathrm{d}^2 #1}{\mathrm{d} {#2}^2}}
\newcommand{\ddd}[2]{\frac{\mathrm{d}^3 #1}{\mathrm{d} {#2}^3}}
\newcommand{\pdn}[3]{\frac{\partial^{#3} #1}{\partial {#2}^{#3}}}
\newcommand{\pd}[2]{\frac{\partial #1}{\partial #2}}
\newcommand{\pdd}[2]{\frac{\partial^2 #1}{\partial {#2}^2}}
\newcommand{\pddd}[2]{\frac{\partial^3 #1}{\partial {#2}^3}}
\newcommand{\p}{\partial}
\newcommand{\D}[2]{\frac{\mathrm{D} #1}{\mathrm{D} #2}}
\newcommand{\Re}{\mathrm{Re}}
\newcommand{\Im}{\mathrm{Im}}
\newcommand{\bra}[1]{\left\langle #1 \right|}
\newcommand{\ket}[1]{\left|#1 \right\rangle}
\newcommand{\braket}[2]{\left\langle #1 \middle|#2 \right\rangle}
\newcommand{\inner}[2]{\left\langle #1 ,#2 \right\rangle}
\newcommand{\l}{\left} \newcommand{\m}{\middle} \newcommand{\r}{\right}
\newcommand{\f}[2]{\frac{#1}{#2}} \newcommand{\eps}{\varepsilon}
\newcommand{\ra}{\rightarrow} \newcommand{\F}{\mathcal{F}}
\newcommand{\L}{\mathcal{L}} \newcommand{\t}{\quad}
\newcommand{\intinf}{\int_{-\infty}^{+\infty}}
\newcommand{\R}{\mathcal{R}} \newcommand{\C}{\mathcal{C}}
\newcommand{\Z}{\mathcal{Z}} \newcommand{\bm}[1]{\boldsymbol{#1}} \]
これは リレーから始める CPU 自作 Advent Calendar 2021 4 日目の記事です。<<< 3 日目
前回までは、組合回路を作ってきました。 組合回路は、ある入力に対して出力が一意に定まる回路です。 数学の関数 \(y=f(x)\) みたいなもので、入力が決まれば答えが決まります。
しかし、それだけではコンピュータは作れません。 コンピュータが数学の関数と違うところは、記憶ができるという点です。 コンピュータは内部状態をもっていて、内部状態の変化で多彩な動作をします。
ということで、今回は、状態を記憶できる「順序回路」という回路を作ります。
ラッチ
- ボタンを押すと、リレーが ON になる
- リレーが ON になると、リレーのスイッチが導通する
- ボタンを離しても、リレーが ON し続ける
一度ボタンを押したら、リレーが ON になりっぱなしになります。 このような回路を「ラッチ」といいます。
この回路には、OFFとONの2状態があって、スイッチが押されると状態がOFFからONに切り替わります。
電源を入れてから今までにスイッチが押されていればONに、スイッチが押されていなければOFFになります。 過去の状態に応じて出力が変わる順序回路の一種であるといえます。
RS フリップフロップ
リセットするボタンをつけると、
手押しのボタンではなく、リレーを使って電気的に信号を入力できるようにすると、
これが SR フリップフロップと呼ばれる回路です。
早押しボタン
早押しボタンの機能は、
- ある人がボタンを押したら、ランプが光り続ける
- ある人がボタンを押したら、他の人がボタンを押しても光らない
- ゲームマスターがリセットできる
- A のボタンを押すと、リレー A が ON 状態になる
- A が ON になると、E が ON になる
- E が ON になると、BC のボタンを押してもリレーが ON にならなくなる(入力を受け付けなくなる)
- リセットボタンを押すと、リレー A の ON 状態が解除され OFF 状態になる
>>> 5 日目