디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

Ada 프로그래밍: 4.2.5 병렬 루프 (Ada 2022)

나르시갤로그로 이동합니다. 2025.08.12 04:48:26
조회 149 추천 0 댓글 0

4.2.5 병렬 루프 (Ada 2022)

Ada 2022는 병렬 루프를 도입하여, for 루프의 반복들이 여러 논리적 제어 스레드에 의해 동시에 실행될 수 있게 합니다. 이 기능은 루프의 작업 부하를 분산시켜 멀티코어 프로세서에서 계산 집약적인 작업의 성능을 크게 향상시킬 수 있습니다.

구현 참고: 병렬 루프 기능은 Ada 2022 표준에 추가된 사항입니다. GCC 15 기준으로, GNAT 컴파일러는 아직 parallel키워드를 지원하지 않습니다. 따라서 다음 구문과 예제들은 Ada 2022 명세에 기반한 것이며, 현재의 GNAT 버전으로는 컴파일되지 않을 수 있습니다.

병렬 루프는 표준 for 루프 구문 앞에 오는 parallel 키워드로 표시됩니다. 런타임 시스템은 루프의 반복들을 하나 이상의 청크(chunk)로 분할하며, 각 청크는 별도의 논리적 스레드에 의해 처리됩니다. 어떤 형태의 병렬 루프에서도 reverse 키워드는 허용되지 않는다는 점에 유의해야 합니다.

Ada 2022는 세 가지 주요 형태의 병렬 반복을 정의합니다.

1. 이산 범위에 대한 병렬 for 루프

이것은 병렬 루프의 가장 직접적인 형태로, 이산 범위(예: 정수 또는 열거형 범위)에 대한 반복이 병렬화됩니다.

구문:

parallel for loop_parameter in discrete_subtype_definition loop
  -- 일련의 문장들
end loop;

예제:

-- 각 인덱스에 대한 독립적인 계산을 병렬로 수행
parallel for i in 1 .. 100 loop
  process_data (i);
end loop;

2. 배열 및 컨테이너를 위한 병렬 반복자

이 형태는 배열의 원소나 병렬 반복자 인터페이스를 제공하는 모든 컨테이너 타입(특히, Ada.Iterator_Interfaces.Parallel_Iterator에서 파생된 타입)에 대한 병렬 반복을 허용합니다.

구문:

parallel for element of Iterable_Container loop
  -- 일련의 문장들
end loop;

예제 (병렬 컴포넌트 반복): 이 예제는 2차원 배열의 각 원소를 병렬로 두 배로 만듭니다.

-- Board는 Float 타입의 2차원 배열
parallel for element of Board loop
  element := element * 2.0;
end loop;

3. 병렬 절차적 반복자

이 고급 형태는 프로시저를 사용하여 반복을 제어합니다. 지정된 프로시저가 Parallel_Iterator => True 애스펙트를 가지고 있다면 루프는 병렬화됩니다. 이는 프로시저 자체가 여러 스레드에서 루프 본문을 안전하게 호출하도록 설계되었음을 나타냅니다.

구문:

parallel for (parameters) of Iterator_Procedure loop
  -- 일련의 문장들
end loop;

청크 명세 (Chunk Specification)

프로그래머는 chunk_specification을 제공하여 작업 부하가 어떻게 분할되는지에 영향을 줄 수 있습니다. 이는 병렬 실행의 세분성을 미세 조정할 수 있게 합니다. 청크를 명시하는 두 가지 방법이 있습니다.

  1. 최대 개수로: 정수 표현식이 최대 청크 수를 정의합니다.
  2. 청크 서브타입으로: 이산 서브타입이 청크의 집합을 정의합니다. 이 형태는 또한 루프 내에서 특정 청크를 식별하는 데 사용할 수 있는 청크 파라미터를 암묵적으로 선언하여, 결과를 분할하는 데 유용합니다.

예제 (서브타입을 사용한 청크 명세): 이 루프는 최대 8개의 청크를 사용하여 부분 계산을 병렬로 수행합니다. Chunk_Number 타입의 Chunk 파라미터는 루프 내에서 어떤 스레드가 데이터의 어느 부분을 작업하고 있는지 구별하는 데 사용할 수 있습니다.

declare
  subtype Chunk_Number is Natural range 1 .. 8;
  partial_sum : array (Chunk_Number) of Natural := (others => 0);
  grid        : array (1 .. 1_000) of Boolean;
  -- ... grid가 초기화됨
begin
  parallel (chunk in Chunk_Number)
  for i in grid'range loop
    if grid(i) then
      -- 이 연산은 스레드-안전해야 함. 예제는 간결함을 위해 '@'를 사용했지만,
      -- 실제 구현에서는 스레드-안전한 업데이트를 위해 원자적 연산이나
      -- 보호 객체가 필요할 것임
      partial_sum(chunk) := @ + 1;
    end if;
  end loop;
  -- ... partial_sum으로부터 최종 결과를 집계
end;



https://nimfsoft.art/ko/books/ada-programming/#425-%EB%B3%91%EB%A0%AC-%EB%A3%A8%ED%94%84-ada-2022

 



