Тактовая частота и количество ядер для параллельного компьютерного моделирования
Мой вопрос похож на некоторые вопросы "скорость против ядер", которые уже задавались на этом сайте. Однако меня интересуют некоторые очень специфические и технические моменты. Поэтому я надеюсь, что мой вопрос будет иметь право на "ответ", а не исключительно на основе мнения.
На моем рабочем месте мы часто подходим к определенным статистическим проблемам, используя компьютерное моделирование. Программное обеспечение, которое мы используем, в основном предназначено для одноядерных процессоров, но мы запускаем его параллельно, используя несколько экземпляров этих программ. Моделирование требует значительных вычислительных ресурсов, и одна итерация может занять до одного часа.
Чтобы повысить скорость этих вычислений, меня попросили предложить несколько моделей, которые лучше всего подойдут. Однако я не уверен, что в этом случае вычисления выиграют от более высокой тактовой частоты, чем от более распараллеленных процессов.
Компьютеры, которые мы используем в настоящее время, представляют собой решения серверного масштаба, которые содержат несколько процессоров с относительно высокой скоростью (16 физических ядер, 2,9 ГГц каждое и без графического процессора). Таким образом, решение сводится к двум вариантам:
- инвестирование в аналогичные машины с чуть более высокой тактовой частотой (например, 3,2 ГГц) и таким же количеством ядер (скажем, 16) или, альтернативно...
- снижение тактовой частоты (например, 2,6 ГГц) и переход на большее количество ядер (скажем, 20 или 24).
Я не уверен, что увеличение тактовой частоты окупится даже в приложениях, требующих большого объема вычислений, поскольку я предполагаю, что производительность не увеличивается линейно с тактовой частотой. Строго говоря, я мог бы просто подойти к проблеме следующим образом:
- 3,2 ГГц * 16 ядер = 51,2 ГГц или, альтернативно...
- 2,5 ГГц * 24 ядра = 60,0 ГГц
Тем не менее, я уверен, что этот расчет ошибочен во многих отношениях. Но каким именно образом? В данном частном случае деньги на самом деле не проблема, и, к сожалению, необходимо исключать вычисления с использованием графических процессоров.
Машины будут работать под управлением Windows Server 2012 R2 и будут использоваться исключительно для такого рода расчетов. Все задействованные программы оптимизированы для работы с 64-битной версией, но иногда могут использоваться и 32-битные программы. Память и жесткий диск не должны быть огромным фактором для рассмотрения.
Ура!
1 ответ
Расчеты не точные. Они с математической точки зрения, но в вычислениях вам действительно нужно умножить на 0,9 до 0,75, чтобы получить реальную "мощность". Чем больше ядер / процессоров, тем меньше число. Это происходит из-за мощности компьютера, вам нужно распараллеливать задачи и их, чтобы получить конечный результат из разных потоков.