Skip to content

Гусева Алена. Технология SEQ-MPI. Сумма элементов матрицы по столбцам. Вариант 12#11

Merged
allnes merged 7 commits intolearning-process:masterfrom
gsvval:guseva_a_matrix_sums
Dec 10, 2025
Merged

Гусева Алена. Технология SEQ-MPI. Сумма элементов матрицы по столбцам. Вариант 12#11
allnes merged 7 commits intolearning-process:masterfrom
gsvval:guseva_a_matrix_sums

Conversation

@gsvval
Copy link
Copy Markdown
Contributor

@gsvval gsvval commented Oct 29, 2025

Описание

  • Задача: Сумма элементов матрицы по столбцам
  • Вариант: 12
  • Технология: SEQ, MPI
  • Описание вашей реализации и отчёта.
    SEQ: Создается вектор сумм столбцом входной матрицы. Итерируясь по матрице, каждый очередной ее элемент добавляется к соответствующей сумме.
    MPI: Элементы входной матрицы поровну распределяются по процессам. Если число элементов не кратно числу процессов, нераспределенные n элементов дораспределяются по первым n процессам. Рассчитываются массивы количеств и смещений для MPI_Scatterv() и локальный сдвиг shift для корректного суммирования текущих элементов с соответствующими элементами локального результирующего вектора (для случаев, когда границы распределенных диапазонов не соответствуют границам строк матрицы). Когда локальные результаты вычислены, они собираются на корневом процессе функцией MPI_Reduce.

Чек-лист

  • Статус CI: Все CI-задачи (сборка, тесты, генерация отчёта) успешно проходят на моей ветке в моем форке
  • Директория и именование задачи: Я создал директорию с именем <фамилия>_<первая_буква_имени>_<короткое_название_задачи>
  • Полное описание задачи: Я предоставил полное описание задачи в теле pull request
  • clang-format: Мои изменения успешно проходят clang-format локально в моем форке (нет ошибок форматирования)
  • clang-tidy: Мои изменения успешно проходят clang-tidy локально в моем форке (нет предупреждений/ошибок)
  • Функциональные тесты: Все функциональные тесты успешно проходят локально на моей машине
  • Тесты производительности: Все тесты производительности успешно проходят локально на моей машине
  • Ветка: Я работаю в ветке, названной точно так же, как директория моей задачи (например, nesterov_a_vector_sum), а не в master
  • Правдивое содержание: Я подтверждаю, что все сведения, указанные в этом pull request, являются точными и достоверными

@gsvval
Copy link
Copy Markdown
Contributor Author

gsvval commented Oct 29, 2025

Отправила ПР, т.к. локально проверить не могу, по какой-то причине нет доступных раннеров:
https://github.com/gsvval/ppc-2025-processes-informatics/actions/runs/18918876144
image
@allnes
@aobolensk

@aobolensk
Copy link
Copy Markdown
Member

Отправила ПР, т.к. локально проверить не могу, по какой-то причине нет доступных раннеров: https://github.com/gsvval/ppc-2025-processes-informatics/actions/runs/18918876144 image @allnes @aobolensk

That could be related to the major outage of Microsoft Azure yesterday. Now that should be OK

@gsvval gsvval marked this pull request as draft October 30, 2025 15:45
@codecov-commenter
Copy link
Copy Markdown

codecov-commenter commented Oct 31, 2025

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 94.62%. Comparing base (92b24d3) to head (62eb173).
⚠️ Report is 1 commits behind head on master.

Additional details and impacted files
@@            Coverage Diff             @@
##           master      #11      +/-   ##
==========================================
+ Coverage   94.03%   94.62%   +0.59%     
==========================================
  Files          15       17       +2     
  Lines         486      540      +54     
  Branches      181      203      +22     
==========================================
+ Hits          457      511      +54     
  Partials       29       29              

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

@aobolensk aobolensk marked this pull request as ready for review October 31, 2025 18:31
@aobolensk aobolensk marked this pull request as draft October 31, 2025 18:31
Copy link
Copy Markdown

@chatgpt-codex-connector chatgpt-codex-connector Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

💡 Codex Review

