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

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

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

26 ответов

14 просмотров

если ядро одно и на нём запущено несколько потоков, то да, по прерыванию таймера(допустим раз в 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
Т.е ты перемножал одну матрицу кучей потоков, так?

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

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

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

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Привет. Подскажите, как правильно сматчить лист фиксированного размера, чтобы компилятор не говорил мне о неполном паттерне? Допустим что-то такое [x', y'] = sort [x, y]?
Arseny
8
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Карта сайта