プログラミング論

プログラミング論 I
2010年6月17日
論理回路(and,or,not)を作成.
回路を組み合わせ半/全加算器.
http://www.ns.kogakuin.ac.jp/~ct13140/Prog.2010/
H-1
配列のメモリ格納方法
int x[4][3];
は,
「長さ3の配列」が4個 であり,
「長さ4の配列」が3個 ではない?
計算機のメモリ上には,以下の順で格納されている.
x[0][0] x[0][1] x[0][2] x[1][0] x[1][1] x[1][2] x[2][0] x[2][1]
これは重要ではない.無理して理解する必要はない.
H-2
練習 A
int x[100]のx[0]~x[99]には値が格
納されている.
この100個をint y[100]のy[0]~
y[99]にコピーするプログラムは?
ヒント:
y[0] = x[0];
y[1] = x[1];
:
をfor文を使って作り上げれば良い.
H-3
解答 A
int i;
for(i=0; i<100; i++){
y[i] = x[i];
}
H-4
C言語と関数
• 関数を作成し,関数呼び出すことにより
– 同一/類似の処理を再度書かなくて良い
– 関数を組み合わせることにより,より複雑な処
理を簡易に記述可能
これが,手続き型言語C言語の神髄(?)
積極的に関数を作成し,関数に慣れましょ
う.
H-5
だめな例
int main(){
void hoge(){
printf("hello\n");
}
printf("abc\n");
}
H-6
論理回路(and,or,not)
の作成.
回路を組み合わせ
半/全加算器を作成
H-7
BTW... 演算子とは?
• 算数の足し算 + とは?
3 + 4 = 7
3 と 4 の演算結果が,7である.
3 と 4 を入力すると,7が出力される.
H-8
ブール論理
(Boolean logic)
• 0と1(真と偽)を論理体系.
• それを扱う代数が,ブール代数.
– 論理否定(not),論理和(or),論理積
(and)の3演算より構成される.
– 登場する値は“真”と“偽”のみ.
• 0と1と考えてもよい.これはdigitalである.
– 基本は,四則演算(+-*/)より単純
• ただし,多くの場合は大量に登場する
H-9
論理値
• “真”と“偽”の二値
– 通常,真を1,偽を0と表現する.
– つまり,“整数の足し算”よりも単純で簡単?
H-10
演算
• 基本的な演算
– not(論理否定),or(論理和),
and(論理積)
• 応用的な演算
– 基本的な演算を組み合わせることにより表現
可能だが,よく使われる演算.
– xor(排他的論理和),nor(否定論理和),
nand(否定論理積)など
• 例えば,P nand Q = not( P and Q )
H-11
論理否定 (not)
• 論理値を反転する演算.
– 表記は ¬P や not P や P など.
単項演算子.
Pが真のとき,¬Pは偽.
¬真 = 偽
P
¬1 = 0
偽
Pが偽のとき,¬Pは真.
0
¬偽 = 真
真
¬0 = 1
1
注意:0と1以外の値は存在しない.
¬P
真
1
偽
0
H-12
論理和 (or)
• どれが一つでも真なら,演算結果は真.
– 表記は,P∨Q や P or Q
– 多項演算子
– 日本語の“または”に
近い(が少し異なる).
– P+Q+R
=(P+Q)+R=P+(Q+R)
や P+Q など.
P
Q
P∨Q
0
0
0
0
1
1
1
0
1
1
1
1
これは,足し算に近い? H-13
論理積 (and)
• 全てが真のとき限り,演算結果は真.
– 表記は,P∧Q や P and Q
– 多項演算子
– 日本語の“かつ”に
近い.
– P・Q・R
=(P・Q)・R=P・(Q・R)
や P・Q など.
P
Q
P∨Q
0
0
0
0
1
0
1
0
0
1
1
1
これは,まさにかけ算 H-14
排他的論理和 (xor)
• 論理和に近いが,1xor1=0
– 表記は,P xor Q や P  Q など.
– exclusive or
P
Q
– PとQが異なれば 1
PとQが同じななら 0
0
0
– P Q R
0
1
=(P  Q)  R
=P  (Q  R)
1
0
1
1
P∨Q
0
1
1
0
論理和に近いが排他的? H-15
否定論理和 (nor)
• P nor Qは, not(P or Q)
• 本講義では扱わない
P
Q
P∨Q
0
0
1
0
1
0
1
0
0
1
1
0
H-16
否定論理積 (nand)
• P nand Qは, not(P and Q)
– nandを組み合わせれば,
not,and,orなど
P
全てを表現できる.
• 本講義では扱わない
Q
P∨Q
0
0
1
0
1
1
1
0
1
1
1
0
H-17
“or” と 日本語“または”
• 「国語90点以上」または「算数90点以上」
の人は授業料免除です.
– 両方満たした人も含む.“or”と同じ.
– 「少なくとも1個が成り立てば」の意味.
• コーヒーまたは紅茶がつきます.
– 両方つくことはない.これは“xor”と同じ.
• 電車代またはガソリン代を請求します.
– 両方請求することはない.“xor”と同じ.
H-18
Bool代数
• ¬(¬P)=P
2回反転すると,元に戻る.
• ドモルガンの法則
¬(P∧Q) = (¬P)∨(¬Q)
¬(P∨Q) = (¬P)∧(¬Q)
H-19
Bool代数
• P  Qは,(Pに対して,  Qが施されたと考える)
– Qが0ならP. Qが1なら¬P.
つまり,  0は値を保持,  1は値を反転.
– P  Q  R  S  Tは
1が登場するたびに反転するので,
1が偶数個の場合→計算結果は 0
1が奇数個の場合→計算結果は 1
H-20
論理回路
• 0 と 1 の情報の演算を処理する回路.
– 計算機, CPUは基本的にこれら回路の組み合
わせ.これらを組み合わせると計算ができる.
– ディジタル(電子)回路などと呼ばれる
H-21
論理回路
not
and
or
xor
H-22
論理回路
x
z
x
y
not
z
or
入力
x
出力
z
入力
x
入力
y
出力
z
0
1
0
0
0
1
0
0
1
1
1
0
1
1
1
1
左から0を入れると,
右から1が出てくる回路.
H-23
論理回路
x
y
z
x
y
z
xor
and
入力
x
入力
y
出力
z
入力
x
入力
y
出力
z
0
0
0
0
0
0
0
1
0
0
1
1
1
0
0
1
0
1
1
1
1
1
1
0
H-24
論理回路の例
• 下の回路に(左から) 1 と 0 を入力すると,
(右から) 1 が出力される.
1
1
or
0
1
1
1
1
0
0
and
0
0 not
and
1
1
H-25
加算器
• not,or,andを組み合わせると“加算処
理装置”を作ることができる.
• 2進数の加算器を考える.
– 例えば,
10進数:
5 +
1 =
6
2進数: 101 + 001 = 110
H-26
半加算器 (half adder)
• 1桁の2進数 A と B を入力し,
その和を出力する回路考える.
– ただし,下の桁からの繰り上がりは考えない.
• 1桁の2進数は,真偽値(0か1)が1個.
• つまり,2個の真偽値を入力すると,
2個の真偽値が出力される回路.
– 注意:桁が繰り上がる事があるので ,
1桁同士の加算結果は,2桁になることがある.
H-27
半加算器 (half adder)