Here are some automated review suggestions for this pull request.

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

Comment thread tasks/guseva_a_matrix_sums/mpi/src/ops_mpi.cpp Outdated
@gsvval gsvval marked this pull request as ready for review November 6, 2025 15:06
@gsvval gsvval force-pushed the guseva_a_matrix_sums branch from 5b308b8 to b57dede Compare November 6, 2025 15:09
@gsvval gsvval force-pushed the guseva_a_matrix_sums branch from b57dede to 0c5de27 Compare November 6, 2025 15:11
Update to current upstream after git reset
@gsvval
Copy link
Copy Markdown
Contributor Author

gsvval commented Nov 6, 2025

Подскажите, пожалуйста, как лишние Labels убрать? Делала git reset и push --force после pull'a хотфиксов. В списке измененных файлов только моя директория и мои файлы
@aobolensk

@aobolensk
Copy link
Copy Markdown
Member

aobolensk commented Nov 6, 2025

Подскажите, пожалуйста, как лишние Labels убрать? Делала git reset и push --force после pull'a хотфиксов. В списке измененных файлов только моя директория и мои файлы
@aobolensk

No worries, fixed manually

Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Report is not attached

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added with the last commit

Comment thread tasks/guseva_a_matrix_sums/tests/functional/main.cpp
if (rank == 0) {
GetOutput() = global_sums;
} else {
GetOutput() = {-1};
Copy link
Copy Markdown
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Output is not actually required to be initialized for other ranks

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed that

@gsvval gsvval requested a review from aobolensk November 8, 2025 15:07
local_sums[(i + shift) % columns] += local_buff[i];
}

std::vector<double> global_sums(columns, 0.0);
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Можно использовать MPI_Reduce сразу для GetOutput()

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed that

Comment on lines +27 to +29
auto &matrix = std::get<2>(GetInput());
auto &columns = std::get<1>(GetInput());
auto &rows = std::get<0>(GetInput());
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Можно распаковать кортеж в три переменные одной строкой

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed that

@gsvval
Copy link
Copy Markdown
Contributor Author

gsvval commented Nov 24, 2025

@allnes @aobolensk Запустите, пожалуйста, джобы

