Форум программистов, компьютерный форум, киберфорум
Python: Научные вычисления
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/34: Рейтинг темы: голосов - 34, средняя оценка - 4.50
19 / 19 / 14
Регистрация: 06.08.2009
Сообщений: 538

Решение системы уравнений: LinAlgError: Singular matrix

06.03.2019, 21:33. Показов 7107. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Коллеги, выполняю такой код:

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
import matplotlib.pyplot as plt
%matplotlib inline
import math
import numpy as np
 
def f(x):
    return np.sin(x / 5) * np.exp(x / 10) + 5 * np.exp(-x / 2)
 
lag = 0.1 #Задаем шаг
x = np.arange(1.0, 15.0+lag, lag) #Вычисляем массив значений X
y = f(x) #Вычисляем значения функции
 
#Строим график
fig = plt.figure()
plt.plot(x, y)
 
points=[1,15]    
size=len(points)            
    
a=np.array(points*size)
a=a.reshape(size, size)
b=f(np.array(points))
 
print a
print b
w = np.linalg.solve(a, b)
И на строке
Python
1
w = np.linalg.solve(a, b)
Выдается сообщение об ошибке:

LinAlgError Traceback (most recent call last)
<ipython-input-21-309827bd33e2> in <module>()
24 print a
25 print b
---> 26 w = np.linalg.solve(a, b)
27 #a = np.array([[3, 1], [1, 2]])
28 #b = np.array([9, 8])

C:\Users\megab\Anaconda2\lib\site-packages\numpy\linalg\linalg.pyc in solve(a, b)
392 signature = 'DD->D' if isComplexType(t) else 'dd->d'
393 extobj = get_linalg_error_extobj(_raise_linalgerr or_singular)
--> 394 r = gufunc(a, b, signature=signature, extobj=extobj)
395
396 return wrap(r.astype(result_t, copy=False))

C:\Users\megab\Anaconda2\lib\site-packages\numpy\linalg\linalg.pyc in _raise_linalgerror_singular(err, flag)
87
88 def _raise_linalgerror_singular(err, flag):
---> 89 raise LinAlgError("Singular matrix")
90
91 def _raise_linalgerror_nonposdef(err, flag):

LinAlgError: Singular matrix
Подскажите, пожалуйста, как победить эту ошибку
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.03.2019, 21:33
Ответы с готовыми решениями:

Ошибка "Error, (in dsolve/numeric/bvp) matrix is singular"
При попытке решения краевой задачи в Maple возникает ошибка Error, (in dsolve/numeric/bvp) matrix is singular Вот сам код: eq :=...

Решение системы нелинейных уравнений 8 уравнений – 8 неизвестных переменных
Решаю систему нелинейных уравнений в символьном виде, решение выполняю с помощью математических программ. Возник вопрос в плане математики,...

Решение системы нелинейных уравнений (для двух уравнений)
Нужна написать программный модуль для решения систем неленейных уравнений методом ньютона и методом простых итераций. Вот уравнения: sinx +...

3
Эксперт Python
 Аватар для dondublon
4649 / 2069 / 366
Регистрация: 17.03.2012
Сообщений: 10,176
Записей в блоге: 6
07.03.2019, 11:58
У меня с вашими значениями решается. Убедитесь, что значения именно таковы.
0
19 / 19 / 14
Регистрация: 06.08.2009
Сообщений: 538
08.03.2019, 15:31  [ТС]
Спасибо, разобрался.
Криво формировалась матрица.
Надо было делать вот так:

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
import matplotlib.pyplot as plt
%matplotlib inline
import math
import numpy as np
 
def f(x):
    return np.sin(x / 5) * np.exp(x / 10) + 5 * np.exp(-x / 2)
 
def polinom(x,w):
    res=[]
    for item_x in x:
        index=0
        summ=0
        for item_w in w:  
            summ+=((item_x**index)*item_w)
            index+=1
        res.append(summ)
    return res
 
def appoximate(points):
    size=len(points) 
    a=np.zeros((size,size))
    i=0
    while i<size:
        j=0
        while j<size:
            a[i,j]=points[i]**j
            j+=1
        i+=1
    b=f(np.array(points))
    w = np.linalg.solve(a, b)
    print w
    return polinom(x,w)    
 
lag = 0.1 #Задаем шаг
x = np.arange(1.0, 15.0+lag, lag) #Вычисляем массив значений X
y = f(x) #Вычисляем значения функции
 
y1=appoximate([1.0,15.0])
y2=appoximate([1.0,8.0,15.0])
y3=appoximate([1.0,4.0,10.0,15.0])
 
#Строим график
fig = plt.figure()
plt.plot(x, y)
plt.plot(x, y1)
plt.plot(x, y2)
plt.plot(x, y3)
Заполнение матрицы, правда, не очень красивое.
Если кто подскажет более красивое решение, буду благодарен.
0
Эксперт Python
 Аватар для dondublon
4649 / 2069 / 366
Регистрация: 17.03.2012
Сообщений: 10,176
Записей в блоге: 6
11.03.2019, 10:24
megabax, numpy поддерживает векторные операции, почитайте какое-нибудь введение.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.03.2019, 10:24
Помогаю со студенческими работами здесь

Решение системы нелинейных уравнений 12 уравнений – 12 неизвестных переменных
мне надо решать такую задачу, помогите мне пожалуйста даны 12 уравнений 1/ A+B+C+D+E+F+G+H+I+J+K+L=24.05 2/...

Решение нестационарной системы уравнений с большим числом уравнений
Доброго дня! Мне необходимо численно решить нестационарное уравнение Шредингера, у которого гамильтониан зависит от времени. В рамках...

Исследовать совместность и найти общее решение и одно частное решение системы уравнений.
Исследовать совместность и найти общее решение и одно частное решение системы уравнений. (3 системы) помогите кто чем может

Решение системы уравнений (5 уравнений, 3 неизвестные)
мучаюсь и не могу решить систему: b0 = (A*( (A+1) + (A-1)*cos(w0) + 2*sqrt(A)*aalpha )) / (A+1) - (A-1)*cos(w0) +...

Решение уравнений и системы уравнений (множества)
Помогите пожалуйста решить задачу, к завтрашнему дню очень нужно... Все задачи в прикрепленной картинке 1 Задача - Решить уравнение,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
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 . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru