С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.62/26: Рейтинг темы: голосов - 26, средняя оценка - 4.62
3 / 3 / 1
Регистрация: 27.06.2011
Сообщений: 101

Правильно распараллелить цикл

14.03.2013, 22:02. Показов 4883. Ответов 21
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Реализую тест Люка-Лемера на C#. Хочу использовать распараллеливание цикла, но не выходит.
По времени выигрываю примерно в 3 раза, но результат выдает неверный.
Вот сам код (закомментированный цикл работает как надо, а Parallel.For некорректно):
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
try
            {
                DateTime start = DateTime.Now;
 
                
                    int p = 521;
                    BigInteger M = BigInteger.Pow(2, p) - 1;
                    BigInteger L = 4;
                    /*for (int k = 1; k < p - 1; k++)
                    {
                        L = (L * L - 2) % M;
                    }*/
                    Parallel.For(1, p-1, i =>
                    
                    {
                        L = (L * L - 2) % M;
                    });
                    
                Console.WriteLine(L == 0 ? p + " простое" : p + " не является простым");
                DateTime end = DateTime.Now;
                Console.WriteLine("Время: " + (end - start));
            }
            catch { Console.WriteLine("Ошибка, инвалид"); };
 
            Console.ReadKey();
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.03.2013, 22:02
Ответы с готовыми решениями:

Распараллелить цикл
Здравствуйте! Есть цикл. M может принимать очень большие значения, считывается в таких случаях все очень долго, тестить крайне...

Как правильно распараллелить программу чтобы она не тормозила
С потоками никогда особо не работал, просто не было каких то тяжеловесных задач. Сейчас такая задача появилась. Принимаю почту с почтового...

Как распараллелить цикл с помощью Parallel.For?
Подскажите, как данный цикл for (int i = 0; i &lt; round_segments; i++) bottom_array = new TPoint(Bottom.getX() +...

21
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
14.03.2013, 22:16
west0293, естественно неправильно, тут же нельзя распараллелить, ведь на следующих итерациях используется информация о предыдущих... Если циклы друг от друга изолированы, параллелить можно, если нет - нельзя...

Добавлено через 1 минуту
Небольшой совет по производительности
C#
1
2
3
4
for (int k = 1; k < p - 1; k++)
                    {
                        L = (L * L - 2) % M;
                    }
лучше заменить на
C#
1
2
3
4
for (int k = 1; k + 1 < p; k++)
                    {
                        L = (L * L - 2) % M;
                    }
потому как к инту гораздо проще добавить единицу, чем вычесть из BigInteger

Добавлено через 4 минуты
И лучше для времени свой контрол использовать, а не костыли:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
using System;
using System.Diagnostics;
using System.Numerics;
 
namespace ConsoleApplication1
{
    public class Program
    {
        private static void Main()
        {
            try
            {
                var sw = new Stopwatch();
                sw.Start();
                int p = 5201;
                BigInteger M = BigInteger.Pow(2, p) - 1;
                BigInteger L = 4;
                for (int k = 1; k < p - 1; k++)
                    L = (L*L - 2)%M;
                Console.WriteLine(p + (L == 0 ? " простое" : " не является простым"));
                Console.WriteLine("Время: {0} ms", sw.ElapsedMilliseconds);
            }
            catch
            {
                Console.WriteLine("Ошибка, инвалид");
            }
            Console.ReadKey();
        }
    }
}
У меня оценка заняла 1600 мс
1
3 / 3 / 1
Регистрация: 27.06.2011
Сообщений: 101
14.03.2013, 22:30  [ТС]
Цитата Сообщение от Psilon Посмотреть сообщение
ведь на следующих итерациях используется информация о предыдущих...
Точно, я как-то не подумал. Спасибо)


Цитата Сообщение от Psilon Посмотреть сообщение
к инту гораздо проще добавить единицу, чем вычесть из BigInteger
Согласен, но в моем случае обе переменные типа int.

Цитата Сообщение от Psilon Посмотреть сообщение
У меня оценка заняла 1600 мс
Не хило) У меня на нетбуке при p=5201 проверка прошла за 8513 мс... Какие у Вас характеристики ПК, если не секрет?) Просто мне нужно максимально оптимизировать код и оборудование (подумывал собрать кластер, но раз распараллелить не вариант, то придется еще копать...) Может быть что-то еще посоветуете по оптимизации?
Спасибо!
0
 Аватар для LeniumSoft