@allnes allnes merged commit d1f8218 into learning-process:master Dec 10, 2025
41 checks passed
AzotEye referenced this pull request in AzotEye/ppc-2025-processes-informatics Dec 14, 2025
…. Вариант 12 (#11)

<!--
Требования к названию pull request:

"<Фамилия> <Имя>. Технология <TECHNOLOGY_NAME:SEQ|OMP|TBB|STL|MPI>.
<Полное название задачи>. Вариант <Номер>"
-->

## Описание
<!--
Пожалуйста, предоставьте подробное описание вашей реализации, включая:
 - основные детали решения (описание выбранного алгоритма)
 - применение технологии параллелизма (если применимо)
-->

- **Задача**: _Сумма элементов матрицы по столбцам_
- **Вариант**: _12_
- **Технология**: _SEQ, MPI_
- **Описание** вашей реализации и отчёта.  
_SEQ_: Создается вектор сумм столбцом входной матрицы. Итерируясь по
матрице, каждый очередной ее элемент добавляется к соответствующей
сумме.
_MPI:_ Элементы входной матрицы поровну распределяются по процессам.
Если число элементов не кратно числу процессов, нераспределенные `n`
элементов дораспределяются по первым `n` процессам. Рассчитываются
массивы количеств и смещений для `MPI_Scatterv()` и локальный сдвиг
`shift` для корректного суммирования текущих элементов с
соответствующими элементами локального результирующего вектора (для
случаев, когда границы распределенных диапазонов не соответствуют
границам строк матрицы). Когда локальные результаты вычислены, они
собираются на корневом процессе функцией MPI_Reduce.
---

## Чек-лист
<!--
Пожалуйста, убедитесь, что следующие пункты выполнены **до** отправки
pull request'а и запроса его ревью:
-->

- [x] **Статус CI**: Все CI-задачи (сборка, тесты, генерация отчёта)
успешно проходят на моей ветке в моем форке
- [x] **Директория и именование задачи**: Я создал директорию с именем
`<фамилия>_<первая_буква_имени>_<короткое_название_задачи>`
- [x] **Полное описание задачи**: Я предоставил полное описание задачи в
теле pull request
- [x] **clang-format**: Мои изменения успешно проходят `clang-format`
локально в моем форке (нет ошибок форматирования)
- [x] **clang-tidy**: Мои изменения успешно проходят `clang-tidy`
локально в моем форке (нет предупреждений/ошибок)
- [x] **Функциональные тесты**: Все функциональные тесты успешно
проходят локально на моей машине
- [x] **Тесты производительности**: Все тесты производительности успешно
проходят локально на моей машине
- [x] **Ветка**: Я работаю в ветке, названной точно так же, как
директория моей задачи (например, `nesterov_a_vector_sum`), а не в
`master`
- [x] **Правдивое содержание**: Я подтверждаю, что все сведения,
указанные в этом pull request, являются точными и достоверными

<!--
ПРИМЕЧАНИЕ: Ложные сведения в этом чек-листе могут привести к отклонению
PR и получению нулевого балла за соответствующую задачу.
-->
AleksndrSakharov pushed a commit to AleksndrSakharov/ppc-2025-processes-informatics that referenced this pull request Dec 16, 2025
…. Вариант 12 (learning-process#11)

<!--
Требования к названию pull request:

"<Фамилия> <Имя>. Технология <TECHNOLOGY_NAME:SEQ|OMP|TBB|STL|MPI>.
<Полное название задачи>. Вариант <Номер>"
-->

## Описание
<!--
Пожалуйста, предоставьте подробное описание вашей реализации, включая:
 - основные детали решения (описание выбранного алгоритма)
 - применение технологии параллелизма (если применимо)
-->

- **Задача**: _Сумма элементов матрицы по столбцам_
- **Вариант**: _12_
- **Технология**: _SEQ, MPI_
- **Описание** вашей реализации и отчёта.  
_SEQ_: Создается вектор сумм столбцом входной матрицы. Итерируясь по
матрице, каждый очередной ее элемент добавляется к соответствующей
сумме.
_MPI:_ Элементы входной матрицы поровну распределяются по процессам.
Если число элементов не кратно числу процессов, нераспределенные `n`
элементов дораспределяются по первым `n` процессам. Рассчитываются
массивы количеств и смещений для `MPI_Scatterv()` и локальный сдвиг
`shift` для корректного суммирования текущих элементов с
соответствующими элементами локального результирующего вектора (для
случаев, когда границы распределенных диапазонов не соответствуют
границам строк матрицы). Когда локальные результаты вычислены, они
собираются на корневом процессе функцией MPI_Reduce.
---

## Чек-лист
<!--
Пожалуйста, убедитесь, что следующие пункты выполнены **до** отправки
pull request'а и запроса его ревью:
-->

- [x] **Статус CI**: Все CI-задачи (сборка, тесты, генерация отчёта)
успешно проходят на моей ветке в моем форке
- [x] **Директория и именование задачи**: Я создал директорию с именем
`<фамилия>_<первая_буква_имени>_<короткое_название_задачи>`
- [x] **Полное описание задачи**: Я предоставил полное описание задачи в
теле pull request
- [x] **clang-format**: Мои изменения успешно проходят `clang-format`
локально в моем форке (нет ошибок форматирования)
- [x] **clang-tidy**: Мои изменения успешно проходят `clang-tidy`
локально в моем форке (нет предупреждений/ошибок)
- [x] **Функциональные тесты**: Все функциональные тесты успешно
проходят локально на моей машине
- [x] **Тесты производительности**: Все тесты производительности успешно
проходят локально на моей машине
- [x] **Ветка**: Я работаю в ветке, названной точно так же, как
директория моей задачи (например, `nesterov_a_vector_sum`), а не в
`master`
- [x] **Правдивое содержание**: Я подтверждаю, что все сведения,
указанные в этом pull request, являются точными и достоверными

<!--
ПРИМЕЧАНИЕ: Ложные сведения в этом чек-листе могут привести к отклонению
PR и получению нулевого балла за соответствующую задачу.
-->
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

6 participants