Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 16.11.2020
Сообщений: 17

Изменение\ упрощение кода

25.10.2021, 19:26. Показов 522. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Постановка задания: нужно матрицу А разложить на 3 матрицы, L - нижнетругольная, D - диагональная, R - верхнетреугольная. А = LDR. Код написан, работает исправно. Однако я создал функцию trans, которая на выходе выдает матрицы LDR, однако при создании функции, внутри нее созданы еще 3, series_d, series_l, series_r, которые считают сумму ряда. Мне нужно вытащить создании данных функций на создание функции trans. Я приложил скрин суммы, которую считают функции и сам код. Я пробовал вытаскивать def series_d и т.д, но пишет, что не найден i и j, т.к я их задаю в цикле, который в trans. Приложенный код работает. Заранее огромное спасибо
Python
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
import numpy as np
 
n = int(input('Введите размер матрицы: '))
 
A = np.random.randint(1, 10, size = (n, n))
X = np.random.randint(1, 10, size = (n, 1))
 
 
 
 
 
def trans(A):
    L = np.eye(n)
    D = np.eye(n)
    R = np.eye(n)
 
    def series_d(m):
        summa = 0
        for k in range(1,m):
            res = L[m - 1][k - 1] * D[k - 1][k - 1] * R[k - 1][m - 1]
            summa = summa + res
        return summa
 
    def series_r(m):
        summa = 0
        for k in range(1,m):
            res = L[m - 1][k - 1] * D[k - 1][k - 1] * R[k - 1][j - 1]
            summa = summa + res
        return summa
 
    def series_l(m):
        summa = 0
        for k in range(1,m):
            res = L[i - 1][k - 1] * D[k - 1][k - 1] * R[k - 1][m - 1]
            summa = summa + res
        return summa
    
    for m in range(1, n + 1):
        for i in range(1, n + 1):
            for j in range(1, n + 1):
                D[m - 1][m - 1] = A[m - 1][m - 1] - series_d(m)
                R[m - 1][j - 1] = (A[m - 1][j - 1] - series_r(m))/D[m - 1][m - 1]
                L[i - 1][m - 1] = (A[i - 1][m - 1] - series_l(m))/D[m - 1][m - 1]
    return L, D, R
 
 
 
 
 
 
L , D, R = trans(A)
print(L)
print(D)
print(R)
Миниатюры
Изменение\ упрощение кода  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.10.2021, 19:26
Ответы с готовыми решениями:

Упрощение кода
Написал код, но интересует можно ли его как-то сделать проще? a = , , , , , , ] a3= , , , , , , ] v = 20 a1= a2= sump=0 for i...

Упрощение кода
Кто поможет упростить код на python pygame? Не надо писать что это говно код (я и сам знаю) просто новичок в этом деле) import pygame ...

Упрощение кода python
Господа,есть работающий код: #работа с файлом excel import pandas as pd from pandas import DataFrame read_table =...

1
Эксперт Python
8849 / 4501 / 1864
Регистрация: 27.03.2020
Сообщений: 7,316
25.10.2021, 20:47
Marat22,
Python
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
import numpy as np
 
n = int(input('Введите размер матрицы: '))
 
A = np.random.randint(1, 10, size = (n, n))
X = np.random.randint(1, 10, size = (n, 1))
 
 
 
 
 
def trans(A):
    L = np.eye(n)
    D = np.eye(n)
    R = np.eye(n)
    sd, sr, sl = [], [], []
    def series_d(m):
        summa = 0
        for k in range(1,m):
            res = L[m - 1][k - 1] * D[k - 1][k - 1] * R[k - 1][m - 1]
            summa = summa + res
        return summa
 
    def series_r(m):
        summa = 0
        for k in range(1,m):
            res = L[m - 1][k - 1] * D[k - 1][k - 1] * R[k - 1][j - 1]
            summa = summa + res
        return summa
 
    def series_l(m):
        summa = 0
        for k in range(1,m):
            res = L[i - 1][k - 1] * D[k - 1][k - 1] * R[k - 1][m - 1]
            summa = summa + res
        return summa
    
    for m in range(1, n + 1):
        td = series_d(m)
        sd.append(td)
        D[m - 1][m - 1] = A[m - 1][m - 1] - td
        for i in range(1, n + 1):
            tl = series_l(m)
            sl.append(tl)
            L[i - 1][m - 1] = (A[i - 1][m - 1] - tl)/D[m - 1][m - 1]
            for j in range(1, n + 1):
                tr = series_r(m)
                sr.append(tr)
                R[m - 1][j - 1] = (A[m - 1][j - 1] - tr)/D[m - 1][m - 1]
    return L, D, R, sd, sl, sr
 
 
 
 
 
 
L, D, R, sd, sl, sr = trans(A)
print(L, '\n')
print(D, '\n')
print(R, '\n')
 
print(sd, '\n')
print(sl, '\n')
print(sr, '\n')
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.10.2021, 20:47
Помогаю со студенческими работами здесь

Упрощение кода программы, callback
Доброго времени суток, имеется программа, которая достает и парсит из бинарного файла нужные данные и сохраняет их в файл. Данные беру из...

Упрощение кода
Здравствуйте. Требуется упростить следующий код: int CountP = 110; List<double> lstMin = new List<double> ( ); bool...

Упрощение кода
Всем привет!! Попалась на вёрстку менюшка с противными разделителями...ну совсем не стандартными. На макете, вроде, всё красиво, но на...

Упрощение кода
Имеется несколько функций, где идет проверка заданной строки и потом выдает значение. Но вот в чем проблема, на каждый ComBoBox написана...

Упрощение кода
Добрый Всем день. Есть на форме кнопка0 и надпись0 и т. д.Их много и кода идинакового в кнопках больше.Кнопка0 проверяет надпись0 и в...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru