Как получить единичную матрицу из numpy.dot (A, A_inv)

Я готовлю матрицу случайных чисел, вычисляю ее обратную и матрицу умножаю на исходную матрицу. Это, в теории, дает единичную матрицу. Как я могу позволитьnumpy сделать это для меня?

import numpy

A = numpy.zeros((100,100))
E = numpy.zeros((100,100))

size = 100

for i in range(size):
    for j in range(size):
        A[i][j]+=numpy.random.randint(10)
        if i == j:
            E[i][j]+=1

A_inv = numpy.linalg.linalg.inv(A)
print numpy.dot(A, A_inv)

Запуск кода производит

[me]machine @ numeric $ python rand_diag.py 
[[  1.00000000e+00  -7.99360578e-15  -1.14491749e-16 ...,   3.81639165e-17
   -4.42701431e-15   1.17961196e-15]
[ -5.55111512e-16   1.00000000e+00  -2.22044605e-16 ...,  -3.88578059e-16
    1.33226763e-15  -8.32667268e-16]

Это'Очевидно, что результат представляет собой единичную матрицу, но не точно, поэтомуprint numpy.dot(A, A_inv) == E очевидно даетFalse, Я'Я делаю это для практики линейной алгебры и пытаюсь найти размер матрицы, для которой моя машина достигает своих пределов. ПолучениеTrue будет дидактически привлекательным.

Редактировать:

настройкаsize=10000Мне не хватает памяти

[me]machine @ numeric $ Python(794) malloc:
***mmap(size=800002048) failed (error code=12)
*** error: can\'t allocate region
*** set a breakpoint in malloc_error_break to debug
Traceback (most recent call last):
File "rand_diag.py", line 14, in      A_inv = numpy.linalg.linalg.inv(A)
File "/Library/Frameworks/Python.framework/Versions/7.2/lib/python2.7/site-packages/numpy/linalg/linalg.py", line 445, in inv
return wrap(solve(a, identity(a.shape[0], dtype=a.dtype)))
File "/Library/Frameworks/Python.framework/Versions/7.2/lib/python2.7/site-packages/numpy/linalg/linalg.py", line 323, in solve
a, b = _fastCopyAndTranspose(t, a, b)
File "/Library/Frameworks/Python.framework/Versions/7.2/lib/python2.7/site-packages/numpy/linalg/linalg.py", line 143, in _fastCopyAndTranspose
cast_arrays = cast_arrays + (_fastCT(a),)
MemoryError

[1]+  Exit 1                  python rand_diag.py

Как я могу выделить больше памяти и как я могу запустить это параллельно (у меня есть 4 ядра)?

Ответы на вопрос(4)

Ваш ответ на вопрос