Significance of encoding scheme in Genetic Algorithms












0












$begingroup$


In the basic structure of a genetic algorithm, we have a population which is iteratively changed via selection, crossover, and mutation. Roughly:





  • selection biases the procedure towards individuals with high fitness,


  • crossover combines individuals to generate new individuals,


  • mutation perturbs individuals to generate new individuals which may be completely foreign to what's been seen before.


Intuitively, as an optimization routine, a prerequisite to making this effective should be some assumption of smoothness in the fitness landscape (the function from encoded string to fitness value). Without that assumption (and considering each step separately) [1]:





  • selection would function like a random search/random sampling,


  • crossover would send you to an arbitrary location in the landscape, with no guarantees that a combination of parents actually takes any of their (desirable or not) traits,


  • mutation would not necessary give you a neighbor of your parent (in the fitness sense or even in the sense of having mostly similar traits) - again it can send you to a random location in the landscape.


So without that smoothness assumption, it seems none of the operations are any better than random search/random sampling. Admittedly, any kind of non-exhaustive optimization routine implicitly or otherwise makes at least some smoothness assumptions (simulated annealing and hill climbing both assume neighbors of current state should have closer objective value than a random candidate). What's interesting in the case of a genetic algorithm is that we do not directly operate on the parameters - so there is a chance for/a requirement that the encoding scheme is designed such that the fitness landscape is smooth.



I haven't seen any explicit mention of this idea in the theory. Is this actually a concern? If so, should we be designing encoding schemes so that there's a higher chance that crossover and mutation produce true "neighbors" of their inputs?



[1] I'm aware that the Schema Theorem implies the entire procedure works differently, and does not necessarily require any short of "neighbor" relationship be maintained across the operators. However, it seems even that idea requires some structure from the schemas: "11**" ought to be closer to "1***" than to "0***", but one can imagine a encoding where that's not the case; additionally, "11**" appear equidistant to "10**" and "01**", but in the case where the first digit represents a trait and the second a parameter of the trait, "10**" would be a true neighbor but "01**" would be completely unrelated.










share|cite|improve this question









$endgroup$












  • $begingroup$
    Richard Dawkins' "Climbing Mount Improbable" has an extensive discussion of the impacts of the fitness landscape on evolution. It is oriented toward living things, but the ideas apply. He talks about the differences between a large smooth plain and a mountainous landscape in detail.
    $endgroup$
    – Ross Millikan
    Jan 1 at 17:08










  • $begingroup$
    Natural selection is one of nature's most formidable design tools.
    $endgroup$
    – Cesareo
    Jan 1 at 17:13
















0












$begingroup$


In the basic structure of a genetic algorithm, we have a population which is iteratively changed via selection, crossover, and mutation. Roughly:





  • selection biases the procedure towards individuals with high fitness,


  • crossover combines individuals to generate new individuals,


  • mutation perturbs individuals to generate new individuals which may be completely foreign to what's been seen before.


Intuitively, as an optimization routine, a prerequisite to making this effective should be some assumption of smoothness in the fitness landscape (the function from encoded string to fitness value). Without that assumption (and considering each step separately) [1]:





  • selection would function like a random search/random sampling,


  • crossover would send you to an arbitrary location in the landscape, with no guarantees that a combination of parents actually takes any of their (desirable or not) traits,


  • mutation would not necessary give you a neighbor of your parent (in the fitness sense or even in the sense of having mostly similar traits) - again it can send you to a random location in the landscape.


So without that smoothness assumption, it seems none of the operations are any better than random search/random sampling. Admittedly, any kind of non-exhaustive optimization routine implicitly or otherwise makes at least some smoothness assumptions (simulated annealing and hill climbing both assume neighbors of current state should have closer objective value than a random candidate). What's interesting in the case of a genetic algorithm is that we do not directly operate on the parameters - so there is a chance for/a requirement that the encoding scheme is designed such that the fitness landscape is smooth.



I haven't seen any explicit mention of this idea in the theory. Is this actually a concern? If so, should we be designing encoding schemes so that there's a higher chance that crossover and mutation produce true "neighbors" of their inputs?