1454 / 847 / 150
Регистрация: 06.06.2012
Сообщений: 2,370
14.03.2013, 22:36
Цитата Сообщение от Psilon Посмотреть сообщение
У меня оценка заняла 1600 мс
Обогнал!!!!!
Миниатюры
Правильно распараллелить цикл  
1
3 / 3 / 1
Регистрация: 27.06.2011
Сообщений: 101
14.03.2013, 22:44  [ТС]
Немного добавлю:
Этот код мне нужен для проверки одного конкретного большого числа (длина порядка 1млрд знаков). И, чтобы проверка не заняла долгие-долгие годы, мне нужно добиться максимального эффекта (задействовать максимальное количество ресурсов, возможно использовать какой-то кэш (например, текстовый файл), чтобы программу можно было прерывать и продолжать, возможно перейти на Linux (C# Mono) и т.д и т.п.). Компьютерного оборудования у меня достаточно много (порядка пяти компьютеров (3 ноутбука, 2 ПК) + куча комплектующих). Могу и еще достать - главное, чтобы толк был... Рассматриваю варианты по апгрейду ПК (процессор, SSD, ОЗУ, возможно использовать GPU) и т.д. и т.п. В общем, любые советы будут к месту)))

Добавлено через 57 секунд
Цитата Сообщение от LeniumSoft Посмотреть сообщение
Обогнал!!!!!
Если можно, тоже напишите характеристики своего компьютера)
0
 Аватар для LeniumSoft
1454 / 847 / 150
Регистрация: 06.06.2012
Сообщений: 2,370
14.03.2013, 22:50
Кликните здесь для просмотра всего текста


Свойства ЦП:
Тип ЦП 4x
Имя ЦП CPUID Intel(R) Core(TM) i5-3330 CPU @ 3.00GHz
Версия CPUID 000306A9h

Частота ЦП:
Частота ЦП 2993.2 MHz (исходное: 3000 MHz)

Кэш ЦП:
Кэш L1 кода 32 Кб
Кэш L1 данных 32 Кб
Кэш L2 256 Кб (Asynchronous)
Кэш L3 6 Мб


1
 Аватар для Wolkodav
842 / 480 / 58
Регистрация: 18.09.2012
Сообщений: 1,688
14.03.2013, 22:51
ASM вам в помощь.
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
14.03.2013, 23:06
LeniumSoft, скомпилировал в релиз


west0293
Вот такие характеристики:
http://www.samsung.com/ru/cons... S01RU-spec
Только хард на SSD поменял, но это тут не влияет.
1
3 / 3 / 1
Регистрация: 27.06.2011
Сообщений: 101
14.03.2013, 23:07  [ТС]
У меня на ПК программа выполнилась за 5 мс. Сейчас я нашел и поделючил неплохую библиотеку для работы с большими числами, теперь:
Миниатюры
Правильно распараллелить цикл  
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
14.03.2013, 23:09
Wolkodav, писать параллельный код на асме? Вы решили отстрелить вообще все на свете?

Добавлено через 26 секунд
west0293, Больше информации...
0
3 / 3 / 1
Регистрация: 27.06.2011
Сообщений: 101
14.03.2013, 23:09  [ТС]
Вот отсюда библиотеку взял... _http://www.emilstefanov.net/Projects/GnuMpDotNet/
0
 Аватар для LeniumSoft
1454 / 847 / 150
Регистрация: 06.06.2012
Сообщений: 2,370
14.03.2013, 23:11
Цитата Сообщение от Psilon Посмотреть сообщение
скомпилировал в релиз
Всё равно я быстрей!!!
Миниатюры
Правильно распараллелить цикл  
0
3 / 3 / 1
Регистрация: 27.06.2011
Сообщений: 101
14.03.2013, 23:11  [ТС]
Если влом заморачиваться, вот уже проект с подключенной библиотекой: _http://zalil.ru/34348091
Интересно, что на Вашей машинке получится)
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
14.03.2013, 23:13
LeniumSoft,

Не по теме:

эт все восьмерка!..


А вообще мобильный проц с десктопным не очень правильно сравнивать, даже если это i7 vs i3, благо многопоточности тут нет, так бы мобильный может и быстрее оказался бы)
0
 Аватар для LeniumSoft
