Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Generalize ReHLine to solve quadratic problems with linear constraints #6

Closed
wants to merge 2 commits into from

Conversation

aorazalin
Copy link
Contributor

ReHLine is designed to solve problems of the kind
$$\min_{\mathbf{\beta} \in \mathbb{R}^d} \frac{1}{2}||\beta||^2 + \sum_{i=1}^n L_i(\mathbf{x}_i^T \mathbf{\beta}) (*)$$
s.t. $\mathbf{Aw} + \mathbf{b} \geq \mathbf{0}$ where $L_i$ are PLQ convex loss functions.

This PR aims to add a straightforward generalization (for details, see the attachment) to the ReHLine algorithm to solve problems the kind
$$\min_{\mathbf{\beta} \in \mathbb{R}^d} \frac{1}{2}\mathbf{\beta}^T \mathbf{P} \mathbf(\beta) - \mathbf{\mu}^T \mathbf{\beta} + \sum_{i=1}^n L_i(\mathbf{x}_i^T \mathbf{\beta})$$
s.t. $\mathbf{Aw} + \mathbf{b} \geq \mathbf{0}$ where $L_i$ are PLQ convex loss functions, and $\mathbf{P}$ is a PSD matrix.

It is of course possible to transform the above problem to the original problem (*) using linear transformations. However, there are cases where that might not be desirable. For example, instead of running cholesky decomposition one might have a very fast way to solve $\mathbf{Px} = \mathbf{y}$ (which is intrinsic to how the modified ReHLine algorithm runs), e.g. portfolio optmization with factor modelling.

PR_details.pdf

@statmlben
Copy link
Member

As its performance appears to be slightly suboptimal compared to variable substitution approach, I will put on hold this push for further investigation and improvement.

@statmlben statmlben closed this Aug 5, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants