プログラマブル・カウンタ
[Wikipedia|▼Menu]
.mw-parser-output .ambox{border:1px solid #a2a9b1;border-left:10px solid #36c;background-color:#fbfbfb;box-sizing:border-box}.mw-parser-output .ambox+link+.ambox,.mw-parser-output .ambox+link+style+.ambox,.mw-parser-output .ambox+link+link+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+style+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+link+.ambox{margin-top:-1px}html body.mediawiki .mw-parser-output .ambox.mbox-small-left{margin:4px 1em 4px 0;overflow:hidden;width:238px;border-collapse:collapse;font-size:88%;line-height:1.25em}.mw-parser-output .ambox-speedy{border-left:10px solid #b32424;background-color:#fee7e6}.mw-parser-output .ambox-delete{border-left:10px solid #b32424}.mw-parser-output .ambox-content{border-left:10px solid #f28500}.mw-parser-output .ambox-style{border-left:10px solid #fc3}.mw-parser-output .ambox-move{border-left:10px solid #9932cc}.mw-parser-output .ambox-protection{border-left:10px solid #a2a9b1}.mw-parser-output .ambox .mbox-text{border:none;padding:0.25em 0.5em;width:100%;font-size:90%}.mw-parser-output .ambox .mbox-image{border:none;padding:2px 0 2px 0.5em;text-align:center}.mw-parser-output .ambox .mbox-imageright{border:none;padding:2px 0.5em 2px 0;text-align:center}.mw-parser-output .ambox .mbox-empty-cell{border:none;padding:0;width:1px}.mw-parser-output .ambox .mbox-image-div{width:52px}html.client-js body.skin-minerva .mw-parser-output .mbox-text-span{margin-left:23px!important}@media(min-width:720px){.mw-parser-output .ambox{margin:0 10%}}

この記事には複数の問題があります。改善ノートページでの議論にご協力ください。

出典がまったく示されていないか不十分です。内容に関する文献や情報源が必要です。(2016年4月)


マークアップをスタイルマニュアルに沿った形に修正する必要があります。(2016年4月)
出典検索?: "プログラマブル・カウンタ" ? ニュース ・ 書籍 ・ スカラー ・ CiNii ・ J-STAGE ・ NDL ・ dlib.jp ・ ジャパンサーチ ・ TWL

プログラマブル・カウンタ(: Programmable Counter)とは電子回路の一つで、任意の回数の入力信号変化を計数することができるカウンタ

プログラマブル・カウンタは、通常2つのレジスタから構成される。1つは入力パルスがある度に1ずつ増加する回路を持つもので、もう1つは前者をクリアする値を保持しておくものである。CPUがこれらのレジスタの値を読み書きできるようになっていることが多い。

また、これらのレジスタの値を比較して、一致した場合にカウント値をゼロクリアする信号を生成する回路も持っている。このクリア信号はたいてい外部に取り出せるようになっており、CPUに対して割り込みをかける用途に用いられたり、他のカウンタ回路の入力に用いられたりする。

カウンタをクリアするカウント値としてNを設定した場合、クリア信号は入力Nパルス毎に発生することとなる。つまり、入力に定期的に繰り返すパルス信号を与えた場合には、その周波数を1/Nにしたパルス信号を出力する。この観点から、プログラマブル・カウンタは「1/N分周器」と呼ばれることがある。また、この場合の設定値Nを分周比と呼ぶ。

例えばシリアル通信における通信速度(ボーレート)を様々に変化させたい(様々な通信速度に対応できる機器を作りたい)場合、分周比をCPUから自由に変えることができるプログラマブル・カウンタが必要になる。

プログラマブル・カウンタには、入力パルスをカウントする回路の前段に、別のカウンタが併設されていることが多い。この前段のカウンタはプリスケーラと呼ばれる。プリスケーラは回路の簡素化のために、2、4、16など2の冪乗の回数をカウントする毎に出力パルスが出るものであることが多い。

CPUから設定する値が、カウンタをゼロクリアする値ではなく、カウンタがオーバーフロー(最大値を過ぎるまでカウントアップ)した時にリセットする初期値であるように設計されたプログラマブル・カウンタも多い。この場合、設定するのは分周比そのものではなく、[カウンタが計数することのできる最大値-N+1](2の補数表現として見れば-N)を設定することにより1/N分周器となる。例えば、カウンタ部が8bitで構成されていた場合、(255-10+1)=246を設定すると入力周波数を1/10にする分周器になる。プログラマブル・カウンタをそのような機構にすると、回路が若干簡単になる。

かつてはプログラマブル・カウンタはそれだけで1つのICとして用いられていたが、近年はCPUの付属周辺回路としてCPUチップの中に入ってしまっていたり、CPUの周辺処理を一手に引き受けるチップセットLSIの中の1回路として組み込まれていることのほうが多い。

組み込み機器向けに設計されたCPUの場合、プログラマブル・カウンタに様々な付加機能を与える回路が付いていることが多い。例えば、カウンタをクリアする値の他に、出力値をOFFからONに切り替えるカウンタ値をセットできるレジスタを持っている場合、2つのレジスタの設定をうまく調整すると、ONである時間とOFFである時間を独立に調整しデューティ比を自在に設定した出力波形を作ることができる。このような、パルス幅を制御する技術はPWMと呼ばれ、発光体の明るさの調整や音の音色の調整など様々な用途で用いられている。

また、カウントアップのための入力信号とは別の入力信号と連動し、信号がONである間だけカウントを行ない、信号が途切れた時にカウント値を別のレジスタに転送するという機能を持つものもある。この場合、信号がONであった時間を精密に測定することができる。さらに、カウント値をデジタルアナログ変換する回路と、その出力電圧と外部入力電圧を比較して一致しているかどうかを検出する回路(アナログ・コンパレータ)をつけることにより、簡易型のアナログデジタル変換器を構成することができる。このように構成したアナログデジタル変換器は、変換時間が長くかかるという欠点を持つものの、ごく簡単な回路で作成することができ、IC上への集積も容易であるため、多く用いられている。

これらのように、多機能化したプログラマブル・カウンタは、ICU (Intelligent Counter Unit)やITU (Intelligent Timer Unit)などと呼ばれることがある。.mw-parser-output .asbox{position:relative;overflow:hidden}.mw-parser-output .asbox table{background:transparent}.mw-parser-output .asbox p{margin:0}.mw-parser-output .asbox p+p{margin-top:0.25em}.mw-parser-output .asbox{font-size:90%}.mw-parser-output .asbox-note{font-size:90%}.mw-parser-output .asbox .navbar{position:absolute;top:-0.90em;right:1em;display:none}

この項目は、電子工学に関連した書きかけの項目です。この項目を加筆・訂正などしてくださる協力者を求めていますPortal:エレクトロニクス)。
.mw-parser-output .hlist ul,.mw-parser-output .hlist ol{padding-left:0}.mw-parser-output .hlist li,.mw-parser-output .hlist dd,.mw-parser-output .hlist dt{margin-right:0;display:inline-block;white-space:nowrap}.mw-parser-output .hlist dt:after,.mw-parser-output .hlist dd:after,.mw-parser-output .hlist li:after{white-space:normal}.mw-parser-output .hlist li:after,.mw-parser-output .hlist dd:after{content:" ・\a0 ";font-weight:bold}.mw-parser-output .hlist dt:after{content:": "}.mw-parser-output .hlist-pipe dd:after,.mw-parser-output .hlist-pipe li:after{content:" |\a0 ";font-weight:normal}.mw-parser-output .hlist-hyphen dd:after,.mw-parser-output .hlist-hyphen li:after{content:" -\a0 ";font-weight:normal}.mw-parser-output .hlist-comma dd:after,.mw-parser-output .hlist-comma li:after{content:"、";font-weight:normal}.mw-parser-output .hlist-slash dd:after,.mw-parser-output .hlist-slash li:after{content:" /\a0 ";font-weight:normal}.mw-parser-output .hlist dd:last-child:after,.mw-parser-output .hlist dt:last-child:after,.mw-parser-output .hlist li:last-child:after{content:none}.mw-parser-output .hlist dd dd:first-child:before,.mw-parser-output .hlist dd dt:first-child:before,.mw-parser-output .hlist dd li:first-child:before,.mw-parser-output .hlist dt dd:first-child:before,.mw-parser-output .hlist dt dt:first-child:before,.mw-parser-output .hlist dt li:first-child:before,.mw-parser-output .hlist li dd:first-child:before,.mw-parser-output .hlist li dt:first-child:before,.mw-parser-output .hlist li li:first-child:before{content:" (";font-weight:normal}.mw-parser-output .hlist dd dd:last-child:after,.mw-parser-output .hlist dd dt:last-child:after,.mw-parser-output .hlist dd li:last-child:after,.mw-parser-output .hlist dt dd:last-child:after,.mw-parser-output .hlist dt dt:last-child:after,.mw-parser-output .hlist dt li:last-child:after,.mw-parser-output .hlist li dd:last-child:after,.mw-parser-output .hlist li dt:last-child:after,.mw-parser-output .hlist li li:last-child:after{content:")\a0 ";font-weight:normal}.mw-parser-output .hlist ol{counter-reset:listitem}.mw-parser-output .hlist ol>li{counter-increment:listitem}.mw-parser-output .hlist ol>li:before{content:" "counter(listitem)" ";white-space:nowrap}.mw-parser-output .hlist dd ol>li:first-child:before,.mw-parser-output .hlist dt ol>li:first-child:before,.mw-parser-output .hlist li ol>li:first-child:before{content:" ("counter(listitem)" "}.mw-parser-output .navbar{display:inline;font-size:75%;font-weight:normal}.mw-parser-output .navbar-collapse{float:left;text-align:left}.mw-parser-output .navbar-boxtext{word-spacing:0}.mw-parser-output .navbar ul{display:inline-block;white-space:nowrap;line-height:inherit}.mw-parser-output .navbar-brackets::before{margin-right:-0.125em;content:"[ "}.mw-parser-output .navbar-brackets::after{margin-left:-0.125em;content:" ]"}.mw-parser-output .navbar li{word-spacing:-0.125em}.mw-parser-output .navbar-mini abbr{font-variant:small-caps;border-bottom:none;text-decoration:none;cursor:inherit}.mw-parser-output .navbar-ct-full{font-size:114%;margin:0 7em}.mw-parser-output .navbar-ct-mini{font-size:114%;margin:0 4em}.mw-parser-output .infobox .navbar{font-size:88%}.mw-parser-output .navbox .navbar{display:block;font-size:88%}.mw-parser-output .navbox-title .navbar{float:left;text-align:left;margin-right:0.5em}


次ページ
記事の検索
おまかせリスト
▼オプションを表示
ブックマーク登録
mixiチェック!
Twitterに投稿
オプション/リンク一覧
話題のニュース
列車運行情報
暇つぶしWikipedia

Size:11 KB
出典: フリー百科事典『ウィキペディア(Wikipedia)
担当:undef