1454 / 847 / 150
Регистрация: 06.06.2012
Сообщений: 2,370
14.03.2013, 23:17
Цитата Сообщение от west0293 Посмотреть сообщение
Интересно, что на Вашей машинке получится)
Да выигрыш огромный!!!

А вообще мобильный проц с десктопным не очень правильно сравнивать, даже если это i7 vs i3, благо многопоточности тут нет, так бы мобильный может и быстрее оказался бы)
У меня I5 . Твой близок к моему за счёт восьми потоков против моих четырёх!
Миниатюры
Правильно распараллелить цикл  
0
3 / 3 / 1
Регистрация: 27.06.2011
Сообщений: 101
14.03.2013, 23:25  [ТС]
Цитата Сообщение от LeniumSoft Посмотреть сообщение
Да выигрыш огромный!!!
Значит однозначно имеет смысл использовать) спасибо)
А на что посоветуете в первую очередь смотреть при апгрейде компьютера под вычислительные нужды? Частота? Кэш? может что-то еще? или всё в комплексе?
0
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
14.03.2013, 23:29
Я вас всех обогнал . Скомпилировал в релиз. Обычный проект без сторонних библиотек. Хар-ки компа в профиле есть.
Миниатюры
Правильно распараллелить цикл  
0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6101 / 4957 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
14.03.2013, 23:36
west0293, лол, архитектура решает. Например, у интела гораздо более высокая производительность на ядро. Но и цена выше. АМД занимает низ-мидл, интел - мидл-топ, цены у них соответствующие. Современный двухядерный i3 уделает за счет архитектуры любой первый core duo, возможно даже разница составит порядок.


LeniumSoft, почему-то думал, что меньше 3400 - i3

Добавлено через 56 секунд
Casper-SC, ну да, ты б еще результаты с 3770k сравнил с множителем под 50, или даже с парочкой ксеонов

Добавлено через 3 минуты
В дебаге - 289 мс со сторонней библиотекой, а при попытке скомпилить в релиз крашится lol

Добавлено через 1 минуту
Всех любителей пытаться непонятный многопоточный код заставить работать прошу сюда
Непонятная работа релиз сборки
0
 Аватар для LeniumSoft
1454 / 847 / 150
Регистрация: 06.06.2012
Сообщений: 2,370
15.03.2013, 10:06
Я бы всёж попробовал эти несколько строчек на C++ проверить! Возможно будет быстрее!
0
Заблокирован
15.03.2013, 15:56
Попробуйте так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
 class Program
    {
        static BigInteger L = 4;
        static int p = 521;
        static BigInteger M = BigInteger.Pow(2, p) - 1;
        static object obj = new object();
 
        static void Calculate()
        {
            lock (obj)
            {
                L = (L * L - 2) % M;
            }
        }
 
        static void Main(string[] args)
        {
            try
            {
                DateTime start = DateTime.Now;
 
              //  for (int k = 1;k< p-1; k++) Calculate();
                     Parallel.For(1, p-1, i => Calculate());
 
                Console.WriteLine(L == 0 ? p + " простое" : p + " не является простым");
                DateTime end = DateTime.Now;
                Console.WriteLine("Время: " + (end - start));
            }
            catch { Console.WriteLine("Ошибка, инвалид"); };
            Console.ReadKey();
        }
    }
Но смысл это делать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.03.2013, 15:56
Помогаю со студенческими работами здесь

Как правильно распараллелить выполнение DoWork, чтобы не было взаимоисключающих ситуаций
Так вот, пишу клиент-серверную вещь, что-то вроде переборщика паролей. Количество потоков для перебора пользователь выбирает сам. Далее при...

Как правильно распараллелить цикл?
Есть процедура в которой выполняется цикл. Хотелось бы его правильно распараллелить. Попытка сделать это нижеследующим образом не проходит,...

Распараллелить цикл
Распараллелить цикл: For(i=2;i&lt;N;i++) For(j=2;i&lt;N;j++) A =A +A; #include &lt;iostream&gt; #include &lt;omp.h&gt; #include...

Как распараллелить цикл while?
Доброго времени суток. При распараллелировании применять технологии Openmp. Было бы здорово, если бы ответ на вопрос, что в заглавии,...

Помогите распараллелить цикл!!!
Эксперты помогите, распараллелить консольное приложение на два(или четыре) ядра. Раньше ни когда не сталкивался с этим, даже не знаю, что...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 05.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru