diff --git a/src/mps.hpp b/src/mps.hpp index 0d3ffd1..a916314 100644 --- a/src/mps.hpp +++ b/src/mps.hpp @@ -116,6 +116,12 @@ std::tuple, e::Tensor, e::Tensor> split_truncate_theta(const e::MatrixX& theta, e::Index chivL, e::Index dL, e::Index dR, e::Index chivR, size_t chiMax, dtype eps); +/** + * @brief Apply a pertubation to the entries in the physical dimension of the B tensors + * @details + * For each value in the physical dimension, adds a random value between 0 and `pertubationStrength`. + * Then, every tensor is normalized again. + */ template void applyPertubationOnB(std::vector>& Bs, double pertubationStrength) { std::mt19937 generator(493852934); // Mersenne twister rng