Coverage for cvx/risk/linalg/valid.py: 100%
7 statements
« prev ^ index » next coverage.py v7.6.8, created at 2024-11-30 11:04 +0000
« prev ^ index » next coverage.py v7.6.8, created at 2024-11-30 11:04 +0000
1# Copyright 2023 Stanford University Convex Optimization Group
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14from __future__ import annotations
16import numpy as np
19def valid(matrix):
20 """
21 Construct the valid subset of matrix (correlation) matrix matrix
22 :param matrix: n x n matrix
24 :return: Tuple of matrix boolean vector indicating if row/column
25 is valid and the valid subset of the matrix
26 """
27 # make sure matrix is quadratic
28 if matrix.shape[0] != matrix.shape[1]:
29 raise AssertionError
31 v = np.isfinite(np.diag(matrix))
32 return v, matrix[:, v][v]