디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.12 04:48:26
조회 96 추천 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 - -
공지 이미지 댓글 기능 안내 운영자 25/08/20 - -
AD 전자제품 세일쇼! 운영자 25/08/19 - -
2880897 니들 정치인하고싶냐? [3] 헬마스터갤로그로 이동합니다. 08.12 94 1
2880896 PM님이 사무실에서 일본어 공부하는 저를 발견하셨어요 [2] 아스카영원히사랑해갤로그로 이동합니다. 08.12 111 1
2880891 그냥 어느 레이어에 따라서 필요한 멘탈 모델이 달라진다는게 핵심이지 ㅆㅇㅆ(124.216) 08.12 45 0
2880889 애초에 프로그래밍은 유일한 절대적 최적해가 아닌 ㅆㅇㅆ(124.216) 08.12 71 0
2880888 한국에서는 논리적 사고를 수학적 사고랑 동치화해서 그래 ㅆㅇㅆ(124.216) 08.12 58 0
2880887 수학적 사고력이라는게 뭘까 [1] 프갤러(211.186) 08.12 58 0
2880886 토스는 개발자의 회사보다는 기획자의 회사가 더 맞지 않나 싶은데 난 [2] ㅆㅇㅆ(124.216) 08.12 132 1
2880883 토스 다크패턴은 진짜 UI/UX 설계중에서도 악질중에 악질임 [3] ㅆㅇㅆ(124.216) 08.12 131 0
2880881 토스부러윤이유 [2] 밀우갤로그로 이동합니다. 08.12 96 0
2880880 토스 다크패턴 느낀게 [2] 루도그담당(211.184) 08.12 106 0
2880874 네이버나 이런 애들은 뭔가 그래도 오픈소스로 혁신기술 만들어팔잖아 [4] ㅆㅇㅆ(124.216) 08.12 107 0
2880872 토스의 서사라는게 그건 10년대 초반이나 통했지 지금은 20년대 중반인데 ㅆㅇㅆ(124.216) 08.12 76 0
2880871 내가 느끼는 것은 구직 시장에서 서사를 어떻게 파느냐가 중요한듯 ㅆㅇㅆ(124.216) 08.12 76 0
2880868 왜 애들은 토스를 가고 싶어할까. [4] ㅆㅇㅆ(124.216) 08.12 146 0
2880864 구강. 편광. 표리의 틈새. 까마귀와 성명 공기역학갤로그로 이동합니다. 08.12 48 0
2880862 토뱅은 또갑자기 집중채용이네 [3] 밀우갤로그로 이동합니다. 08.12 137 0
2880856 ㅆㅇㅆ 게이 요즘 cs 위주 글 안 써줘서 ㅁㅈㅎ [2] 루도그담당(211.184) 08.12 89 0
2880854 너는 따땃한 회사의 응딩이에 붙어있지만 나는 고객한테 구걸해야한다 [4] ㅆㅇㅆ(124.216) 08.12 82 0
2880853 몇 년만에 왔는데 멍유 아직도 살아있었네 [1] ㅇㅇ(211.185) 08.12 66 0
2880852 구직단념자가 왜 되는지 알것같다 [3] ㅇㅇ(223.38) 08.12 107 0
2880851 당연히 명세랑 구조는 내가 직접짜지 게이야 [2] ㅆㅇㅆ(124.216) 08.12 60 0
2880850 나는 현존하는 모든 LLM아레나에 있는 모든 모델 다쓰고 있는데 [2] ㅆㅇㅆ(124.216) 08.12 82 0
2880848 걍 질문을 존나 상세하게 해야하는게 귀찮음 [2] 루도그담당(211.184) 08.12 80 0
2880846 운동 다시 시작해야 하는데 좆됐노 프갤러(61.79) 08.12 51 0
2880845 나는 api 쓰면 비용 너무 많이 나와서 에이전트도 꺼둔 사람임 ㅆㅇㅆ(124.216) 08.12 75 0
2880842 GPT 질문을 제대로 하기위해서 질문을 래퍼하고 있는 이게 맞는거냐? [2] ㅆㅇㅆ(124.216) 08.12 67 0
2880840 일단 GPT 5용 시스템 카드 읽고 질문 프롬프트 템플릿 만듬 ㅆㅇㅆ(124.216) 08.12 45 0
2880839 지피티 이거 처음 나왔을땐 충격이였는데 [1] 루도그담당(211.184) 08.12 82 0
2880836 GPT 5 시스템 카드 읽어보고 어떻게 최고수준의 질문할지 생각해봄 [2] ㅆㅇㅆ(124.216) 08.12 90 1
2880833 GPT 5 이거 라우팅 모델이라는게 결국 질문을 잘해야 좋은 모델 쓰게 [2] ㅆㅇㅆ(124.216) 08.12 77 0
2880830 아 공부 며칠간 쉴까 [3] 루도그담당(211.184) 08.12 64 0
2880829 상사가 그냥이란건 없다. 모든 것엔 이유가 있어야 된다길래 [3] 프갤러(211.36) 08.12 82 0
2880828 나는 좀 궁금한게 통진당 해산이 됐으면 당연히 국힘도 해산되야하지 않나. [5] ㅆㅇㅆ(124.216) 08.12 81 0
2880825 집에 가고싶다 루도그담당(211.184) 08.12 53 0
2880823 왓더버거~ 프갤러(61.79) 08.12 49 0
2880822 프로그래밍은 어차피 멘탈 모델인 이상 인식이 다를 수밖에 없음 [4] ㅆㅇㅆ(124.216) 08.12 70 0
2880821 모든것은 헬조센 한마디로 설명이 가능하다 프갤러(61.79) 08.12 39 0
2880820 저 소비 많나요? 넥도리아(223.38) 08.12 46 0
2880819 전한길씨 스스로를 전한길이라 칭하는거 재밋지않냐? [2] 헬마스터갤로그로 이동합니다. 08.12 83 0
2880818 추상화란 무엇일까 루도그담당(211.184) 08.12 62 0
2880817 재명 지원금 마지막으로 짜장먹으러나왔는데 [5] ㅆㅇㅆ찡갤로그로 이동합니다. 08.12 80 0
2880816 근데 개발 재밌잖아 [2] ㅆㅇㅆ찡갤로그로 이동합니다. 08.12 78 0
2880815 맨날 이렇게 일 많았음 좋겠다 ㅆㅇㅆ찡갤로그로 이동합니다. 08.12 55 0
2880814 오랜만에 일많네 [3] ㅆㅇㅆ찡갤로그로 이동합니다. 08.12 65 0
2880813 30대면 몰라도 20대 고졸들은 처참하네 ㅇㅇ(211.235) 08.12 82 0
2880812 SI 갈까 생각하는 사람들은 봐라 [1] 프갤러(180.71) 08.12 328 1
2880809 챗gpt 플러스랑 제미나이 프로 써본 사람?? 프갤러(112.219) 08.12 56 0
2880808 개발 좀 하다보면 착각하기 딱 좋음 [2] ㅇㅇ갤로그로 이동합니다. 08.12 130 0
2880807 개발이 재밌다고하는 새끼들 특징이 뭐냐면 [2] ㅇㅇ갤로그로 이동합니다. 08.12 105 0
2880805 고졸 앰생 입장에선 개발자가 최선의 선택인듯 [2] 프갤러(106.101) 08.12 82 0
뉴스 사천시, 제13회 삼천포아가씨 가요제 왕중왕전 개최 디시트렌드 08.20
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2