本文整理匯總了Golang中github.com/cpmech/goga.Optimiser.RptFmax方法的典型用法代碼示例。如果您正苦於以下問題:Golang Optimiser.RptFmax方法的具體用法?Golang Optimiser.RptFmax怎麽用?Golang Optimiser.RptFmax使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/cpmech/goga.Optimiser
的用法示例。
在下文中一共展示了Optimiser.RptFmax方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: DTLZ2mGenerator
func DTLZ2mGenerator(opt *goga.Optimiser, nf int) (ng int, fcn goga.MinProb_t) {
nx := nf + 10
ng = nx * 2
opt.FltMin = make([]float64, nx)
opt.FltMax = make([]float64, nx)
for i := 0; i < nx; i++ {
opt.FltMin[i], opt.FltMax[i] = -0.01, 1.01
}
fcn = func(f, g, h, x []float64, ξ []int, cpu int) {
var failed bool
for i := 0; i < nx; i++ {
g[0+i*2] = x[i]
g[1+i*2] = 1.0 - x[i]
if g[0+i*2] < 0 {
failed = true
}
if g[1+i*2] < 0 {
failed = true
}
}
if failed {
return
}
var c float64
for i := nf - 1; i < nx; i++ {
c += math.Pow((x[i] - 0.5), 2.0)
}
for i := 0; i < nf; i++ {
f[i] = (1.0 + c)
for j := 0; j < nf-1-i; j++ {
f[i] *= math.Cos(x[j] * PI / 2.0)
}
if i > 0 {
j := nf - 1 - i
f[i] *= math.Sin(x[j] * PI / 2.0)
}
}
}
opt.Multi_fcnErr = func(f []float64) float64 {
var sum float64
for i := 0; i < nf; i++ {
sum += f[i] * f[i]
}
return sum - 1.0
}
opt.RptFmin = make([]float64, nf)
opt.RptFmax = make([]float64, nf)
for i := 0; i < nf; i++ {
opt.RptFmax[i] = 1
}
return
}