Coverage for src / cvx / markowitz / linalg / valid.py: 100%
8 statements
« prev ^ index » next coverage.py v7.12.0, created at 2025-12-08 13:49 +0000
« prev ^ index » next coverage.py v7.12.0, created at 2025-12-08 13:49 +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.
14"""Extract valid submatrix of a matrix."""
16from __future__ import annotations
18import numpy as np
20from .types import Matrix
23def valid(matrix: Matrix) -> tuple[Matrix, Matrix]:
24 """Construct the valid subset of a (correlation) matrix.
26 Args:
27 matrix: n x n matrix.
29 Returns:
30 A tuple of (mask, submatrix) where mask is a boolean vector indicating
31 valid rows/columns and submatrix is the valid subset of the input.
32 """
33 # make sure matrix is quadratic
34 if matrix.shape[0] != matrix.shape[1]:
35 raise ValueError("Matrix must be quadratic")
37 _valid = np.isfinite(np.diag(matrix))
38 return _valid, matrix[:, _valid][_valid]