How to impletement a multi-objective optimization in Optaplanner?
I want to implement a multi-objective optimization with Optaplanner, and I have read the "Pareto Scoring" chapter in the document. I understood the principle of multi-objective planning in optaplanner, but don't actually know how to implement it, there are bellow queries:
How to design a custom score definition class, which class it should extend from, and what filed it should have basically?
As a multi-objective planning, I have to provide multiple solutions to the user. But the best solution is only one, how can I keep more than one solutions while planning? Does it mean, in the bestScoreChange event, I have to calculate the scores, find and keep the best solutions for each objective?
optaplanner
add a comment |
I want to implement a multi-objective optimization with Optaplanner, and I have read the "Pareto Scoring" chapter in the document. I understood the principle of multi-objective planning in optaplanner, but don't actually know how to implement it, there are bellow queries:
How to design a custom score definition class, which class it should extend from, and what filed it should have basically?
As a multi-objective planning, I have to provide multiple solutions to the user. But the best solution is only one, how can I keep more than one solutions while planning? Does it mean, in the bestScoreChange event, I have to calculate the scores, find and keep the best solutions for each objective?
optaplanner
Do you have an example of what you are trying to achieve? If you have two different goals can you simply run two different solvers at the same time with two different sets of rules?
– code4dc
2 days ago
I am developing a job shop project that a system makes a production planning every day. I got 2 goals for the production plan from the user - start the task as soon as possible and minimize the cost, these goals are different. after optaplanner solved, I want to provide the best solution for these each goal. I don't think it's work to split the goals into a different set of rules and run them side by side, due to these goals have some dependencies to each other.
– Kent Zhang
yesterday
add a comment |
I want to implement a multi-objective optimization with Optaplanner, and I have read the "Pareto Scoring" chapter in the document. I understood the principle of multi-objective planning in optaplanner, but don't actually know how to implement it, there are bellow queries:
How to design a custom score definition class, which class it should extend from, and what filed it should have basically?
As a multi-objective planning, I have to provide multiple solutions to the user. But the best solution is only one, how can I keep more than one solutions while planning? Does it mean, in the bestScoreChange event, I have to calculate the scores, find and keep the best solutions for each objective?
optaplanner
I want to implement a multi-objective optimization with Optaplanner, and I have read the "Pareto Scoring" chapter in the document. I understood the principle of multi-objective planning in optaplanner, but don't actually know how to implement it, there are bellow queries:
How to design a custom score definition class, which class it should extend from, and what filed it should have basically?
As a multi-objective planning, I have to provide multiple solutions to the user. But the best solution is only one, how can I keep more than one solutions while planning? Does it mean, in the bestScoreChange event, I have to calculate the scores, find and keep the best solutions for each objective?
optaplanner
optaplanner
asked Dec 27 at 13:13
Kent Zhang
205
205
Do you have an example of what you are trying to achieve? If you have two different goals can you simply run two different solvers at the same time with two different sets of rules?
– code4dc
2 days ago
I am developing a job shop project that a system makes a production planning every day. I got 2 goals for the production plan from the user - start the task as soon as possible and minimize the cost, these goals are different. after optaplanner solved, I want to provide the best solution for these each goal. I don't think it's work to split the goals into a different set of rules and run them side by side, due to these goals have some dependencies to each other.
– Kent Zhang
yesterday
add a comment |
Do you have an example of what you are trying to achieve? If you have two different goals can you simply run two different solvers at the same time with two different sets of rules?
– code4dc
2 days ago
I am developing a job shop project that a system makes a production planning every day. I got 2 goals for the production plan from the user - start the task as soon as possible and minimize the cost, these goals are different. after optaplanner solved, I want to provide the best solution for these each goal. I don't think it's work to split the goals into a different set of rules and run them side by side, due to these goals have some dependencies to each other.
– Kent Zhang
yesterday
Do you have an example of what you are trying to achieve? If you have two different goals can you simply run two different solvers at the same time with two different sets of rules?
– code4dc
2 days ago
Do you have an example of what you are trying to achieve? If you have two different goals can you simply run two different solvers at the same time with two different sets of rules?
– code4dc
2 days ago
I am developing a job shop project that a system makes a production planning every day. I got 2 goals for the production plan from the user - start the task as soon as possible and minimize the cost, these goals are different. after optaplanner solved, I want to provide the best solution for these each goal. I don't think it's work to split the goals into a different set of rules and run them side by side, due to these goals have some dependencies to each other.
– Kent Zhang
yesterday
I am developing a job shop project that a system makes a production planning every day. I got 2 goals for the production plan from the user - start the task as soon as possible and minimize the cost, these goals are different. after optaplanner solved, I want to provide the best solution for these each goal. I don't think it's work to split the goals into a different set of rules and run them side by side, due to these goals have some dependencies to each other.
– Kent Zhang
yesterday
add a comment |
1 Answer
1
active
oldest
votes
If you really just have 2 goals, you can also fake it through running the Solver twice with different score levels in the @ConstraintWeights in the @ConstraintConfiguration class.
Real pareto solving is much more complex and requires adjustments to the BestScolutionRecaller, which is just the tip of the iceberg.
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53945695%2fhow-to-impletement-a-multi-objective-optimization-in-optaplanner%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
If you really just have 2 goals, you can also fake it through running the Solver twice with different score levels in the @ConstraintWeights in the @ConstraintConfiguration class.
Real pareto solving is much more complex and requires adjustments to the BestScolutionRecaller, which is just the tip of the iceberg.
add a comment |
If you really just have 2 goals, you can also fake it through running the Solver twice with different score levels in the @ConstraintWeights in the @ConstraintConfiguration class.
Real pareto solving is much more complex and requires adjustments to the BestScolutionRecaller, which is just the tip of the iceberg.
add a comment |
If you really just have 2 goals, you can also fake it through running the Solver twice with different score levels in the @ConstraintWeights in the @ConstraintConfiguration class.
Real pareto solving is much more complex and requires adjustments to the BestScolutionRecaller, which is just the tip of the iceberg.
If you really just have 2 goals, you can also fake it through running the Solver twice with different score levels in the @ConstraintWeights in the @ConstraintConfiguration class.
Real pareto solving is much more complex and requires adjustments to the BestScolutionRecaller, which is just the tip of the iceberg.
answered 43 mins ago
Geoffrey De Smet
14.7k54088
14.7k54088
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53945695%2fhow-to-impletement-a-multi-objective-optimization-in-optaplanner%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Do you have an example of what you are trying to achieve? If you have two different goals can you simply run two different solvers at the same time with two different sets of rules?
– code4dc
2 days ago
I am developing a job shop project that a system makes a production planning every day. I got 2 goals for the production plan from the user - start the task as soon as possible and minimize the cost, these goals are different. after optaplanner solved, I want to provide the best solution for these each goal. I don't think it's work to split the goals into a different set of rules and run them side by side, due to these goals have some dependencies to each other.
– Kent Zhang
yesterday