Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.67
oksanaBM
1 / 1 / 0
Регистрация: 27.01.2011
Сообщений: 91
#1

Немного из архитектуры ЭВМ - C++

29.04.2011, 15:52. Просмотров 1483. Ответов 30
Метки нет (Все метки)

Пусть заданы две квадратных матрицы A и B размером NxN.
Они созданы с помощью двух подходов:

1 подход:
C++
1
2
3
4
int **A;
A = new int*[N];
for(int i=0;i<N;i++)
A[i] = new int[N];
Доступ к элементу: A[i][j]

2 подход:
C++
1
2
int *A;
A = new int[N*N];
Доступ к элементу: A[i*N+j]

Необходимо сложить эти матрицы и сравнить время вычисления. Нужны выводы по этим подходам: количество обращений к памяти,
вычислений, теоретические оценки времени вычислений (можно считать, что
матрицы не загружаются в кэш, время доступа к одному элементу в памяти 10
тактов, арифметическая операция 2 такта), реальное время вычисления.

Кто свободен, может поможите?.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.04.2011, 15:52
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Немного из архитектуры ЭВМ (C++):

Структура "ЭВМ". Определить какая ЭВМ имеет минимальное отношение стоимость/быстродействие - C++
Даны 3 ЭВМ , известны объемы памяти, цена и быстродействие. Определить какая ЭВМ имеет минимальное отношение стоимости/быстродействию и...

Проектирование ОО архитектуры - C++
Интересно мнение публики. &quot;Программирование в терминах интерфейсов&quot; Вопрос такой: как правильно конструировать едино-образный интерфейс? ...

Реализация архитектуры - C++
Задача такая. Есть класс строк ( десятичная , символьная и т.п.) и операции к ним. Я собрал архитектуру, и с помощью класса SWITCH я...

Задача проектирования архитектуры - C++
добрый день. недавно дали первое моё самостоятельное задание. ну, как самостоятельное, просто мне дали в этом задании полную свободу...

Организация архитектуры движка - C++
коротко интро: Есть три компонента, они в исходниках естессно, так как пишу их я. так вот эти три компонента должны ...

Предложения по изменению архитектуры - C++
Есть код (много но просто): #include &lt;iostream&gt; #include &lt;memory&gt; #include &lt;vector&gt; using namespace std; class SceneNode ...

30
KuKu
1558 / 1036 / 78
Регистрация: 17.04.2009
Сообщений: 2,988
29.04.2011, 16:18 #2
A[j][i] => A[j] + i*sizeof(int*) =>A + sizeof(int)*j + i*sizeof(int*)
A[i] => A+i*sizeof(int)

По идее в первом подходе на одно считывание элемента приходится два обращения к памяти и 4 арифм операции.
Во-втором одно обращение и две операции
1
oksanaBM
1 / 1 / 0
Регистрация: 27.01.2011
Сообщений: 91
29.04.2011, 16:36  [ТС] #3
А как вычислить реальное время вычисления?
0
KuKu
1558 / 1036 / 78
Регистрация: 17.04.2009
Сообщений: 2,988
29.04.2011, 16:47 #4
Если в ваших тактах, то умножьте число действий на длительность действия в тактах. А рельное никак, оно завист от кучи параметров.
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
29.04.2011, 18:03 #5
С некоторой долей уверенности можно утверждать, что второй вариант будет быстрее при малых размерах N (т.е. когда весь массив помещается в одной странице). Если N большое, то разница будет минимальна или её не будет вообще.
A[i][j] и A[i*N+j] равнозначны, т.к. любой вменяемый компилятор сгенерирует для них одинаковый код.

Добавлено через 6 минут
Цитата Сообщение от Deviaphan Посмотреть сообщение
A[i][j] и A[i*N+j] равнозначны, т.к. любой вменяемый компилятор сгенерирует для них одинаковый код.
А я соврал.) Это только для статически создаваемых массивов.)

Добавлено через 51 секунду
Однако,
Цитата Сообщение от Deviaphan Посмотреть сообщение
Если N большое, то разница будет минимальна или её не будет вообще
это осталось истинным.)
А считать такты это жжжесть!
1
oksanaBM
1 / 1 / 0
Регистрация: 27.01.2011
Сообщений: 91
29.04.2011, 18:04  [ТС] #6
Спасибо.. а сравнить время вычислений может возможно при помощи каких-нибудь функций?
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
29.04.2011, 18:06 #7
GetTickCount() до и после. Разница между ними будет временем.

Но время выполнения должно быть больше 1 тысячной секунды.
0
oksanaBM
1 / 1 / 0
Регистрация: 27.01.2011
Сообщений: 91
29.04.2011, 18:11  [ТС] #8
Можете помочь с кодом программы с использованием функции?
0
KuKu
1558 / 1036 / 78
Регистрация: 17.04.2009
Сообщений: 2,988
29.04.2011, 18:14 #9
Deviaphan, чет вы мне все предстваление о мире сломали. Делаю тест, первый вариант быстрее выходит... умя ступор
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
29.04.2011, 18:17 #10
Цитата Сообщение от KuKu Посмотреть сообщение
умя ступор
Во первых, тестируй в релизе. Во вторых, большое N - это хотя бы несколько тысяч.
0
oksanaBM
1 / 1 / 0
Регистрация: 27.01.2011
Сообщений: 91
29.04.2011, 18:17  [ТС] #11
)))) блин а у меня зачет ломается)) я сделала только вот эту прогу -
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
33
34
35
36
#include <stdio.h>
#include <stdafx.h>
#include <windows.h>
#include <ctime>
#include <conio.h>
#include <locale.h>
 
#define N 200
 
void main()
{setlocale(LC_CTYPE, "Russian");
LARGE_INTEGER b_start,b_stop,freq;
QueryPerformanceFrequency(&freq);
long long int a[N][N], b[N][N], c[N][N];
srand(time(NULL));
int i,j,k;
for(i = 0; i < N; i++)
for(j = 0; j < N; j++)
{     a[i][j] = rand()%N;
     b[i][j] = rand()%N;        }
QueryPerformanceCounter(&b_start);
for(i = 0; i < N; i++)
for(j = 0; j < N; j++)
for(k = 0; k < N; k++)
       c[i][j] += a[i][k] + b[k][j];
QueryPerformanceCounter(&b_stop);
printf("Время стандартного алгоритма: %lf мксек\n", (double)(b_stop.QuadPart - b_start.QuadPart)*1000000.0/(double)(freq.QuadPart));
QueryPerformanceCounter(&b_start);
for(i = 0; i < N; i++)
for(k = 0; k < N; k++)
for(j = 0; j < N; j++)
       c[i][j] += a[i][k] + b[k][j];
QueryPerformanceCounter(&b_stop);
printf("Время алгоритма с учетом прямого обхода памяти: %lf мксек\n", (double)(b_stop.QuadPart - b_start.QuadPart)*1000000.0/(double)(freq.QuadPart));
_getch();
}


чем она мне помочь может... наверно ничем. не знаю...
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
29.04.2011, 18:19 #12
QueryPerformanceCounter точнее, чем GetTickCount, но N слишком маленькое.
0
oksanaBM
1 / 1 / 0
Регистрация: 27.01.2011
Сообщений: 91
29.04.2011, 18:20  [ТС] #13
не. я тупанула..
0
KuKu
1558 / 1036 / 78
Регистрация: 17.04.2009
Сообщений: 2,988
29.04.2011, 18:21 #14
Цитата Сообщение от Deviaphan Посмотреть сообщение
Во первых, тестируй в релизе. Во вторых, большое N - это хотя бы несколько тысяч.
Массив 5000*5000 и 25000000. Постоянно на процентов 10 медленее.
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
29.04.2011, 18:28 #15
i,j разные пробовал или в конце массива?
0
29.04.2011, 18:28
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.04.2011, 18:28
Привет! Вот еще темы с ответами:

Ошибка при построении архитектуры if-else - C++
Добрый день! Написал программу по условию: (см. 1 картинку) Выглядит программа так: #include &quot;stdio.h&quot; #include...

Критика архитектуры набора планов - C++
Требуется создать систему похожую на Hierarchical task network то есть некоторая библиотека планов и каждый план может содержать...

Программа проверки знания истории архитектуры - C++
Напишите программу проверки знания истории архитектуры. Программа должна вывести вопрос и три варианта ответа. Пользователь должен выбрать...

Нужна помощь в выборе архитектуры системы. - C++
Стоит задача создать довольно сложную систему. Прошу помоч в выборе архетектуры. Примерное ТЗ: Есть много (150-200) компьютеров,...


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

Или воспользуйтесь поиском по форуму:
15
Закрытая тема Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru