|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
||||||
Сделайте, чтобы двумерный вектор обогнал двумерный массив при заполнении случайными числами07.02.2019, 10:21. Показов 6581. Ответов 31
Метки нет (Все метки)
Всем привет!
Попробовал сравнить время заполнения векторов в векторе и массивов в массиве (динамические) случайными числами, получаемыми STL генератором. Вот фрагменты кода
first -> длина стороны матрицы n (получается двумерный массив n x n) second -> время заполнения матрицы такого размера случайными числами, передаётся в мой алгоритм построения графиков, который начертил то, что приведено на прикреплённом скрине. Для динамического массива - оранжевый. Для вектора - циан. По оси x размер стороны квадратной матрицы n, по оси y кол-во секунд, затраченное на заполнение матрицы такого размера случайными числами. Чем больше (выше) - тем хуже (медленней). Как видно вектор долго возится (циановые кольца выше оранжевых, то есть затрачено больше времени), массив его обходит по времени. Я делал ставку на вектора в векторе, но они проиграли массивам в массиве по времени выполнения. Предлагаю Вам предложить мне коды, которые бы при равноценных условиях заполняли случайными числами по STL и вектора в векторе и таким же образом массивы в массиве, но чтобы вектор выиграл по времени. Возможно я использовал недостаточно чёткий алгоритм заполнения векторов и массивов.
0
|
||||||
| 07.02.2019, 10:21 | |
|
Ответы с готовыми решениями:
31
Задать двумерный массив со случайными числами Заполнить двумерный массив случайными числами |
|
Mental handicap
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
|
|||||
| 07.02.2019, 12:20 | |||||
|
Добавлено через 2 минуты Добавлено через 1 минуту
0
|
|||||
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
|||||
| 07.02.2019, 12:26 [ТС] | |||||
|
0
|
|||||
|
Mental handicap
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
|
||||||||||||||
| 07.02.2019, 12:42 | ||||||||||||||
Сообщение было отмечено SomniPhobia как решение
Решение
Допустим возьмем обычный вектор.
Кот:
vector: 0.094393Теперь нативный:
array: 0.001643Уфф, существенный проигрыш, но постойте в векторе мы же использовали зачем-то push_back, меняем на experimental[i] = magic_numberрезультат, усредненный по 10 замерам vector: 0.001478Упс, разницы нету почти или это погрешность.. Флаги компилятора -Wall -Wextra -std=c++17 -pedantic -O3 Добавлено через 1 минуту Добавлено через 1 минуту ![]() Добавлено через 8 минут Добавлено через 3 минуты Хотя мои замеры просто баловство, по заполению разницы не будет, тк это почти тоже, то что вы используете stl или методы для заполнения вектора/нативного массива только дает небольшое замедление, генератор рандомных чисел тоже такое се, мы проверяем заполнение, какая нам раница чем? + вы еще проверяете на создание.
1
|
||||||||||||||
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
||||
| 07.02.2019, 12:42 [ТС] | ||||
|
0
|
||||
|
Mental handicap
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
|
|
| 07.02.2019, 12:48 | |
|
0
|
|
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
|||
| 07.02.2019, 12:48 [ТС] | |||
|
Добавлено через 37 секунд
0
|
|||
|
Mental handicap
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
|
|
| 07.02.2019, 13:00 | |
|
0
|
|
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
||||||
| 07.02.2019, 13:02 [ТС] | ||||||
|
Azazel-San, по Вашим котам я сформировал такой код и графики следующие. Почему такие результаты?
0
|
||||||
|
Mental handicap
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
|
|
| 07.02.2019, 13:23 | |
|
SomniPhobia, я откуда знаю что делает ваша программа. Первый квадрат ваш на графике, в самом нижнем левом углу, посмотрите и сравните эти две картинки смотря только на этот один квадрат, отклонения почти идентичны (только смотрите на отлонение между линиями, а не относительно осей).
Добавлено через 8 минут Впринципе нижняя полоска, как я понимаю для нативного массива ожидаема, у нас доступ к элементу происходит за О(1), лучше уже не может быть, с вектором тоже самое, отклонение должны быть минимальны или на уровне погрешности. Добавлено через 4 минуты Кстати в своем первом замере с вектором на push_back я сделал ошибку из-за констуктора, его надо убрать, но мы всеравно проиграем из-за push_back'a.
0
|
|
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
||||||||
| 07.02.2019, 13:47 [ТС] | ||||||||
Затем для durations_v (циан) и durations_a (рыжий) строятся эти графики. first (кол-во элементов) откладывается по x, second (время выполнения) - по y. Добавлено через 2 минуты В случае с gen() просто чуть дольше заполнение, но эта функция если применяется к вектору, то и к массиву аналогично - подразумевается равноправность данных для заполнения.
0
|
||||||||
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
|
| 07.02.2019, 14:01 [ТС] | |
|
Ещё замеры.
Начальное значение длины контейнера/массива 1 000. Шаг 10 000. Конечное значение 2 000 000. Единицы измерения времени миллисекунды.
0
|
|
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
|
| 07.02.2019, 14:03 [ТС] | |
|
Погрешность? Не знаю. На графиках прослеживаются 2 линии, да значения, формирующие их колеблются, но разброс от линии не велик.
0
|
|
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
|
| 07.02.2019, 14:09 [ТС] | |
|
Ещё скрин.
0
|
|
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
|
| 07.02.2019, 14:10 [ТС] | |
|
Две последние картинки про заполнение через
static inline constexpr std::size_t magic_number = 0xFF;
0
|
|
|
Mental handicap
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
|
|
| 07.02.2019, 14:12 | |
|
SomniPhobia, значит при каждом вызове цикла вы вызываете вашу ф-ю
test_array?Вижу в ней создание динамического массива, а очистки памяти не вижу, у вас там утечка памяти. Если я ничего не пропустил.
1
|
|
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
|||||||
| 07.02.2019, 14:22 [ТС] | |||||||
|
Добавлено через 4 минуты Так быстрее заполняется, почти в два раза угол от x до прямой меньше.
0
|
|||||||
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
|
| 07.02.2019, 14:25 [ТС] | |
|
Azazel-San, вот скрины.
Вектор объявляется + заполняется без цикла. Вектор только заполняется одним и тем же числом. Забыл дописать: в цикле a[i] = ...;
0
|
|
|
Mental handicap
1246 / 624 / 171
Регистрация: 24.11.2015
Сообщений: 2,429
|
|
| 07.02.2019, 14:29 | |
|
SomniPhobia, не знаю, у меня значения вышли +/- одинаковые, что с нативным массивом, что с вектором, разница была в ~0.002 что может быть на уровне погрешности.
0
|
|
|
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,405
|
||||||
| 07.02.2019, 14:35 [ТС] | ||||||
|
Azazel-San, при такой записи
1
|
||||||
| 07.02.2019, 14:35 | |
|
Помогаю со студенческими работами здесь
20
Заполнить двумерный массив случайными числами Заполнить двумерный массив случайными числами
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.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/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|
Фото: Daniel Greenwood
kumehtar 13.11.2025
|
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга,
Ты же видел моря и метели.
Как сменялись короны и стяги,
Как эпохи стрелою летели.
- Этот мир — это крылья и горы,
Снег и пламя, любовь и тревоги,
И бескрайние. . .
|