0
0
1
1
と
と
と
と
0
1
0
1
の加算→ 0
の加算→ 1
の加算→ 1
の加算→10
入力
A
入力
B
出力
C
出力
S
0
0
1
1
0
1
0
1
0
0
0
1
0
1
1
0
(上桁
(上桁
(上桁
(上桁
0,
0,
0,
1,
下桁
下桁
下桁
下桁
0)
1)
1)
0)
上の桁の出力結果をC,
下の桁の出力結果をS
とるす.
上の桁は繰り上がり
(Carry Out)と呼ばれる.
H-28
半加算器 (上の桁)
入A 入B 出C
0
0
1
• A と B の両方が 1 のときのみ, 1
C が 1 となる.
A
B
and
0
1
0
1
0
0
0
1
C
H-29
半加算器 (下の桁)
入A 入B
0
0
1
• (A と B の少なくとも片方が 1 ) 1
かつ (“A と B の両方が 1”でない)
が成り立つとき,S が 1 と考える.
A
0
1
1
0
or
and
B
0
1
0
1
出S
and
S
not
H-30
半加算器
• 2入力の加算器が完成
A
or
入A 入B 出C 出S
0
0
1
1
and
0
1
0
1
0
0
0
1
0
1
1
0
S
not
B
and
C
H-31
全加算器 (full adder)
• 1桁の加算器を桁数分組み合わせれば,
n桁の2進数同士の加算器が作成可能.
• ただし,一番下の桁以外は,
下の桁からの繰り上がりを
1 Carry
考慮するする必要がある.
繰り上がりも考慮し,
結局この3個を
足す必要がある.
1
+) 0
1
0
0
1
1
1
0
H-32
全加算器 (full adder)
• 1桁の2進数3個 A と B と c を入力し,
その和を出力する回路考える.
出力は,繰り上がり と その桁 の2個.
入力
A
入力
B
入力
C0
出力
C1
出力
S
0
0
0
0
1
1
1
1
0
0
1
1
0
0
1
1
0
1
0
1
0
1
0
1
0
0
0
1
0
1
1
1
0
1
1
0
1
0
0
1
H-33
全加算器 (full adder)
A
or
and
S
not
B
and
C
先ほど作成した上の回路を,
“Half Adder”という一つの回路と定義する.
Half
Adder
S
C
“Half Adder”は, 2入力2出力の回路.
内部構成は忘れて良い.
原理が分からなくても使えればよい.
入出力の関係さえ理解していればよい.
Black Boxという.
H-34
全加算器 (full adder)
A
B
Half S
Adder
C
Half S
Adder
C
S
C
or
C
H-35
4桁2進数同士の加算回路
• 4桁2進数 A3A2A1A0 と B3B2B1B0 を
入力し,その加算結果,
S4S3S2S1S0を出力する回路を考える.
• ただし,A3A2A1A0 は
A3*8 + A2*4 + A1*2 + A0
H-36
4桁2進数同士の加算回路
• 先ほど作成した下の回路を,“Full
Adder”という一つの回路と定義する.
A
B
C
Half S
Adder
C
Half S
Adder
C
or
S
A Full
B Adder
C
C
S
C
入力のA,B,Cは
省略する.
入れ替えても
結果は同一
H-37
4桁2進数同士の加算回路
A0B0
A1B1
A2B2
A3B3
FA
FA
FA
HA
C
C
C
C
S
S
S
S
S0
S1
S2
S3
S4
H-38
C言語で回路を模倣
• not回路
– 1入力1出力の関数で模倣できる.
入力値を反転した物を返す.
char not(char a){
if( a == 1 ){
return 0;
} else {
return 1;
}
}
H-39
C言語で回路を模倣
• or回路
– 2入力1出力の関数で模倣できる.
2個の入力の論理和演算結果を返す.
char or(char a, char b){
if( a == 1 || b == 1 ){
return 1;
} else {
return 0;
}
}
H-40
C言語で回路を模倣
• and回路
– 2入力1出力の関数で模倣できる.
2個の入力の論理積演算結果を返す.
char and(char a, char b){
if( a == 1 && b == 1 ){
return 1;
} else {
return 0;
}
}
H-41
A
or
B
and
C
char lc00(char a, char b, char, c){
return and(or(a,b),c);
}
H-42
A
B
or
and
Y
X
not
and
S
Z
char ha_s(char a, char b){
char x, y, z;
x = or(a,b);
y = and(a,b);
z = not(y);
return and(x,z);
}
H-43
A
B
or
and
Y
X
not
and
S
Z
char ha_s(char a, char b){
return
and(
or(a,b), not(and(a,b))
);
}
1文で書くと.
H-44
A
B
and
C
char ha_c(char a, char b){
return and(a,b);
}
H-45
A
B
Half S
Adder
C
X
Ci
Half S
Adder
C
or
S
Z
Co
Y
char fa_s(char a, char b, char ci){
char x;
x = ha_s(a,b);
return ha_s(x,c);
}
H-46
A
B
Half S
Adder
C
X
Ci
Half S
Adder
C
or
S
Z
Co
Y
char fa_c(char a, char b, char ci){
char x, y, z;
x = ha_s(a,b);
y = ha_c(a,b);
z = ha_c(x,c);
return or(z,y);
}
H-47
4桁2進数同士の加算回路
A0B0
A1B1
A2B2
A3B3
FA
FA
FA
HA
C X
C
Y
C
Z
C
S
S
S
S
S0
S1
S2
S3
S4
H-48
void adder( char a3, char a2, char a1, char a0,
char b3, char b2, char b1, char b0){
char s4, s3, s2, s1, s0;
char x, y, z;
s0 = ha_s(a0,b0);
x = ha_c(a0,b0);
4桁2進数同士の
加算回路
s1 = fa_s( a1, b1, x);
y = fa_c( a1, b1, x);
s2 = fa_s( a2, b2, y);
z = fa_c( a2, b2, y);
注意:
本関数は,
演算結果を返すのではなく
演算結果を表示する.
s3 = fa_s( a3, b3, z);
s4 = fa_c( a3, b3, z);
printf("%d%d%d%d + ", a3, a2, a1, a0);
printf("%d%d%d%d = ", b3, b2, b1, b0);
printf("%d%d%d%d%d\n", s4, s3, s2, s1, s0);
}
H-49
練習 B
• 下記の回路に左から0と1を入力すると,
右から0と1のどちらが出力されるか?
0
not
or
or
1
S
and
H-50
解答 B
0
0
or
1
1 not
1
0
0
1
0
1
and
0
0
or
0
S
H-51