[1] I'm aware that the Schema Theorem implies the entire procedure works differently, and does not necessarily require any short of "neighbor" relationship be maintained across the operators. However, it seems even that idea requires some structure from the schemas: "11**" ought to be closer to "1***" than to "0***", but one can imagine a encoding where that's not the case; additionally, "11**" appear equidistant to "10**" and "01**", but in the case where the first digit represents a trait and the second a parameter of the trait, "10**" would be a true neighbor but "01**" would be completely unrelated.










share|cite|improve this question









$endgroup$












  • $begingroup$
    Richard Dawkins' "Climbing Mount Improbable" has an extensive discussion of the impacts of the fitness landscape on evolution. It is oriented toward living things, but the ideas apply. He talks about the differences between a large smooth plain and a mountainous landscape in detail.
    $endgroup$
    – Ross Millikan
    Jan 1 at 17:08










  • $begingroup$
    Natural selection is one of nature's most formidable design tools.
    $endgroup$
    – Cesareo
    Jan 1 at 17:13














0












0








0





$begingroup$


In the basic structure of a genetic algorithm, we have a population which is iteratively changed via selection, crossover, and mutation. Roughly:





  • selection biases the procedure towards individuals with high fitness,


  • crossover combines individuals to generate new individuals,


  • mutation perturbs individuals to generate new individuals which may be completely foreign to what's been seen before.


Intuitively, as an optimization routine, a prerequisite to making this effective should be some assumption of smoothness in the fitness landscape (the function from encoded string to fitness value). Without that assumption (and considering each step separately) [1]:





  • selection would function like a random search/random sampling,


  • crossover would send you to an arbitrary location in the landscape, with no guarantees that a combination of parents actually takes any of their (desirable or not) traits,


  • mutation would not necessary give you a neighbor of your parent (in the fitness sense or even in the sense of having mostly similar traits) - again it can send you to a random location in the landscape.


So without that smoothness assumption, it seems none of the operations are any better than random search/random sampling. Admittedly, any kind of non-exhaustive optimization routine implicitly or otherwise makes at least some smoothness assumptions (simulated annealing and hill climbing both assume neighbors of current state should have closer objective value than a random candidate). What's interesting in the case of a genetic algorithm is that we do not directly operate on the parameters - so there is a chance for/a requirement that the encoding scheme is designed such that the fitness landscape is smooth.



I haven't seen any explicit mention of this idea in the theory. Is this actually a concern? If so, should we be designing encoding schemes so that there's a higher chance that crossover and mutation produce true "neighbors" of their inputs?



[1] I'm aware that the Schema Theorem implies the entire procedure works differently, and does not necessarily require any short of "neighbor" relationship be maintained across the operators. However, it seems even that idea requires some structure from the schemas: "11**" ought to be closer to "1***" than to "0***", but one can imagine a encoding where that's not the case; additionally, "11**" appear equidistant to "10**" and "01**", but in the case where the first digit represents a trait and the second a parameter of the trait, "10**" would be a true neighbor but "01**" would be completely unrelated.










share|cite|improve this question









$endgroup$




In the basic structure of a genetic algorithm, we have a population which is iteratively changed via selection, crossover, and mutation. Roughly:





  • selection biases the procedure towards individuals with high fitness,


  • crossover combines individuals to generate new individuals,


  • mutation perturbs individuals to generate new individuals which may be completely foreign to what's been seen before.


Intuitively, as an optimization routine, a prerequisite to making this effective should be some assumption of smoothness in the fitness landscape (the function from encoded string to fitness value). Without that assumption (and considering each step separately) [1]:





  • selection would function like a random search/random sampling,


  • crossover would send you to an arbitrary location in the landscape, with no guarantees that a combination of parents actually takes any of their (desirable or not) traits,


  • mutation would not necessary give you a neighbor of your parent (in the fitness sense or even in the sense of having mostly similar traits) - again it can send you to a random location in the landscape.


