Comments (2)
So, the part about constructing a multi-output surrogate model is correct. That should indeed happen. The issue is scalarizing the outputs from the model, using an arbitrary sum. We do support ScalarizedObjective
, which is the intentional way of doing this, where the user can specify the scalarization weights.
qNParEGO
is also different here, since it is a multi-objective acquisition function that internally uses a scalarization. It is defined to work with multiple objectives and the behavior is by design.
The issue is doing this silently using arbitrary weights (well, they're just 1 for maximization and -1 for minimization) with acquisition functions that are not designed for multi-objective optimization.
from ax.
Actually, in my (very limited) knowledge, isn't this how MOBO is supposed to work? If you look at the BoTorch documentation for MOBO, especially where the model is initialized, you find:
def initialize_model(train_x, train_obj):
# define models for objective and constraint
train_x = normalize(train_x, problem.bounds)
models = []
for i in range(train_obj.shape[-1]):
train_y = train_obj[..., i : i + 1]
train_yvar = torch.full_like(train_y, NOISE_SE[i] ** 2)
models.append(
FixedNoiseGP(
train_x, train_y, train_yvar, outcome_transform=Standardize(m=1)
)
)
model = ModelListGP(*models)
mll = SumMarginalLogLikelihood(model.likelihood, model)
return mll, model
(in our case we are discussing SingleTaskGP
s, but this does not change the nature of the problem, I think). If this tracks I would think that a ModelList
containing two SingleTaskGP
s would be the way to do MOBO as well, no?
Edit: This is the case for qNParEGO
at least, for example, which uses Chebyshev scalarization, as far as I can see.
from ax.
Related Issues (20)
- Last trial not being recognized (in the submitit tutorial) HOT 3
- Ax pulling numpy 2.0 with breaking changes HOT 3
- How to set the beta coefficient of generation strategy? HOT 6
- Numpy 2.0 Compatibility Issue HOT 1
- save the state HOT 9
- Defining a Model class for ModelListGP HOT 2
- Error : Try again with more data HOT 26
- Using nonlinear constraints with boolean masks HOT 5
- input data is not standardized (mean = tensor([0.] HOT 9
- nonlinear constarined in evaluate paramter instead add to the experiment HOT 2
- Ax 0.4.0 Causing Segmentation Fault When Calling `.get_next_trial()` HOT 2
- Defining Metric in Ax Service HOT 2
- Hierarchical Search Spaces with Multiple Independent Search Spaces HOT 3
- Services API :×1-1.5*×2>=0 HOT 4
- primary_objective and secondary_objective HOT 1
- Comparison of multi-objective acquistion functions HOT 14
- plot_pareto_frontier HOT 6
- attach trials HOT 8
- Multi-task BO with Service API HOT 2
- constrains HOT 17
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from ax.