추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 영포티룩도 멋지게 소화할 것 같은 40대 스타는? 운영자 25/10/27 - -
AD 할로윈 슈퍼위크~!! 운영자 25/10/23 - -
2882376 좇센 커뮤 눈팅하면 인간의 특성 특히 좇센징에 대해서 연구할수있음 뒷통수한방(1.213) 08.18 137 0
2882375 단순 SQL이 아니라 API면 권한,토큰 인증이랑 제한 수치도 [3] ㅆㅇㅆ(124.216) 08.18 143 0
2882374 숨고에서 외주는 외주 등록말고도 코딩/레슨 서비스에도 등록해야함 [8] ㅆㅇㅆ(124.216) 08.18 171 0
2882373 우유먹자 주마다 1잔 넥도리아(223.38) 08.18 159 0
2882369 완공되면 엄청 좋을듯 경강선 넥도리아(222.233) 08.18 122 0
2882368 C++ 복기중이시다 루도그담당(118.235) 08.18 145 0
2882367 SQL 구축된거 API로 바꾸는게 왜 비싼건질 모르겠다 [4] 프갤러(59.25) 08.18 169 0
2882365 제조 it는 별론가 프갤러(39.7) 08.18 131 0
2882364 흠 앞으로 CS지식으로 가득찬 프갤을 재건해야겠군 [2] 네오커헠(1.237) 08.18 257 1
2882363 다이소 니퍼 수준 [1] 뒷통수한방(1.213) 08.18 139 0
2882362 넥도리아 김건희 특검사무실에 갈까 생각중... 넥도리아(119.195) 08.18 159 0
2882358 나 메이플할시간에공부하면 자기보다성공할거같다고 디코대화내역삭제당함 공기역학갤로그로 이동합니다. 08.18 142 0
2882357 OS커널구조는 임베디드개발자 에겐 익숙한 개념이네 네오커헠(1.237) 08.18 210 0
2882355 조언좀.. [1] ㅇㅇ(223.38) 08.18 161 0
2882354 흠 나는 로컬통신 네임드파이프+메시지팩으로하는데 네오커헠(1.237) 08.18 173 0
2882353 Jvm 분석해보는데 신기하네 루도그담당(118.235) 08.18 159 0
2882350 하루에 오조오억줄 감사의 코딩 공기역학갤로그로 이동합니다. 08.18 162 0
2882348 고물들 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 08.18 150 0
2882347 코딩 입문 질문드립니다...(간단한 웹사이트 만드는 정도) [3] 프갤러(110.11) 08.18 138 0
2882344 태연 ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 08.18 150 0
2882343 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.18 113 0
2882341 저 졸업작픔 주제 추천좀 [7] 공기역학갤로그로 이동합니다. 08.18 190 0
2882340 자격증은 따볼까 생각중이다. 근데 3개월전 검색했던 자격증이 뭔지 몰라요 넥도리아(14.35) 08.18 126 0
2882336 c#이 c++++이었음? [2] 뉴진파갤로그로 이동합니다. 08.18 195 0
2882335 다시 맑아졌다. 넥도리아(14.35) 08.18 132 0
2882333 짱깨들 코딩 개잘하노 [2] 뉴진파갤로그로 이동합니다. 08.18 207 0
2882332 sql 파일 포맷인거 처음암 뉴진파갤로그로 이동합니다. 08.18 157 0
2882330 당월 익월 이런 용어는 왜쓰는거냐? [6] 헬마스터갤로그로 이동합니다. 08.18 190 0
2882329 빌게이츠 한국오노 ㅇ.ㅇ(59.151) 08.18 126 0
2882328 전략은 분석선행 필수 ♥냥덩이♥갤로그로 이동합니다. 08.18 135 0
2882327 나의 웹앱땔깜개발자들과의 싸움 이렇게 쉽게 이기면 안되는데 [1] 네오커헠(1.237) 08.18 260 0
2882326 숨고 코딩 강사들 보면 [1] 루도그담당(118.235) 08.18 183 0
2882325 4050 썩은물로 부패하는 한국 ♥냥덩이♥갤로그로 이동합니다. 08.18 180 0
2882320 인지과학조져라 [4] 손발이시립디다갤로그로 이동합니다. 08.18 156 0
2882319 자바 문법 GR 같아서 못 해 먹겠네 증말. [4] 프갤러(59.16) 08.18 180 0
2882317 나님 왤케 특별하실깡? ♥냥덩이♥갤로그로 이동합니다. 08.18 166 0
2882316 나님 끙야즁❤+ ♥냥덩이♥갤로그로 이동합니다. 08.18 138 0
2882315 토요코키즈 ♥냥덩이♥갤로그로 이동합니다. 08.18 151 0
2882311 일본인을 한국의 기준으로 판단이 힘든 이유 프로외노자갤로그로 이동합니다. 08.18 190 1
2882310 동일노동 동일임금이 잘 되려면 노동강도 조사가 잘 되야 발명도둑잡기갤로그로 이동합니다. 08.18 169 0
2882309 건설업종 안전관리자가 직업에 회의감 발명도둑잡기갤로그로 이동합니다. 08.18 153 0
2882308 2030 줄고 4050 고인물천국된 판교 - 뉴스 ㅇㅇ(183.101) 08.18 175 0
2882307 이번달은 안정권이다 씨발ㅋㅋㅋ 저번달 통수만 안당했어도 ㅆㅇㅆ(124.216) 08.18 155 0
2882306 쿠팡 개발자는 노동자 죽이는 앱 개발 하다가 [6] 발명도둑잡기갤로그로 이동합니다. 08.18 203 0
2882305 오늘도 외주하나 깔쌈하게 끝냈다 [1] ㅆㅇㅆ찡갤로그로 이동합니다. 08.18 162 0
2882304 쿠팡 노조 가입 희망자 발명도둑잡기갤로그로 이동합니다. 08.18 138 0
2882303 음기 충전 발명도둑잡기갤로그로 이동합니다. 08.18 133 0
2882302 AI 는 패턴매칭 맞지만, 알려지지않은 패턴도 거의없잖아? 피치(183.101) 08.18 150 0
2882301 ㄹㅇ 아빠회사가 최고다 [1] 프갤러(1.226) 08.18 175 0
2882299 이불 안에서 태블릿 하는 보니 발명도둑잡기갤로그로 이동합니다. 08.18 116 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2