【问题标题】:how to minimize a function using Deap?如何使用 Deap 最小化函数?
【发布时间】:2014-04-19 16:25:16
【问题描述】:

我需要使用遗传算法和 PSO 最小化一个函数。

不同的帖子建议使用DEAP(我正在使用python)但我什至不明白如何开始。

例如,我们可以考虑区间 i 上的 f

i=arange(-10,10,0.1)
def f(x):
    return x*sin(x)

如何使用 DEAP 最小化这个函数?

【问题讨论】:

  • 很遗憾没有'DEAP'标签。

标签: python mathematical-optimization genetic-algorithm deap


【解决方案1】:

我已经解决了。

这是我的代码

t1=linspace(-50,50,100)
sig1=sin(t1/2)+np.random.normal(scale=0.1,size=len(t1))
sig2=sin(t1/2)+np.random.normal(scale=0.1,size=len(t1))



f0=interp1d(t1,sig1,kind="cubic",bounds_error=False,fill_value=-10000)
g=interp1d(t1,sig2,kind="cubic",bounds_error=False,fill_value=10000)
#true value that  I would like to estimate
A=2
B=0.8
C=0

def s(t):
    return A+B*t+C*t*t

def inv_s(t):
    return (t-B)/A

def f(t):
    return f0(s(t))

def hat_s(t,a,b):
    return t*b+a


Ig=arange(t1.min(),t1.max(),1)
If=(Ig-A)/B
I_min=max(If.min(),Ig.min())
I_max=min(If.max(),Ig.max())


J=linspace(min(If.min(),Ig.min()),max(If.max(),Ig.max()))
I=linspace(I_min,I_max,1000)  

#plot(J,f(J),J,g(J))
#ylim(-1.2,1.2)


def cost(x,T=I):
    a=x[0]
    b=x[1]
    return norm(g(b*T+a)-f(T))/len(T),







import operator
import random

import numpy

from deap import base
from deap import benchmarks
from deap import creator
from deap import tools

creator.create("FitnessMax", base.Fitness, weights=(-1.0,))
creator.create("Particle", list, fitness=creator.FitnessMax, speed=list, 
    smin=None, smax=None, best=None)

def generate(size, pmin, pmax, smin, smax):
    part = creator.Particle(random.uniform(pmin, pmax) for _ in range(size)) 
    part.speed = [random.uniform(smin, smax) for _ in range(size)]
    part.smin = smin
    part.smax = smax
    return part

def updateParticle(part, best, phi1, phi2):
    u1 = (random.uniform(0, phi1) for _ in range(len(part)))
    u2 = (random.uniform(0, phi2) for _ in range(len(part)))
    v_u1 = map(operator.mul, u1, map(operator.sub, part.best, part))
    v_u2 = map(operator.mul, u2, map(operator.sub, best, part))
    part.speed = list(map(operator.add, part.speed, map(operator.add, v_u1, v_u2)))
    for i, speed in enumerate(part.speed):
        if speed < part.smin:
            part.speed[i] = part.smin
        elif speed > part.smax:
            part.speed[i] = part.smax
    part[:] = list(map(operator.add, part, part.speed))

toolbox = base.Toolbox()
toolbox.register("particle", generate, size=2, pmin=-6, pmax=6, smin=-3, smax=3)
toolbox.register("population", tools.initRepeat, list, toolbox.particle)
toolbox.register("update", updateParticle, phi1=2.0, phi2=2.0)
toolbox.register("evaluate", cost)

def main():
    pop = toolbox.population(n=5)
    stats = tools.Statistics(lambda ind: ind.fitness.values)
    stats.register("avg", numpy.mean)
    stats.register("std", numpy.std)
    stats.register("min", numpy.min)
    stats.register("max", numpy.max)

    logbook = tools.Logbook()
    logbook.header = ["gen", "evals"] + stats.fields

    GEN = 1000
    best = None

    for g in range(GEN):
        for part in pop:
            part.fitness.values = toolbox.evaluate(part)
            if not part.best or part.best.fitness < part.fitness:
                part.best = creator.Particle(part)
                part.best.fitness.values = part.fitness.values
            if not best or best.fitness < part.fitness:
                best = creator.Particle(part)
                best.fitness.values = part.fitness.values
        for part in pop:
            toolbox.update(part, best)

        # Gather all the fitnesses in one list and print the stats
        logbook.record(gen=g, evals=len(pop), **stats.compile(pop))
        print(logbook.stream)
        print "  Best so far: %s - %s" % (best, best.fitness)

    return pop, logbook, best

pop,logbook,best= main()
print "best=",best,"A,B=",(A,B)

【讨论】:

    【解决方案2】:

    其实有一个例子:http://deap.rtfd.org/en/master/examples/pso_basic.html

    请注意,我是一名 DEAP 开发人员。

    【讨论】:

      【解决方案3】:

      我意识到我的回复迟了,但希望我可以帮助那些刚接触 DEAP 库的人。

      为了最小化你必须创建一个 FitnessMin 类,如下所示:

      creator.create("FitnessMin", base.Fitness, weights=(-1.0,))
      

      注意我的权重是 -1.0,如果我们将其设为 1.0,我们会最大化。

      然后,一旦你这样做了,将健身课程应用到你的个体,这本质上就是你想要训练的染色体:

      creator.create("Individual", list, fitness=creator.FitnessMin)
      

      看看 DEAP 库中的 eaSimple,因为它是最好的入门工具。以下是 DEAP 提供的开箱即用算法列表:http://deap.readthedocs.io/en/master/api/algo.html

      【讨论】:

        【解决方案4】:

        我已将基础健身中的 weights=(1.0,) 更改为 weights=(-1.0,)

        成功了!

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2021-10-25
          • 2018-01-30
          • 2015-02-18
          • 2020-10-06
          • 1970-01-01
          相关资源
          最近更新 更多