|
6 / 6 / 4
Регистрация: 27.05.2010
Сообщений: 48
|
||||||
Как увеличить скорость вычислений 500 000 строк?30.03.2013, 23:53. Показов 3785. Ответов 4
Метки нет (Все метки)
Здравствуйте. Вопрос к людям с опытом. Как ускорить вычисления 500 000 строк. Задача посчитать, какую прибыль приносил магазин в среднем в день за месяц, т.е сумма прибыли за месяц / кол-во дней когда магазин работал. Имеется 600 магазинов, по которым получается список из более 20 000 строк (магазин, год, месяц), с продажами за день получается список из 500 000 строк (магазин, год, месяц, день, продажи).
Результаты применение распараллеливания расчётов, оказались неудовлетворительным прирост в скорости на 30 сек. С 1600 сек (без многопоточности) до 1570 сек (многопоточность). А неудовлетворительны потому, что в ексэле такая операция при построении сводной таблицы занимает секунды. Вот и вопрос "Как ускорить вычисление?".
0
|
||||||
| 30.03.2013, 23:53 | |
|
Ответы с готовыми решениями:
4
Массивы элементов. Как увеличить скорость создания? Истекло время ожидания запроса после вставки 500 000 — 700 000 записей |
|
713 / 680 / 126
Регистрация: 30.03.2012
Сообщений: 1,124
|
||||||||||||||||
| 31.03.2013, 02:14 | ||||||||||||||||
правильный ответ - 10 миллиардов раз магазинов в списке
вы уверены что все 10 миллиардов итераций нужны? как бы эту проблему попробовал решить я: 1) изменить объектную структуру - разделить объект магазин на два: а) собственно магазин, имеющий название, год, месяц и лист продаж за день б) продажи за день - имеющие день и сумму в рублях магазин будет идентифицироваться по первым трем полям (название, год, месяц) 2) вместо инициализации листа fail на 500 тысяч позиций я бы создал Dictionary магазинов, при чтении новой строки из потока добавлял бы продажи к магазинам (если магазина в словаре нет - добавлял бы магазин и добавлял бы к нему продажу) на выходе из первого цикла я бы получил словарь в котором содержатся магазины (20 тыщ штук) каждый из которых содержит лист продаж за день (суммарно 500 тыщ штук) 3) все что нам нужно дальше это пробежаться по словарю и для каждого из 20 тысяч магазинов посчитать сумму в листе продаж за день итоговое количество проходов по этому циклу будет 500 тысяч вместо 10 миллиардов ну и кстати вот это место:
вместо того чтобы рассказать методу Distinct как именно нужно сравнивать объекты (не учитывая поле даты) вы создаете 500 тысяч новых объектовнадеюсь оптимизации последнего цикла в двадцать тысяч раз вам хватит ^_^ Добавлено через 14 минут более простой способ оптимизации цикла (если лениво писать первый) 1) ДО цикла сгруппировать лист fail по указанным параметрам (groupby) вы получите 20 тысяч групп в которых будет суммарно 500 тысяч объектов потом в цикле получать группу по ключу и считать элементы число проходов тоже будет 500 тысяч вместо 10 миллионов (за счет того что вы не будете группировать объекты каждый раз)
2
|
||||||||||||||||
|
Заблокирован
|
|||||||||||||||||
| 31.03.2013, 13:46 | |||||||||||||||||
1
|
|||||||||||||||||
|
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
|
|
| 31.03.2013, 16:03 | |
|
Покажи файл
0
|
|
|
6 / 6 / 4
Регистрация: 27.05.2010
Сообщений: 48
|
||||||
| 01.04.2013, 10:11 [ТС] | ||||||
|
Реализовал как подсказал Tessen стало действительно выполнятся за секунду. Только при использовании параллельного ForEach происходит ошибка "Индекс находился вне границ массива.". Это не столь критично, но интересно с чем это может быть связано? Вот сам код:
HIMen файл большой мин размер 40 мб, шапка файла выглядит так (Наименование магазина|Год|Номер месяца|Дата|Продажи по факт.цене без НДС, руб.) ну а характеристики данных я уже описывал.
0
|
||||||
| 01.04.2013, 10:11 | |
|
Помогаю со студенческими работами здесь
5
Как увеличить скорость загрузки страницы Как увеличить (оптимизировать) скорость TCP сервера? Как увеличить скорость отображения данных
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536
Одним из. . .
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|