디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.12 04:48:26
조회 94 추천 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
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 생활고나 번아웃 고백이 와닿지 않는 스타는? 운영자 25/08/18 - -
AD 전자제품 세일쇼! 운영자 25/08/19 - -
2881366 님이 사용 중인 어플들 러스트가 아니라 C/C++로 만든거다 나르시갤로그로 이동합니다. 08.14 76 0
2881365 납품 준비 하나 끝. 아 존나 힘들다 ㅆㅇㅆ(124.216) 08.14 51 0
2881364 식당 술값이 폭리면? 주식 수익은 부당 이익이냐? 나르시갤로그로 이동합니다. 08.14 52 0
2881363 식당 술값이 폭리면? 개발비도 폭리냐? 나르시갤로그로 이동합니다. 08.14 54 0
2881360 GC없는, (메모리 등) 안전 대세 언어: Ada 나르시갤로그로 이동합니다. 08.14 76 0
2881359 러스트가 확실히 대세가 아닌 이유 나르시갤로그로 이동합니다. 08.14 84 0
2881351 개인적으로 개발 세부 구현사항은 문서화 안하지만 전반적으로 ㅆㅇㅆ(124.216) 08.14 73 0
2881348 그리고 기본적으로 마소 예제는 나름대로 기술 분석 해두는게 좋더라 [2] ㅆㅇㅆ(124.216) 08.14 100 0
2881347 뇌과학적으로 고소득층 사람들은 물건보다 '이것'에 집착합니다 발명도둑잡기갤로그로 이동합니다. 08.14 54 0
2881346 아인슈타인의 ‘그 논문’ 50년간 묻혔다가 과학계 레전드로 역주행 발명도둑잡기갤로그로 이동합니다. 08.14 61 0
2881345 나는 대부분 내가 만들어보거나 해본 것들 어지간하면 적어둠 [8] ㅆㅇㅆ(124.216) 08.14 110 0
2881344 나는 크롤링 전문이 아니라서, 그냥 기초 원리만 아는거. [3] ㅆㅇㅆ(124.216) 08.14 95 0
2881343 아씨발나스닥왜자꾸올라개새끼야!!!!!!! [3] 아스카영원히사랑해갤로그로 이동합니다. 08.14 92 0
2881342 웹 크롤링 뷰티풀 스프 사용하는 방법 [2] ㅆㅇㅆ(124.216) 08.14 95 0
2881341 나도 어제 좆개판으로 크롤러 짯는데 [2] 루도그담당(58.239) 08.14 81 0
2881340 R 스크립트 짜면서 느끼는데 유독 파이썬 R은 GPT가 잘짜 ㅆㅇㅆ(124.216) 08.14 67 0
2881338 개발 항상 하면 느끼지만 가장 큰 적은 '돌아가는데 굳이..' 이거임 [2] ㅆㅇㅆ(124.216) 08.13 93 0
2881337 그 약이라는게 그렇게 끊기가 힘듬?? 계속 생각나?? [7] ㅇㅇ(223.39) 08.13 113 0
2881336 파이썬 질문있습니다 [3] 프갤러(211.105) 08.13 88 0
2881335 ㅆㅇㅆ님 이 글에 대해 의견좀 [1] 발명도둑잡기갤로그로 이동합니다. 08.13 89 0
2881331 내가 ai 안쓰는 이유 프갤러(121.139) 08.13 79 0
2881330 금융 로직의 문제는 뭐냐면 [1] 밀우갤로그로 이동합니다. 08.13 84 0
2881327 프갤러들 제국주의자 되는 과정 발명도둑잡기갤로그로 이동합니다. 08.13 55 0
2881326 이직했는데 존나어렵다 [1] 프갤러(220.70) 08.13 104 0
2881324 코테 문제들 어질어질하노 [1] 프갤러(220.85) 08.13 345 0
2881321 ㅇㅣ거 뭐냐 ㅇㅇ(211.105) 08.13 48 0
2881317 요즘 식당, 술집들 보면 술로 너무 폭리 취함 [16] 야옹아저씨갤로그로 이동합니다. 08.13 298 6
2881315 챗티씨에 코드 맡기고 나는 누워잇는중 [1] 헬마스터갤로그로 이동합니다. 08.13 73 0
2881312 도대체 영화관리를 어떻게 하길래 벌써 XX티비에 영화가 다떴지?? [6] ㅇㅇ(223.39) 08.13 93 0
2881309 잡코리아에서 AI 공모전으로 채용까지 하네요 프갤러(114.203) 08.13 55 0
2881302 퍼플렉시티랑 지피티 듀오로 가야하나 프갤러(61.79) 08.13 61 0
2881300 빌게이츠 이새낀 좇센 왜오는거?? 미국에선 총기맞을까봐 오는거?? 타이밍뒷통수한방(1.213) 08.13 56 0
2881297 카페 와이파이를 쓰면 안 되는 이유 발명도둑잡기갤로그로 이동합니다. 08.13 54 0
2881294 리눅스 예전에는 좋았던거 같은데 점점 성능이 내려가는느낌임 타이밍뒷통수한방(1.213) 08.13 59 0
2881292 형님들 엑셀 도움좀 주실분요 ㅠㅠ [1] 프갤러(180.69) 08.13 62 0
2881291 다들 웹사이트 만들 때 폰트 뭐 씀? ㅇㅇ갤로그로 이동합니다. 08.13 48 0
2881286 러스트가 확실히 요증 대세는 맞네 ㅇㅇ(125.179) 08.13 76 0
2881284 asp.net core 문서 보면서 공부나 해야겠다 루도그담당(58.239) 08.13 50 0
2881283 나도 MCP 만들어서 쓰는데 굳이 한국 토종 MCP 써야할 무언가인가 [4] ㅆㅇㅆ(124.216) 08.13 88 0
2881280 카카오 MCP 나옴 [1] 프갤러(121.133) 08.13 85 0
2881278 자바로 윈도우13 만드는중이누?? 윈도우 출시예정 또 미루누 ㅋㅋㅋㅋㅋㅋ 타이밍뒷통수한방(1.213) 08.13 59 0
2881277 윈도우12 출시예정 또 내년으로 미룸 ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅅㅂ ㅋㅋㅋㅋㅋ 타이밍뒷통수한방(1.213) 08.13 51 0
2881275 클라우드에서 개발하는 서비스 뭐가 좋나요 [3] 프갤러(58.29) 08.13 63 0
2881266 선생님들 m1맥북 엑셀사용 질문있습니다 ㅇㅇ갤로그로 이동합니다. 08.13 56 0
2881259 아 친구 새끼 씨발 [3] 루도그담당(58.239) 08.13 114 0
2881252 어 씨발 해물짬뽕수제비 왔네~ [4] 아스카영원히사랑해갤로그로 이동합니다. 08.13 90 0
2881250 VBA의 좋은점 하나 배웠다 이기 [2] 슈퍼막코더(126.204) 08.13 82 0
2881248 에이치PE, ‘디시인사이드’ 품는다 [시그널] 발명도둑잡기갤로그로 이동합니다. 08.13 89 0
2881247 코딩 잘하면 뭐하나. 프갤러(49.165) 08.13 63 0
2881246 정희햄은 재규어햄이 있어서 아름다운 평가 받는거지 [7] ㅆㅇㅆ(124.216) 08.13 76 0
뉴스 "너네는 약속 다 지키고 사냐?"…유승준, 유튜브 복귀 선언 디시트렌드 08.18
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2