Форум программистов, компьютерный форум CyberForum.ru

Распараллеливание метода нахождения обратной матрицы - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Общий, с чего начать http://www.cyberforum.ru/cpp-beginners/thread1142031.html
В последнее время не могу понять, что стоит изучить, да и вообще потерял слегка интерес к программированию, хотя раньше очень любил это. В колледже по программе мы прошли не особо много, азы: типо классов, функций, рекурсий и тп., далеко не углублялись, потому что пары должны идти "для всех", а не для 5-7 человек. В универе кроме математики, ничего практически нет, а те пары и лабораторные по...
C++ Программное обеспечение для Аудиографа Доброго времени суток! Собственно сразу к делу. Есть проект по разработке устройства для измерения остроты слуха, который делится на 2 части, 1-я касается разработки аппаратной части, а 2-я программная часть. Мне необходимо написать программу которая: 1: Будет управлять процессом измерения чувствительности слуха пациента 2: Cчитать с прибора сохраненные результаты измерения слуха на частотах... http://www.cyberforum.ru/cpp-beginners/thread1140560.html
Код подключения к MS SQL C++
Здравствуйте. Возможно вопрос покажется совсем уж тупым, но пожалуйсто ответте, ибо никак не могу решить проблему, а сроки поджимают. Имеется некторый MSSQL Server, который находится по адресу, скажем, 192.168.1.10, мне на хосте необходимо запустить клиент, который коннектится к БД и совершает некторые транзакции. Вопрос в следующем: как написать код подключения к этой БД на с++ без mfc....
Измерить кол-во тактов процессора C++
Здравствуйте. Подскажите, пожалуйста, каким способом можно измерить количество тактов (или время с точностью до наносекунд), затраченное на выполнение программы (или отдельного участка кода)? Измерить нужно не в написанной мною программе, а в вообще любой программе. Существуют ли утилиты, коды для командной строки, самописные программы и т.д. для этого? Заранее спасибо. P.S. Создал в этом...
C++ Как собрать установочный файл? http://www.cyberforum.ru/cpp-beginners/thread1136825.html
Я написал программу, но хочу сделать так, чтобы она устанавливалась. Как это сделать?
C++ Круглые и квадратные скобки при операторе new Требуются помощь в использовании оператора new! И так для начала вопросы для понимания, что произойдет при выполнении 2-ух вариантов кода size_t* AS = new size_t(Count); //вар 1 size_t* AS = new size_t; //вар 2 какая между ними разница? если усложнить пример и написать: Type ** AP = new (Type*); Type ** AP = new (Type*)(Count); то увидим что первая строка компилируется, а вторая выдает... подробнее

Показать сообщение отдельно
Danila777
0 / 0 / 0
Регистрация: 23.05.2013
Сообщений: 14
09.04.2014, 20:22  [ТС]     Распараллеливание метода нахождения обратной матрицы
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#include "stdafx.h"
#include<stdio.h>
#include<math.h>
#include<iostream>
#include<conio.h>
#include<stdlib.h>
using namespace std;
#define NN 6
 
int main()
{
 
    float M[NN][NN],kst; //kst - определитель матрицы
    int i,j,n,p,k=0,t;
    char yn;
 
    // <----Ввод размера квадратной матрицы---->
 
    while(k==0)
    {
        printf("Razmer matr (ot 2 do %d): N=",NN);
        cin>>n;
        if ((n<2) || (n>NN)) k=0;
        else k=1;
    }
 
    // <----Ввод матрицы a[NN][NN]---->
    printf("Vvedite matr %dx%d\n",n,n);
    for(i=0;i<n;i++)
        for(j=0;j<n;j++)
        {
            cin>>M[i][j];
        }
 
        // <----Транспонируем матрицу---->
        float Mt[NN][NN];//транпонированная матрица
        for(int i=0;i<n;i++)        
        {
            for(int j=0;j<n;j++)
            {
                Mt[i][j]=M[j][i];
            }
        }
 
        // <----Считаем определитель---->
        p=0;
        for (i=0; i<n-1; i++)
        {
            t=1;
            while(M[i][i]==0)
            {
                for(j=0; j<n; j++)
                {
                    M[i][j]=kst;
                    M[i][j]=M[i+t][j];
                    M[i+t][j]=kst;
                }
                p++;
                t++;
            }
 
            for (k=i+1; k<n; k++)
            {
                kst=M[k][i]/M[i][i];
                for(j=0; j<n; j++)
                    M[k][j]-=M[i][j]*kst;
            }
        }
 
        kst=pow(-1.0,p);
        for(i=0; i<n; i++)
        {
            kst*=M[i][i];
        }
 
        // <----Находим обратную матрицу---->
        cout<<"Obratna9 matr:";
        if(kst!=0)
        {
            float Opred=1/kst;
            for(int i=0;i<n;i++)
            {
                cout<<"\n";
                for(int j=0;j<n;j++)
                {
                    Mt[i][j]=M[i][j]*Opred;
                    printf ("%4.2f ", Mt[i][j]);
                }
            }
        }
        else
            cout<<"Opredelitel == 0";
        cin>>n;
        return 0;
}
вот код пожалуйста

Добавлено через 1 минуту
и литературу порекомендуйте, пожалуйста.
теория тоже нужна.
БУДУ ОЧЕНЬ БЛАГОДАРЕН.
 
Текущее время: 14:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru