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

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

Восстановить пароль Регистрация
 
Danila777
0 / 0 / 0
Регистрация: 23.05.2013
Сообщений: 14
08.04.2014, 11:21     Распараллеливание метода нахождения обратной матрицы #1
Здравствуйте!
Помогите пожалуйста.
Мне нужно распараллелить метод нахождения обратной матрицы.
Посоветуйте литературу, касающуюся этой темы.
Просто никогда не делал на практике распараллеливание.
Распараллелить мне нужно на С++.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.04.2014, 11:21     Распараллеливание метода нахождения обратной матрицы
Посмотрите здесь:

Код обратной матрицы на С++ C++
C++ Какие есть способы или алгоритмы написания программы для нахождения обратной матрицы
C++ Дан алгоритм нахождения обратной матрицы. По нему хочу написать код. Но непонятно по какому методу он работает.
Метод итераций для нахождения обратной матрицы C++
Распараллеливание потоков для нахождения суммы матрицы <omp.h> C++
Программа нахождения обратной матрицы C++
Нахождение обратной матрицы C++
C++ Нахождение обратной матрицы

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
OstapBender
 Аватар для OstapBender
581 / 519 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
09.04.2014, 15:24     Распараллеливание метода нахождения обратной матрицы #2
Код, который нужно распараллелить, прикладывайте
Danila777
0 / 0 / 0
Регистрация: 23.05.2013
Сообщений: 14
09.04.2014, 20:22  [ТС]     Распараллеливание метода нахождения обратной матрицы #3
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 минуту
и литературу порекомендуйте, пожалуйста.
теория тоже нужна.
БУДУ ОЧЕНЬ БЛАГОДАРЕН.
Yandex
Объявления
09.04.2014, 20:22     Распараллеливание метода нахождения обратной матрицы
Ответ Создать тему
Опции темы

Текущее время: 15:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru