zdt6.mw

ZDT 6 


`:=`(f, proc (x) options operator, arrow; `+`(1, `-`(`*`(`^`(x, 2)))) end proc); -1; 'f(x)' = f(x); 1; `:=`(x[min], .2807753191); -1; `:=`(x[max], 1); -1; 'x[min]' = x[min], 'x[max]' = x[max]
 

 

f(x) = `+`(1, `-`(`*`(`^`(x, 2))))
x[min] = .2807753191, x[max] = 1 (1)
 

`:=`(delta, proc (x) options operator, arrow; `/`(`*`(sqrt(`+`(`-`(`/`(`*`(diff(f(x), x)), `*`(`+`(1, `*`(`^`(diff(f(x), x), 2))))))))), `*`(int(sqrt(`+`(`-`(diff(f(x), x)))), x = x[min] .. x[max]))) ... 

delta(x) = `+`(`/`(`*`(1.762172271, `*`(`^`(x, `/`(1, 2)))), `*`(`^`(`+`(1., `*`(4., `*`(`^`(x, 2)))), `/`(1, 2))))) (2)
 

`:=`(H1, proc (x) options operator, arrow; `+`(x, `/`(`*`(`+`(f(x), `-`(f(x[min])))), `*`(diff(f(x), x)))) end proc); -1 

`:=`(R1, Optimization:-Maximize(H1(x), x = x[min] .. x[max])); -1; 'R[1]' = R1 

R[1] = [1.46058261009999990, [x = 1.]] (3)
 

`:=`(H2, proc (x) options operator, arrow; `+`(`*`(diff(f(x), x), `*`(`+`(x, `-`(x[max])))), f(x)) end proc); -1 

`:=`(R2, Optimization:-Maximize(H2(x), x = x[min] .. x[max])); -1; 'R[2]' = R2 

R[2] = [1.3333333333333, [x = .333333333333333315]] (4)