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

[Roadmap] Multiple outputs. #9043

Open
4 of 39 tasks
trivialfis opened this issue Apr 17, 2023 · 14 comments
Open
4 of 39 tasks

[Roadmap] Multiple outputs. #9043

trivialfis opened this issue Apr 17, 2023 · 14 comments

Comments

@trivialfis
Copy link
Member

trivialfis commented Apr 17, 2023

Since the XGBoost 1.6, we have been working on having multi-output support for the tree model. In 2.0, we will have the initial implementation for the vector-leaf-based multi-output model. This issue is a tracker for future development and for related discussion. The original feature request is here: #2087 . The related features are for vector leaf instead of general multi-output.

Feel free to share your suggestions or make related feature requests in the comments.

Implementation Optimization

Algorithmic Optimization

We are still looking for potential algorithmic optimization for vector-leaf and here's the pool of candidates. We need to survey all available options. Feel free to share if you have ideas or paper recommendations.

GPU Implementation

  • Evaluation
  • Histogram
  • Prediction

Documentation

  • Derive the approximated hessian in the context of boosting trees.

Multi-task

Features

Learning to rank

We can have a ranking model to consider multiple criteria. This might require multi-task to be supported.

Quantile regression

  • l1
  • quantile

Distributed

Binding

HPO

  • Check compatibility with major HPO frameworks.

Other extensions

  • Sparse label. (multi-label classification optimization)
  • Missing label.
  • Early stopping for each target?

Applications

Benchmarks

  • Collection of datasets for future comparison.
@CarloLepelaars
Copy link

CarloLepelaars commented Oct 30, 2023

Hi, great work on the initial multitarget implementation!

Given the roadmap when can we expect GPU support for multi output regression? When this support is added will xgboost-ray also support it?

@trivialfis
Copy link
Member Author

Hi @CarloLepelaars ,

  • For model-per-target, it's already implemented.
  • For vector leaf, it will take some more work, but eventually yes. I don't have an eta for when it will be available.
  • I think there is on-going work on the ray-xgboost, but you will need to open an issue on that repository for concrete answers.

@wiktorolszowy
Copy link

Hi, very nice work! I am wondering how SHAP should be used for multi-output models, e.g. how to explain links between the Ys, and how to interpret the effects of Xs - e.g., which Xs display common effects across the Ys, and which Xs display differential effects. Do you know a good example of using SHAP for a multi-output model?

@trivialfis
Copy link
Member Author

For model per target, it's the same as single target. As for vector leaf, I haven't looked into it yet, but no significant difference on top of my mind.

@lcrmorin
Copy link

I am currently toying with multitargets approach ... I have a hard time defining a custom metric (haven't tried custom loss). Preds seems to be of size (len(y) x len(targets)) while y_true is of shape (len(y), len(targets)), I have managed to handle this internally to my metric to return one value. But now I have an error about an output being a tuple instead of a number.
Any way to handle this properly or is it too early ?

@Reederey87
Copy link

Hi.

Did anybody train the multiple outputs XGBoost model on Mac arm64 machine?

On recent stable version I have got error:
XGBoostError('[...] Check failed: !trees.front()->IsMultiTarget(): Update tree leaf support for multi-target tree is not yet implemented.

On latest nightly version xgboost-2.1.0.dev0+a7226c02223246be78a59c3a4e8c32d1c68c1ff9 - I have managed load CPU, but it was no feedback on terminal window.

@aniruddhghatpande
Copy link

Is the vector-leaf-based multi-output model still work in progress ? Also what research paper based on which splitting mechanism for decision trees is working for this ? @trivialfis

@trivialfis
Copy link
Member Author

yes, it's still working in progress.

@mxdub
Copy link

mxdub commented Mar 25, 2024

Hi @trivialfis,

I'm currently working on some models using XGBoostLSS which as far as I understand is based on the multi-output feature of XGBoost. I wonder how monotonic constraints are considered in the multi-ouput case ? It seems constraints are shared among trees built for each target, could you confirm ?

Thanks for your work on this feature !

@abseejp
Copy link

abseejp commented Sep 5, 2024

Hello @trivialfis, I'm working on a multi label binary classification problem (I have three targets) and all my targets are highly imbalanced. But I don't seem to understand how I can leverage scale_pos_weight to help with that.

Also, will I be able to access functionalities such as shapley values computation?

@asrpv
Copy link

asrpv commented Nov 10, 2024

Hi @trivialfis , I have been using the muli-ouput-tree feature on a couple of real world datasets across tasks of regression and classification and also with custom loss functions, the results are great. An observation:

The JSON model file of the multi-output-tree model doesn't include loss_changesand sum_hessian. Any particular reason for not providing that? Given that we do a diagonal approximation of hessian, won't the sum_hessian simply be a vector of each target's hessian? and likewise for loss_changes? Is it possible to provide them? I believe providing them would be beneficial in both making sense of the tree splits and also in Tree SHAP (by modifying the JSON of the multi-output-tree model into that of a single target by keeping the target of interest).

Thanks for the great work on this! Looking forward for the successful implementation of the roadmap.

@trivialfis
Copy link
Member Author

Any particular reason for not providing that

It's still working in progress. We still need to add these fields.

Given that we do a diagonal approximation of hessian

This happens only if the output targets are correlated, like softmax. For multi-target regression, we assume targets are independent in the gradient calculation. The potential dependencies are captured in the output tree instead of the gradient calculation.

@miladbarooni
Copy link

Hi @trivialfis
I encountered a problem when attempting to refresh a multi-output tree using the xgboost.Booster class from the Python API. The error is:

Check failed: gpair->Shape(1) == 1 (10 vs. 1): support for multi-target tree is not yet implemented. (Which is likely related to this line)

Why can't we perform the same procedure as single-output trees? In my specific scenario, I aim to adjust the leaf values using the updated gradient statistics from a different dataset without changing thresholds. Due to the small sample size, each iteration requires me to update the previous trees for each new batch of samples based on their gradients.

@trivialfis
Copy link
Member Author

I'm currently trying to work on some other priorities, will get back to this.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

10 participants