So without that smoothness assumption, it seems none of the operations are any better than random search/random sampling. Admittedly, any kind of non-exhaustive optimization routine implicitly or otherwise makes at least some smoothness assumptions (simulated annealing and hill climbing both assume neighbors of current state should have closer objective value than a random candidate). What's interesting in the case of a genetic algorithm is that we do not directly operate on the parameters - so there is a chance for/a requirement that the encoding scheme is designed such that the fitness landscape is smooth.



I haven't seen any explicit mention of this idea in the theory. Is this actually a concern? If so, should we be designing encoding schemes so that there's a higher chance that crossover and mutation produce true "neighbors" of their inputs?



[1] I'm aware that the Schema Theorem implies the entire procedure works differently, and does not necessarily require any short of "neighbor" relationship be maintained across the operators. However, it seems even that idea requires some structure from the schemas: "11**" ought to be closer to "1***" than to "0***", but one can imagine a encoding where that's not the case; additionally, "11**" appear equidistant to "10**" and "01**", but in the case where the first digit represents a trait and the second a parameter of the trait, "10**" would be a true neighbor but "01**" would be completely unrelated.







optimization






share|cite|improve this question













share|cite|improve this question











share|cite|improve this question




share|cite|improve this question










asked Jan 1 at 16:59









Roasted YamRoasted Yam

132




132












  • $begingroup$
    Richard Dawkins' "Climbing Mount Improbable" has an extensive discussion of the impacts of the fitness landscape on evolution. It is oriented toward living things, but the ideas apply. He talks about the differences between a large smooth plain and a mountainous landscape in detail.
    $endgroup$
    – Ross Millikan
    Jan 1 at 17:08










  • $begingroup$
    Natural selection is one of nature's most formidable design tools.
    $endgroup$
    – Cesareo
    Jan 1 at 17:13


















  • $begingroup$
    Richard Dawkins' "Climbing Mount Improbable" has an extensive discussion of the impacts of the fitness landscape on evolution. It is oriented toward living things, but the ideas apply. He talks about the differences between a large smooth plain and a mountainous landscape in detail.
    $endgroup$
    – Ross Millikan
    Jan 1 at 17:08










  • $begingroup$
    Natural selection is one of nature's most formidable design tools.
    $endgroup$
    – Cesareo
    Jan 1 at 17:13
















$begingroup$
Richard Dawkins' "Climbing Mount Improbable" has an extensive discussion of the impacts of the fitness landscape on evolution. It is oriented toward living things, but the ideas apply. He talks about the differences between a large smooth plain and a mountainous landscape in detail.
$endgroup$
– Ross Millikan
Jan 1 at 17:08




$begingroup$
Richard Dawkins' "Climbing Mount Improbable" has an extensive discussion of the impacts of the fitness landscape on evolution. It is oriented toward living things, but the ideas apply. He talks about the differences between a large smooth plain and a mountainous landscape in detail.
$endgroup$
– Ross Millikan
Jan 1 at 17:08












$begingroup$
Natural selection is one of nature's most formidable design tools.
$endgroup$
– Cesareo
Jan 1 at 17:13




$begingroup$
Natural selection is one of nature's most formidable design tools.
$endgroup$
– Cesareo
Jan 1 at 17:13










0






active

oldest

votes











Your Answer





StackExchange.ifUsing("editor", function () {
return StackExchange.using("mathjaxEditing", function () {
StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix) {
StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
});
});
}, "mathjax-editing");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "69"
};
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
},
noCode: true, onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmath.stackexchange.com%2fquestions%2f3058656%2fsignificance-of-encoding-scheme-in-genetic-algorithms%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes
















draft saved

draft discarded




















































Thanks for contributing an answer to Mathematics Stack Exchange!


  • 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.


Use MathJax to format equations. MathJax reference.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmath.stackexchange.com%2fquestions%2f3058656%2fsignificance-of-encoding-scheme-in-genetic-algorithms%23new-answer', 'question_page');
}
);

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







Popular posts from this blog

Bressuire

Cabo Verde

Gyllenstierna