From d547be731240f6ee89c91446518796a3eaf2d47e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Patrick=20Gel=C3=9F?= <38036185+PGelss@users.noreply.github.com> Date: Wed, 13 Mar 2024 15:15:31 +0100 Subject: [PATCH] use larger ranks for Krylov tensors --- scikit_tt/solvers/ode.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/scikit_tt/solvers/ode.py b/scikit_tt/solvers/ode.py index 60f5244..437a8e2 100644 --- a/scikit_tt/solvers/ode.py +++ b/scikit_tt/solvers/ode.py @@ -1318,7 +1318,7 @@ def krylov(operator: 'TT', initial_value: 'TT', dimension: int, step_size: float alpha = (w_tmp.transpose(conjugate=True)@krylov_tensors[-1]) T[0,0] = alpha w_tmp = w_tmp - alpha*krylov_tensors[-1] - w_tmp = w_tmp.ortho(threshold=threshold, max_rank=max_rank) + w_tmp = w_tmp.ortho(threshold=threshold, max_rank=2*max_rank) for i in range(1,dimension): beta = w_tmp.norm() T[i,i-1] = beta @@ -1328,7 +1328,7 @@ def krylov(operator: 'TT', initial_value: 'TT', dimension: int, step_size: float alpha = (w_tmp.transpose(conjugate=True)@krylov_tensors[-1]) T[i,i] = alpha w_tmp = w_tmp - alpha*krylov_tensors[-1] - beta*krylov_tensors[-2] - w_tmp = w_tmp.ortho(threshold=threshold, max_rank=max_rank) + w_tmp = w_tmp.ortho(threshold=threshold, max_rank=2*max_rank) # compute time-evolved state w_tmp = np.zeros([dimension], dtype=complex)