169 похожих чатов

Друзья, подскажите, а что происходит при параллельном выполнении процессором двух

и более процессов? Т.е. то же самое, что и при прерывании (сохранение rip, слова состояния программы и всех регистров)?

26 ответов

16 просмотров

если ядро одно и на нём запущено несколько потоков, то да, по прерыванию таймера(допустим раз в 10мс) вызывается планировщик, который меняет данные

Самый маленький- Автор вопроса
Mixail Frolov
если ядро одно и на нём запущено несколько потоков...

А avx тоже сохраняются? Это ж крайне долго, однако при текстах с перемножением матриц я получил падение производительности при > 4 потоках ~ в 1,5 раза, но с увеличением числа потоков серьёзной разницы я не заметил. В чём магия?

Самый маленький
А avx тоже сохраняются? Это ж крайне долго, однако...

авх сохраняются только если они использованы

Самый маленький
А avx тоже сохраняются? Это ж крайне долго, однако...

долго потому что перед использованием avx сохраняется состояние sse. поэтому надо крайне внимательно за этим смотреть и делать код так чтоб в больших циклах отсутстовали вызовы sse или апи ос (она тоже использует sse и контекст приходится переключать) и не смешивать sse+avx

Самый маленький- Автор вопроса
Mixail Frolov
авх сохраняются только если они использованы

Их дефолтными значениями забивают? Скорее всего нет, тогда как это определяется?

Самый маленький- Автор вопроса
Aiwan \ (•◡•) / _bot
долго потому что перед использованием avx сохраняе...

Ты именно про многопоток? Я просто не уловил взаимосвязь между большими циклами и sse.

Самый маленький
Ты именно про многопоток? Я просто не уловил взаим...

нельзя смешивать в коде работу sse и avx. как вариант у тебя это произошло

Самый маленький- Автор вопроса
Aiwan \ (•◡•) / _bot
нельзя смешивать в коде работу sse и avx. как вари...

Не, я наивный вариант написал и без оптимизаций.

Самый маленький- Автор вопроса
Aiwan \ (•◡•) / _bot
долго потому что перед использованием avx сохраняе...

Так ладно, а как всё-таки взаимосвязаны тогда sse и avx? avx же отдельный блок

Самый маленький
Их дефолтными значениями забивают? Скорее всего не...

а может и нет проверки и всё сохраняется при каждом переключении :)

Самый маленький- Автор вопроса
Самый маленький
А avx тоже сохраняются? Это ж крайне долго, однако...

С avx как и с sse есть какие-то способы не сохранять, если не используется

Aiwan \ (•◡•) / _bot
долго потому что перед использованием avx сохраняе...

Со смешиванием и сохранением нет проблем за сохранение состояния отвечает одна инструкция по сути, нужно только выяснить сколько она сохраняет

Самый маленький- Автор вопроса
disba1ancer
С avx как и с sse есть какие-то способы не сохраня...

В том то и вопрос, какие способы и как определяется их использование? Плюс хотелось бы узнать подробнее про смешивание sse и avx, а также про циклы с ними (ну то, что писал Айван), а также почему с увеличение количества потоков (с определенного значения > количества ядер) не ухудшается производительность?

Самый маленький
В том то и вопрос, какие способы и как определяетс...

Ну как я понял смешивание инструкций только вызывает проблемы производительности, к сохранению состояния это не относится, а про какие потоки вопрос?

Самый маленький- Автор вопроса
disba1ancer
Ну как я понял смешивание инструкций только вызыва...

Так изначально вопрос то и был про производительность)) Про обычные треды вин32.

Самый маленький
Так изначально вопрос то и был про производительно...

Ну вообще, когда потоков больше чем ядер производительность отдельно взятого потока падает, но обычно в системе не так много активных потоков чтобы это было заметно

Самый маленький- Автор вопроса
disba1ancer
Ну вообще, когда потоков больше чем ядер производи...

Ну я ж замерил - взял перемножение матриц, распараллелил, и получил, что производительность на 6 потоках в пределах погрешности совпадает с производительностью на 12, при 4 реальных ядрах.

Самый маленький
Ну я ж замерил - взял перемножение матриц, распара...

Т.е ты перемножал одну матрицу кучей потоков, так?

Самый маленький- Автор вопроса
disba1ancer
Т.е ты перемножал одну матрицу кучей потоков, так?

Ну взял две матрицы и перемножал одну на другую

Самый маленький- Автор вопроса
Самый маленький
Ну взял две матрицы и перемножал одну на другую

Ну так если все потоки по сути работают над общей задачей значительного падения не будет, будет некоторый оверхед на переключение контекста и всё, потому, чтобы выжать максимум, нужно рабочих потоков по числу ядер держать

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта