디지털 회로-시프트 레지스터
우리는 하나의 플립 플롭이 1 비트의 정보를 저장할 수 있다는 것을 알고 있습니다. 여러 비트의 정보를 저장하려면 여러 개의 플립 플롭이 필요합니다. 바이너리 데이터를 보관 (저장)하는 데 사용되는 플립 플롭 그룹은 다음과 같이 알려져 있습니다.register.
레지스터가 비트를 오른쪽 또는 왼쪽으로 이동할 수있는 경우 shift register. 'N'비트 시프트 레지스터에는 'N'플립 플롭이 포함됩니다. 다음은 입력 적용 및 출력 액세스를 기반으로하는 네 가지 유형의 시프트 레지스터입니다.
- 직렬 입력-직렬 출력 시프트 레지스터
- 직렬 입력-병렬 출력 시프트 레지스터
- Parallel In − Serial Out 시프트 레지스터
- Parallel In − Parallel Out 시프트 레지스터
직렬 입력-직렬 출력 (SISO) 시프트 레지스터
직렬 입력을 허용하고 직렬 출력을 생성하는 시프트 레지스터는 직렬 입력 – 직렬 출력으로 알려져 있습니다. (SISO)시프트 레지스터. 그만큼block diagram 3 비트 SISO 시프트 레지스터의 그림은 다음과 같습니다.
이 블록 다이어그램은 3 개의 D 플립 플롭으로 구성됩니다. cascaded. 즉, 하나의 D 플립 플롭의 출력이 다음 D 플립 플롭의 입력으로 연결됩니다. 이러한 모든 플립 플롭은 동일한 클럭 신호가 각각에 적용되기 때문에 서로 동기화됩니다.
이 시프트 레지스터에서 가장 왼쪽에있는 D 플립 플롭의 입력에서 직렬로 비트를 보낼 수 있습니다. 따라서이 입력은 다음과 같이 호출됩니다.serial input. 클록 신호의 모든 포지티브 에지 트리거링에 대해 데이터는 한 단계에서 다음 단계로 이동합니다. 따라서 우리는 대부분의 D 플립 플롭의 출력에서 직렬로 비트를 수신 할 수 있습니다. 따라서이 출력은 다음과 같이 호출됩니다.serial output.
예
바이너리 정보를 전송하여 3 비트 SISO 시프트 레지스터의 작동을 살펴 보겠습니다. “011” 입력에서 직렬로 LSB에서 MSB로.
가장 왼쪽에서 가장 오른쪽까지 D 플립 플롭의 초기 상태가 $ Q_ {2} Q_ {1} Q_ {0} = 000 $라고 가정합니다. 우리는 이해할 수 있습니다working of 3-bit SISO shift register 다음 표에서.
클록의 양의 에지 없음 | 직렬 입력 | 질문 2 | 질문 1 | 질문 0 |
---|---|---|---|---|
0 | - | 0 | 0 | 0 |
1 | 1 (LSB) | 1 | 0 | 0 |
2 | 1 | 1 | 1 | 0 |
삼 | 0 (MSB) | 0 | 1 | 1 (LSB) |
4 | - | - | 0 | 1 |
5 | - | - | - | 0 (MSB) |
클록 신호가 없을 때 D 플립 플롭의 초기 상태는 $ Q_ {2} Q_ {1} Q_ {0} = 000 $입니다. 여기서 직렬 출력은 $ Q_ {0} $에서 나옵니다. 따라서 LSB (1)는 클럭의 3 번째 양의 에지 에서 수신되고 MSB (0)는 클럭의 5 번째 양의 에지 에서 수신됩니다 .
따라서 3 비트 SISO 시프트 레지스터는 유효한 출력을 생성하기 위해 5 개의 클록 펄스가 필요합니다. 마찬가지로N-bit SISO shift register 필요하다 2N-1 'N'비트 정보를 이동하기 위해 클럭 펄스.
직렬 입력-병렬 출력 (SIPO) 시프트 레지스터
직렬 입력을 허용하고 병렬 출력을 생성하는 시프트 레지스터는 직렬 입력 – 병렬 출력으로 알려져 있습니다. (SIPO)시프트 레지스터. 그만큼block diagram 3 비트 SIPO 시프트 레지스터의 그림은 다음과 같습니다.
이 회로는 계단식으로 연결된 3 개의 D 플립 플롭으로 구성됩니다. 즉, 하나의 D 플립 플롭의 출력이 다음 D 플립 플롭의 입력으로 연결됩니다. 이러한 모든 플립 플롭은 동일한 클럭 신호가 각각에 적용되기 때문에 서로 동기화됩니다.
이 시프트 레지스터에서 가장 왼쪽에있는 D 플립 플롭의 입력에서 직렬로 비트를 보낼 수 있습니다. 따라서이 입력은 다음과 같이 호출됩니다.serial input. 클록 신호의 모든 포지티브 에지 트리거링에 대해 데이터는 한 단계에서 다음 단계로 이동합니다. 이 경우 각 D 플립 플롭의 출력에 병렬로 액세스 할 수 있습니다. 그래서 우리는 얻을 것입니다parallel outputs 이 시프트 레지스터에서.
예
바이너리 정보를 전송하여 3 비트 SIPO 시프트 레지스터의 작동을 살펴 보겠습니다. “011” 입력에서 직렬로 LSB에서 MSB로.
D 플립 플롭의 초기 상태는 맨 왼쪽에서 맨 오른쪽으로 $ Q_ {2} Q_ {1} Q_ {0} = 000 $입니다. 여기서 $ Q_ {2} $ 및 $ Q_ {0} $는 각각 MSB 및 LSB입니다. 우리는 이해할 수 있습니다working of 3-bit SIPO shift register 다음 표에서.
클록의 양의 에지 없음 | 직렬 입력 | Q 2 (MSB) | 질문 1 | Q 0 (LSB) |
---|---|---|---|---|
0 | - | 0 | 0 | 0 |
1 | 1 (LSB) | 1 | 0 | 0 |
2 | 1 | 1 | 1 | 0 |
삼 | 0 (MSB) | 0 | 1 | 1 |
클록 신호가 없을 때 D 플립 플롭의 초기 상태는 $ Q_ {2} Q_ {1} Q_ {0} = 000 $입니다. 바이너리 정보“011” 클럭의 세 번째 양의 에지에 대한 D 플립 플롭의 출력에서 병렬로 획득됩니다.
따라서 3 비트 SIPO 시프트 레지스터는 유효한 출력을 생성하기 위해 3 개의 클록 펄스가 필요합니다. 마찬가지로N-bit SIPO shift register 필요하다 N 'N'비트 정보를 이동하기 위해 클럭 펄스.
병렬 입력-직렬 출력 (PISO) 시프트 레지스터
병렬 입력을 허용하고 직렬 출력을 생성하는 시프트 레지스터는 Parallel In-Serial Out으로 알려져 있습니다. (PISO)시프트 레지스터. 그만큼block diagram 3 비트 PISO 시프트 레지스터의 그림은 다음과 같습니다.
이 회로는 계단식으로 연결된 3 개의 D 플립 플롭으로 구성됩니다. 즉, 하나의 D 플립 플롭의 출력이 다음 D 플립 플롭의 입력으로 연결됩니다. 이러한 모든 플립 플롭은 동일한 클럭 신호가 각각에 적용되기 때문에 서로 동기화됩니다.
이 시프트 레지스터에서 우리는 parallel inputsPreset Enable을 1로 설정하여 각 D 플립 플롭으로 전환합니다. 클럭 신호의 모든 포지티브 에지 트리거에 대해 데이터는 한 단계에서 다음 단계로 이동합니다. 그래서 우리는serial output 가장 오른쪽의 D 플립 플롭에서.
예
바이너리 정보를 적용하여 3 비트 PISO 시프트 레지스터의 작동을 살펴 보겠습니다. “011” 사전 설정 입력을 통해 병렬로.
미리 설정된 입력은 Clock의 양의 에지 이전에 적용되기 때문에 D 플립 플롭의 맨 왼쪽에서 맨 오른쪽까지의 초기 상태는 $ Q_ {2} Q_ {1} Q_ {0} = 011 $입니다. 우리는 이해할 수 있습니다working of 3-bit PISO shift register 다음 표에서.
클록의 양의 에지 없음 | 질문 2 | 질문 1 | 질문 0 |
---|---|---|---|
0 | 0 | 1 | 1 (LSB) |
1 | - | 0 | 1 |
2 | - | - | 0 (LSB) |
여기서 직렬 출력은 $ Q_ {0} $에서 나옵니다. 따라서 LSB (1)는 클록의 양의 에지를 적용하기 전에 수신되고 MSB (0)는 클록의 두 번째 양의 에지 에서 수신됩니다 .
따라서 3 비트 PISO 시프트 레지스터는 유효한 출력을 생성하기 위해 두 개의 클록 펄스가 필요합니다. 마찬가지로N-bit PISO shift register 필요하다 N-1 'N'비트 정보를 이동하기 위해 클럭 펄스.
병렬 입력-병렬 출력 (PIPO) 시프트 레지스터
병렬 입력을 허용하고 병렬 출력을 생성하는 시프트 레지스터는 Parallel In-Parallel Out으로 알려져 있습니다. (PIPO)시프트 레지스터. 그만큼block diagram 3 비트 PIPO 시프트 레지스터의 그림은 다음과 같습니다.
이 회로는 계단식으로 연결된 3 개의 D 플립 플롭으로 구성됩니다. 즉, 하나의 D 플립 플롭의 출력이 다음 D 플립 플롭의 입력으로 연결됩니다. 이러한 모든 플립 플롭은 동일한 클럭 신호가 각각에 적용되기 때문에 서로 동기화됩니다.
이 시프트 레지스터에서 우리는 parallel inputsPreset Enable을 1로 설정하여 각 D 플립 플롭에 병렬 입력을 적용 할 수 있습니다. 이 두 가지는 비동기 입력입니다. 즉, 플립 플롭은 비동기 입력 값에 따라 해당 출력을 생성합니다. 이 경우 출력 효과는 클럭 전환과 무관합니다. 그래서 우리는parallel outputs 각 D 플립 플롭에서.
예
이진 정보를 적용하여 3 비트 PIPO 시프트 레지스터의 작동을 살펴 보겠습니다. “011” 사전 설정 입력을 통해 병렬로.
미리 설정된 입력은 Clock의 양의 에지 이전에 적용되기 때문에 D 플립 플롭의 맨 왼쪽에서 맨 오른쪽까지의 초기 상태는 $ Q_ {2} Q_ {1} Q_ {0} = 011 $입니다. 그래서 바이너리 정보“011” 클럭의 양의 에지를 적용하기 전에 D 플립 플롭의 출력에서 병렬로 획득됩니다.
따라서 3 비트 PIPO 시프트 레지스터는 유효한 출력을 생성하기 위해 제로 클럭 펄스가 필요합니다. 마찬가지로N-bit PIPO shift register 'N'비트 정보를 이동하기 위해 클록 펄스가 필요하지 않습니다.