병렬 알고리즘-구조
알고리즘을 제대로 적용하려면 적절한 데이터 구조를 선택하는 것이 매우 중요합니다. 데이터 구조에서 수행되는 특정 작업은 다른 데이터 구조에서 수행되는 동일한 작업에 비해 시간이 더 오래 걸릴 수 있기 때문입니다.
Example− 배열을 이용하여 집합 의 i 번째 원소에 접근하기 위해서는 일정한 시간이 걸리지 만 연결 목록을 이용하면 동일한 연산을 수행하는 데 필요한 시간이 다항식이 될 수 있습니다.
따라서 데이터 구조의 선택은 수행 할 아키텍처와 작업 유형을 고려하여 이루어져야합니다.
다음 데이터 구조는 일반적으로 병렬 프로그래밍에 사용됩니다.
- 연결된 목록
- Arrays
- Hypercube 네트워크
연결된 목록
연결 목록은 포인터로 연결된 0 개 이상의 노드가있는 데이터 구조입니다. 노드는 연속적인 메모리 위치를 차지할 수도 있고 차지하지 않을 수도 있습니다. 각 노드에는 2 개 또는 3 개의 부분이 있습니다.data part 데이터를 저장하고 나머지 두 개는 link fields이전 또는 다음 노드의 주소를 저장합니다. 첫 번째 노드의 주소는 다음과 같은 외부 포인터에 저장됩니다.head. 다음으로 알려진 마지막 노드tail, 일반적으로 주소를 포함하지 않습니다.
연결 목록에는 세 가지 유형이 있습니다.
- 단일 연결 목록
- 이중 연결 목록
- 순환 연결 목록
단일 연결 목록
단일 연결 목록의 노드에는 데이터와 다음 노드의 주소가 포함됩니다. 호출 된 외부 포인터head 첫 번째 노드의 주소를 저장합니다.
이중 연결 목록
이중 연결 목록의 노드에는 데이터와 이전 및 다음 노드의 주소가 모두 포함됩니다. 호출 된 외부 포인터head 첫 번째 노드의 주소와 호출 된 외부 포인터를 저장합니다. tail 마지막 노드의 주소를 저장합니다.
순환 연결 목록
순환 연결 목록은 마지막 노드가 첫 번째 노드의 주소를 저장했다는 점을 제외하고는 단일 연결 목록과 매우 유사합니다.
배열
배열은 유사한 유형의 데이터를 저장할 수있는 데이터 구조입니다. 1 차원 또는 다차원 일 수 있습니다. 배열은 정적으로 또는 동적으로 만들 수 있습니다.
에 statically declared arrays, 배열의 차원과 크기는 컴파일 시점에 알려져 있습니다.
에 dynamically declared arrays, 배열의 차원과 크기는 런타임에 알려집니다.
공유 메모리 프로그래밍의 경우 배열을 공통 메모리로 사용할 수 있고 데이터 병렬 프로그래밍의 경우 하위 배열로 분할하여 사용할 수 있습니다.
Hypercube 네트워크
Hypercube 아키텍처는 각 작업이 다른 작업과 통신해야하는 병렬 알고리즘에 유용합니다. Hypercube 토폴로지는 링 및 메시와 같은 다른 토폴로지를 쉽게 포함 할 수 있습니다. n-cubes라고도합니다.n차원의 수입니다. 하이퍼 큐브는 재귀 적으로 구성 될 수 있습니다.