MarketEstimation of distribution algorithm
Company Profile

Estimation of distribution algorithm

Estimation of distribution algorithms (EDAs), sometimes called probabilistic model-building genetic algorithms (PMBGAs), are stochastic optimization methods that guide the search for the optimum by building and sampling explicit probabilistic models of promising candidate solutions. Optimization is viewed as a series of incremental updates of a probabilistic model, starting with the model encoding an uninformative prior over admissible solutions and ending with the model that generates only the global optima.

Estimation of distribution algorithms (EDAs)
This section describes the models built by some well known EDAs of different levels of complexity. It is always assumed a population P(t) at the generation t, a selection operator S, a model-building operator \alpha and a sampling operator \beta. ==Univariate factorizations==
Univariate factorizations
The most simple EDAs assume that decision variables are independent, i.e. p(X_1,X_2) = p(X_1)\cdot p(X_2). Therefore, univariate EDAs rely only on univariate statistics and multivariate distributions must be factorized as the product of N univariate probability distributions, D_\text{Univariate} := p(X_1,\dots,X_N) = \prod_{i=1}^N p(X_i). Such factorizations are used in many different EDAs, next we describe some of them. Univariate marginal distribution algorithm (UMDA) The UMDA is a simple EDA that uses an operator \alpha_{UMDA} to estimate marginal probabilities from a selected population S(P(t)). By assuming S(P(t)) contain \lambda elements, \alpha_{UMDA} produces probabilities: p_{t+1}(X_i) = \dfrac{1}{\lambda} \sum_{x\in S(P(t))} x_i,~\forall i\in 1,2,\dots,N. Every UMDA step can be described as follows D(t+1) = \alpha_\text{UMDA} \circ S \circ \beta_{\lambda}(D(t)). ===Population-based incremental learning (PBIL)=== The PBIL, represents the population implicitly by its model, from which it samples new solutions and updates the model. At each generation, \mu individuals are sampled and \lambda\leq \mu are selected. Such individuals are then used to update the model as follows p_{t+1}(X_i) = (1- \gamma) p_{t}(X_i) + (\gamma/\lambda) \sum_{x\in S(P(t))} x_i,~\forall i\in 1,2,\dots,N, where \gamma\in(0,1] is a parameter defining the learning rate, a small value determines that the previous model p_t(X_i) should be only slightly modified by the new solutions sampled. PBIL can be described as D(t+1) = \alpha_\text{PIBIL} \circ S \circ \beta_\mu(D(t)) Compact genetic algorithm (cGA) The CGA, also relies on the implicit populations defined by univariate distributions. At each generation t, two individuals x,y are sampled, P(t)=\beta_2(D(t)). The population P(t) is then sorted in decreasing order of fitness, S_{\text{Sort}(f)}(P(t)), with u being the best and v being the worst solution. The CGA estimates univariate probabilities as follows p_{t+1}(X_i) = p_t(X_i) + \gamma (u_i - v_i), \quad\forall i\in 1,2,\dots,N, where, \gamma\in(0,1] is a constant defining the learning rate, usually set to \gamma=1/N. The CGA can be defined as D(t+1) = \alpha_\text{CGA} \circ S_{\text{Sort}(f)} \circ \beta_2(D(t)) ==Bivariate factorizations==
Bivariate factorizations
Although univariate models can be computed efficiently, in many cases they are not representative enough to provide better performance than GAs. In order to overcome such a drawback, the use of bivariate factorizations was proposed in the EDA community, in which dependencies between pairs of variables could be modeled. A bivariate factorization can be defined as follows, where \pi_i contains a possible variable dependent to X_i, i.e. |\pi_i|=1. D_\text{Bivariate} := p(X_1,\dots,X_N) = \prod_{i=1}^{N} p(X_i|\pi_i). Bivariate and multivariate distributions are usually represented as probabilistic graphical models (graphs), in which edges denote statistical dependencies (or conditional probabilities) and vertices denote variables. To learn the structure of a PGM from data linkage-learning is employed. Mutual information maximizing input clustering (MIMIC) The MIMIC factorizes the joint probability distribution in a chain-like model representing successive dependencies between variables. It finds a permutation of the decision variables, r : i \mapsto j, such that x_{r(1)}x_{r(2)},\dots,x_{r(N)} minimizes the Kullback–Leibler divergence in relation to the true probability distribution, i.e. \pi_{r(i+1)} = \{X_{r(i)}\}. MIMIC models a distribution p_{t+1}(X_1,\dots,X_N) = p_t(X_{r(N)}) \prod_{i=1}^{N-1} p_t(X_{r(i)}|X_{r(i+1)}). New solutions are sampled from the leftmost to the rightmost variable, the first is generated independently and the others according to conditional probabilities. Since the estimated distribution must be recomputed each generation, MIMIC uses concrete populations in the following way P(t+1) = \beta_\mu \circ \alpha_\text{MIMIC} \circ S(P(t)). Bivariate marginal distribution algorithm (BMDA) The BMDA factorizes the joint probability distribution in bivariate distributions. First, a randomly chosen variable is added as a node in a graph, the most dependent variable to one of those in the graph is chosen among those not yet in the graph, this procedure is repeated until no remaining variable depends on any variable in the graph (verified according to a threshold value). The resulting model is a forest with multiple trees rooted at nodes \Upsilon_t. Considering I_t the non-root variables, BMDA estimates a factorized distribution in which the root variables can be sampled independently, whereas all the others must be conditioned to the parent variable \pi_i. p_{t+1}(X_1,\dots,X_N) = \prod_{X_i\in \Upsilon_t} p_t(X_i) \cdot \prod_{X_i\in I_t} p_t(X_i | \pi_i). Each step of BMDA is defined as follows P(t+1) = \beta_\mu \circ \alpha_\text{BMDA} \circ S(P(t)). ==Multivariate factorizations==
Multivariate factorizations
The next stage of EDAs development was the use of multivariate factorizations. In this case, the joint probability distribution is usually factorized in a number of components of limited size |\pi_i| \leq K,~\forall i\in 1,2,\dots,N. p(X_1,\dots,X_N) = \prod_{i=1}^{N} p(X_i|\pi_i) The learning of PGMs encoding multivariate distributions is a computationally expensive task, therefore, it is usual for EDAs to estimate multivariate statistics from bivariate statistics. Such relaxation allows PGM to be built in polynomial time in N; however, it also limits the generality of such EDAs. Extended compact genetic algorithm (eCGA) The ECGA was one of the first EDA to employ multivariate factorizations, in which high-order dependencies among decision variables can be modeled. Its approach factorizes the joint probability distribution in the product of multivariate marginal distributions. Assume T_\text{eCGA}=\{\tau_1,\dots,\tau_\Psi\} is a set of subsets, in which every \tau\in T_\text{eCGA} is a linkage set, containing |\tau|\leq K variables. The factorized joint probability distribution is represented as follows p(X_1,\dots,X_N) = \prod_{\tau\in T_\text{eCGA}} p(\tau). The ECGA popularized the term "linkage-learning" as denoting procedures that identify linkage sets. Its linkage-learning procedure relies on two measures: (1) the Model Complexity (MC) and (2) the Compressed Population Complexity (CPC). The MC quantifies the model representation size in terms of number of bits required to store all the marginal probabilities MC = \log_2 (\lambda+1) \sum_{\tau\in T_\text{eCGA}} (2^{|\tau|-1}), The CPC, on the other hand, quantifies the data compression in terms of entropy of the marginal distribution over all partitions, where \lambda is the selected population size, |\tau| is the number of decision variables in the linkage set \tau and H(\tau) is the joint entropy of the variables in \tau CPC = \lambda \sum_{\tau\in T_\text{eCGA}} H(\tau). The linkage-learning in ECGA works as follows: (1) Insert each variable in a cluster, (2) compute CCC = MC + CPC of the current linkage sets, (3) verify the increase on CCC provided by joining pairs of clusters, (4) effectively joins those clusters with highest CCC improvement. This procedure is repeated until no CCC improvements are possible and produces a linkage model T_\text{eCGA}. The ECGA works with concrete populations, therefore, using the factorized distribution modeled by ECGA, it can be described as P(t+1) = \beta_\mu \circ \alpha_\text{eCGA} \circ S(P(t)) Bayesian optimization algorithm (BOA) The BOA uses Bayesian networks to model and sample promising solutions. Bayesian networks are directed acyclic graphs, with nodes representing variables and edges representing conditional probabilities between pair of variables. The value of a variable x_i can be conditioned on a maximum of K other variables, defined in \pi_i. BOA builds a PGM encoding a factorized joint distribution, in which the parameters of the network, i.e. the conditional probabilities, are estimated from the selected population using the maximum likelihood estimator. p(X_1,X_2,\dots,X_N)=\prod_{i=1}^{N}p(X_i|\pi_{i}). The Bayesian network structure, on the other hand, must be built iteratively (linkage-learning). It starts with a network without edges and, at each step, adds the edge which better improves some scoring metric (e.g. Bayesian information criterion (BIC) or Bayesian-Dirichlet metric with likelihood equivalence (BDe)). The scoring metric evaluates the network structure according to its accuracy in modeling the selected population. From the built network, BOA samples new promising solutions as follows: (1) it computes the ancestral ordering for each variable, each node being preceded by its parents; (2) each variable is sampled conditionally to its parents. Given such scenario, every BOA step can be defined as P(t+1) = \beta_\mu \circ \alpha_\text{BOA} \circ S(P(t)) Linkage-tree Genetic Algorithm (LTGA) The LTGA differs from most EDA in the sense it does not explicitly model a probability distribution but only a linkage model, called linkage-tree. A linkage T is a set of linkage sets with no probability distribution associated, therefore, there is no way to sample new solutions directly from T. The linkage model is a linkage-tree produced stored as a Family of sets (FOS). T_\text{LT} = \{ \{x_1\}, \{x_2\},\{x_3\},\{x_4\},\{x_1,x_2\},\{x_3,x_4\} \}. The linkage-tree learning procedure is a hierarchical clustering algorithm, which work as follows. At each step the two closest clusters i and j are merged, this procedure repeats until only one cluster remains, each subtree is stored as a subset \tau\in T_\text{LT}. The LTGA uses T_\text{LT} to guide an "optimal mixing" procedure which resembles a recombination operator but only accepts improving moves. We denote it as R_\text{LTGA}, where the notation x[\tau]\gets y[\tau] indicates the transfer of the genetic material indexed by \tau from y to x. Input: A family of subsets T_\text{LT} and a population P(t) Output: A population P(t+1). for each x_i in P(t) do for each \tau in T_\text{LT} do choose a random x_j\in P(t) : x_i\neq x_j f_{x_i} := f(x_i) x_i[\tau]:= x_j[\tau] if f(x_i) \leq f_{x_i} then x_i[\tau]:= x_j[\tau] return P(t) The LTGA does not implement typical selection operators, instead, selection is performed during recombination. Similar ideas have been usually applied into local-search heuristics and, in this sense, the LTGA can be seen as an hybrid method. In summary, one step of the LTGA is defined as P(t+1) = R_{\text{LTGA}}(P(t)) \circ \alpha_\text{LTGA} (P(t)) ==Other==
Other
• Probability collectives (PC) • Hill climbing with learning (HCwL) • Estimation of multivariate normal algorithm (EMNA) • Estimation of Bayesian networks algorithm (EBNA) • Stochastic hill climbing with learning by vectors of normal distributions (SHCLVND) • Real-coded PBIL • Selfish Gene Algorithm (SG) • Compact Differential Evolution (cDE) and its variants • Compact Particle Swarm Optimization (cPSO) • Compact Bacterial Foraging Optimization (cBFO) • Probabilistic incremental program evolution (PIPE) • Estimation of Gaussian networks algorithm (EGNA) • Estimation multivariate normal algorithm with thresheld convergence • Dependency Structure Matrix Genetic Algorithm (DSMGA) ==Related==
tickerdossier.comtickerdossier.substack.com