3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-12 22:18:23 +01:00
dft_tools/pytriqs/gf/local/matrix_stack.pyx
Olivier Parcollet f2c7d449cc First commit : triqs libs version 1.0 alpha1
for earlier commits, see TRIQS0.x repository.
2013-07-17 19:24:07 +02:00

35 lines
1.2 KiB
Cython

import numpy
class MatrixStack:
def __init__(self, A):
"""
"""
self.data = A
self.is_double = A.dtype in [numpy.float, numpy.float64, numpy.float128, numpy.float, numpy.float_]
def add(self, M):
if self.is_double:
matrix_stack[double](self.data).iadd(matrix_view[double](M))
else:
matrix_stack[dcomplex](self.data).iadd(matrix_view[dcomplex](M.astype(numpy.complex)))
def sub(self, M):
if self.is_double:
matrix_stack[double](self.data).isub(matrix_view[double](M))
else:
matrix_stack[dcomplex](self.data).isub(matrix_view[dcomplex](M.astype(numpy.complex)))
def matmul_L_R(self, L, D, R):
if self.is_double:
matrix_stack[double](self.data).onsite_matmul_L_R(matrix_view[double](L), matrix_stack[double](D), matrix_view[double](R))
else:
matrix_stack[dcomplex](self.data).onsite_matmul_L_R(
matrix_view[dcomplex](L.astype(numpy.complex)), matrix_stack[dcomplex](D), matrix_view[dcomplex](R.astype(numpy.complex)))
def invert(self):
if self.is_double:
matrix_stack[double](self.data).invert()
else:
matrix_stack[dcomplex](self.data).invert()