Manytasking Jmetal代码反向解析1_MATP测试函数集

觉得有用的话,欢迎一起讨论相互学习~Follow Me

  • 这是我在写Manytask optimization时的笔记,代码地址可以下载
  • 打开文件夹如下目录,选择benchmark中的任意一个测试函数集,此时我们选择MATP1

    MATP1

package momfo.problems.benchmarks;

import java.io.IOException;

import momfo.core.Problem;
import momfo.core.ProblemSet;
import momfo.problems.base.*;

public class MATP1 {

    public static ProblemSet getProblem() throws IOException {

        int taskNumber=50;

        ProblemSet problemSet = new ProblemSet(taskNumber);

        for(int i=1;i<=taskNumber;i++)
            problemSet.add(getT(i).get(0));

        return problemSet;

    }

    public static ProblemSet getT(int taskID) throws IOException {
        ProblemSet problemSet = new ProblemSet(1);

        MMDTLZ prob = new MMDTLZ(2, 50, 1, -100,100);
        prob.setGType("sphere");

        double[][] matrix = IO.readMatrixFromFile("MData/M1/M1_"+taskID+".txt");

        double shiftValues[] = IO.readShiftValuesFromFile("SVData/S1/S1_"+taskID+".txt");

        prob.setRotationMatrix(matrix);
        prob.setShiftValues(shiftValues);       

        ((Problem)prob).setName("MATP1-"+taskID);

        problemSet.add(prob);

        return problemSet;
    }

}
  • int taskNumber=50; 表示MATP1问题设置的任务个数是50,初始化problemSet作为一个容器以承载每一个被初始化后的实际MATP1问题。
  • for(int i=1;i<=taskNumber;i++) problemSet.add(getT(i).get(0));
    意味着此时需要关注的是getT函数,从

    MMDTLZ prob = new MMDTLZ(2, 50, 1, -100,100);
    prob.setGType("sphere");

    看出MATP_1是一个双目标的问题,并且决策变量个数为50,决策变量最小值为-100,最大值为100,而G函数的类型为sphere,而只要是双目标的函数使用的H函数都是circle
    ```java
    // MMDTLZ
    if (numberOfObjectives == 2)
    hType_ = "circle";
    else
    hType_ = "sphere";

![在这里插入图片描述](https://img-blog.csdnimg.cn/20191216155508697.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTM1NTU3MTk=,size_16,color_FFFFFF,t_70)

* **通过**

double[][] matrix = IO.readMatrixFromFile("MData/M1/M1_"+taskID+".txt");

double shiftValues[] = IO.readShiftValuesFromFile("SVData/S1/S1_"+taskID+".txt");
``* 可知matrix[][]其中保存有旋转函数,根据taskID具有不同的旋转角度,shiftValues则保存了偏移向量,通过不同的旋转函数和偏移向量可以保证MATP问题中的不同任务即使具有相同的帕累托前沿,但是对应的决策变量距离和位置却完全不同。 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20191216145252251.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTM1NTU3MTk=,size_16,color_FFFFFF,t_70) ## 注意在MATP2中仅仅设置G函数的形状为spherealpha`值1。(后期通关观察得知,alpha值是用于计算cos函数的)


MATP2

public class MATP2 {

    public static ProblemSet getProblem() throws IOException {

        int taskNumber=50;

        ProblemSet problemSet = new ProblemSet(taskNumber);

        for(int i=1;i<=taskNumber;i++)
            problemSet.add(getT(i).get(0));

        return problemSet;

    }

    public static ProblemSet getT(int taskID) throws IOException {
        ProblemSet problemSet = new ProblemSet(1);

        MMZDT prob = new MMZDT(50, 1,  -100,100);
        prob.setGType("mean");
        prob.setHType("concave");

        double[][] matrix = IO.readMatrixFromFile("MData/M2/M2_"+taskID+".txt");

        double shiftValues[] = IO.readShiftValuesFromFile("SVData/S2/S2_"+taskID+".txt");

        prob.setRotationMatrix(matrix);
        prob.setShiftValues(shiftValues);       

        ((Problem)prob).setName("MATP2-"+taskID);

        problemSet.add(prob);

        return problemSet;
    }

}

和MATP1问题不同的是MATP2问题设置G函数为mean,设置H函数为concave,最终形状为concave并且是根据ZDT问题改编的,而不是DTLZ问题,表示有50个变量,并且K值为1,根据ZDT问题的默认函数来看,ZDT问题构造的都是双目标问题。

public MMZDT(int numberOfVariables, int k, double lg, double ug) {
  numberOfObjectives_ = 2;
  numberOfVariables_ = numberOfVariables;
  k_ = k;

  gType_ = "sphere";
  f1Type_ = "linear";
  hType_ = "convex";


MATP3

package momfo.problems.benchmarks;

import java.io.IOException;

import momfo.core.Problem;
import momfo.core.ProblemSet;
import momfo.problems.base.*;

public class MATP3 {

    public static ProblemSet getProblem() throws IOException {

        int taskNumber=50;

        ProblemSet problemSet = new ProblemSet(taskNumber);

        for(int i=1;i<=taskNumber;i++)
            problemSet.add(getT(i).get(0));

        return problemSet;

    }

    public static ProblemSet getT(int taskID) throws IOException {
        ProblemSet problemSet = new ProblemSet(1);

        MMZDT prob = new MMZDT(10,  1, -5,5);
        prob.setGType("rosenbrock");
        prob.setHType("concave");

        double[][] matrix = IO.readMatrixFromFile("MData/M3/M3_"+taskID+".txt");

        double shiftValues[] = IO.readShiftValuesFromFile("SVData/S3/S3_"+taskID+".txt");

        prob.setRotationMatrix(matrix);
        prob.setShiftValues(shiftValues);       

        ((Problem)prob).setName("MATP3-"+taskID);

        problemSet.add(prob);

        return problemSet;
    }

}

和MATP1以及MATP2问题不同的是MATP3问题设置G函数为rosenbrock,设置H函数为concave,最终形状为concave并且是根据ZDT问题改编的,而不是DTLZ问题,表示有50个这样的任务,并且K值为1,根据ZDT问题的默认函数来看,ZDT问题构造的都是双目标问题,与MATP2问题不同的是使用10个变量,并且变量范围为[-5,5]而不是[-50,50]


MATP4

import java.io.IOException;

import momfo.core.Problem;
import momfo.core.ProblemSet;
import momfo.problems.base.*;

public class MATP4 {

    public static ProblemSet getProblem() throws IOException {

        int taskNumber=50;

        ProblemSet problemSet = new ProblemSet(taskNumber);

        for(int i=1;i<=taskNumber;i++)
            problemSet.add(getT(i).get(0));

        return problemSet;

    }

    public static ProblemSet getT(int taskID) throws IOException {
        ProblemSet problemSet = new ProblemSet(1);

        MMDTLZ prob = new MMDTLZ(2, 50, 1, -2,2);
        prob.setGType("rastrigin");

        double[][] matrix = IO.readMatrixFromFile("MData/M4/M4_"+taskID+".txt");

        double shiftValues[] = IO.readShiftValuesFromFile("SVData/S4/S4_"+taskID+".txt");

        prob.setRotationMatrix(matrix);
        prob.setShiftValues(shiftValues);       

        ((Problem)prob).setName("MATP4-"+taskID);

        problemSet.add(prob);

        return problemSet;
    }

}

可以看出MATP4使用的是DTLZ函数其中具有两个目标函数,具有50个决策变量,alpha值为1,上界为2下界为-2.使用的G函数为rastrigin,使用的H函数为sphere

//MMDTLZ
if (numberOfObjectives == 2)
            hType_ = "circle";
        else
            hType_ = "sphere";


MATP5

package momfo.problems.benchmarks;

import java.io.IOException;

import momfo.core.Problem;
import momfo.core.ProblemSet;
import momfo.problems.base.*;

public class MATP5 {

    public static ProblemSet getProblem() throws IOException {

        int taskNumber=50;

        ProblemSet problemSet = new ProblemSet(taskNumber);

        for(int i=1;i<=taskNumber;i++)
            problemSet.add(getT(i).get(0));

        return problemSet;

    }

    public static ProblemSet getT(int taskID) throws IOException {
        ProblemSet problemSet = new ProblemSet(1);

        MMZDT prob = new MMZDT(50, 1,  -1,1);
        prob.setGType("ackley");
        prob.setHType("convex");

        double[][] matrix = IO.readMatrixFromFile("MData/M5/M5_"+taskID+".txt");

        double shiftValues[] = IO.readShiftValuesFromFile("SVData/S5/S5_"+taskID+".txt");

        prob.setRotationMatrix(matrix);
        prob.setShiftValues(shiftValues);       

        ((Problem)prob).setName("MATP5-"+taskID);

        problemSet.add(prob);

        return problemSet;
    }

}

决策变量个数为50,k为1,变量最小范围为-1,变量最大范围为1,G函数为ackley,H函数为convex


MATP6

package momfo.problems.benchmarks;

import java.io.IOException;

import momfo.core.Problem;
import momfo.core.ProblemSet;
import momfo.problems.base.*;

public class MATP6 {

    public static ProblemSet getProblem() throws IOException {

        int taskNumber=50;

        ProblemSet problemSet = new ProblemSet(taskNumber);

        for(int i=1;i<=taskNumber;i++)
            problemSet.add(getT(i).get(0));

        return problemSet;

    }

    public static ProblemSet getT(int taskID) throws IOException {
        ProblemSet problemSet = new ProblemSet(1);

        MMDTLZ prob = new MMDTLZ(2, 50, 1, -50,50);
        prob.setGType("griewank");

        double[][] matrix = IO.readMatrixFromFile("MData/M6/M6_"+taskID+".txt");

        double shiftValues[] = IO.readShiftValuesFromFile("SVData/S6/S6_"+taskID+".txt");

        prob.setRotationMatrix(matrix);
        prob.setShiftValues(shiftValues);       

        ((Problem)prob).setName("MATP6-"+taskID);

        problemSet.add(prob);

        return problemSet;
    }

}

目标函数2个,50个决策变量,alpha值设置为1,下边界为-50,上边界为50,G函数为griewank,H函数为circle

MATP算例总结

float[] rgb1 = {0, 0, 0};//黑色-circle
        float[] rgb2 = {(float) 0, (float) 0, (float) 139};//蓝黑-concave
        float[] rgb3 = {(float) 255, (float) 0, (float) 0};//红色-concave
        float[] rgb4 = {(float) 0, (float) 255, (float) 0};//绿色-circle
        float[] rgb5 = {(float) 255, (float) 255, (float) 0};//黄色-convex
        float[] rgb6 = {(float) 139, (float) 69, (float) 19};//巧克力色-circle

        float alpha = (float) 1;
        Scatter scatter1 = tools.Setpoint(TruePFT1_Matrix, rgb1, alpha, 20);
        Scatter scatter2 = tools.Setpoint(TruePFT2_Matrix, rgb2, alpha, 15);
        Scatter scatter3 = tools.Setpoint(TruePFT3_Matrix, rgb3, alpha, 8);
        Scatter scatter4 = tools.Setpoint(TruePFT4_Matrix, rgb4, alpha, 10);
        Scatter scatter5 = tools.Setpoint(TruePFT5_Matrix, rgb5, alpha, 6);
        Scatter scatter6 = tools.Setpoint(TruePFT6_Matrix, rgb6, alpha, 5);

Manytasking optimization MATP的更多相关文章

  1. theano scan optimization

    selected from Theano Doc Optimizing Scan performance Minimizing Scan Usage performan as much of the ...

  2. [Project Name] was compiled with optimization - stepping may behave oddly; variables may not be available.

    控制台输出的时候显示一串这样的信息:[Project Name] was compiled with optimization - stepping may behave oddly; variabl ...

  3. Mvc 之System.Web.Optimization 压缩合并如何让*.min.js 脚本不再压缩

    最近项目中用到了easy ui ,但是在配置BundleConfig 的时候出现了问题,easy ui的脚本jquery.easyui.min.js 压缩后出现各种脚本错误,总是莫名其妙的 i标量错误 ...

  4. MySQL Range Optimization

    8.2.1.3 Range Optimization MYSQL的Range Optimization的目的还是尽可能的使用索引 The range access method uses a sing ...

  5. 命名空间“System.Web”中不存在类型或命名空间名称“Optimization”(是否缺少程序集引用?)

    今天,在.net4.5,mvc4下新建了个区域,运行起来就报这个错误: 命名空间"System.Web"中不存在类型或命名空间名称"Optimization"( ...

  6. [阅读笔记]Software optimization resources

    http://www.agner.org/optimize/#manuals 阅读笔记Optimizing software in C++   7. The efficiency of differe ...

  7. Tomcat APR & Linux Optimization

    一.简介 APR(Apache portable Run-time libraries)模式:简单理解,就是从操作系统级别解决异步IO问题,大幅度的提高服务器的处理和响应性能, 也是Tomcat运行高 ...

  8. low-rank 的相关求解方法 (CODE) Low-Rank Matrix Recovery and Completion via Convex Optimization

    (CODE) Low-Rank Matrix Recovery and Completion via Convex Optimization 这个是来自http://blog.sina.com.cn/ ...

  9. hdu 1232, disjoint set, linked list vs. rooted tree, a minor but substantial optimization for path c 分类: hdoj 2015-07-16 17:13 116人阅读 评论(0) 收藏

    three version are provided. disjoint set, linked list version with weighted-union heuristic, rooted ...

随机推荐

  1. css overflow失效的原因

    声明 转载自https://my.oschina.net/xuqianwen/blog/540587 项目中常常有同学遇到这样的问题,现象是给元素设置了overflow:hidden,但超出容器的部分 ...

  2. Android 还可以走多久?

    最近,有位知识星球的球友问我这么一个问题: 我做 Android 开发五年多时间了,但是最近总是很焦虑,看着人工智能越来越火,很担心 Android 要不行了,想问下,我现在要转行么?Android ...

  3. RabbitMQ 的 docker 镜像使用

    RabbitMQ 的 docker 镜像使用 1.下载镜像(management版本的才带有web管理界面) docker pull rabbitmq:3.7.18-management 2.创建容器 ...

  4. wordpress时间函数the_time() 实例解读

    wordpress the_time()时间函数想必大家多多少少都会用到,但是要自定义一些时间相对没那么熟悉了,随ytkah一起来看看吧.我们知道时间函数基础调用是<?php the_time( ...

  5. linux mustache bash 实现mo 做为docker容器运行动态配置工具数组的处理

    前面有说过关于使用mo 工具的简单配置使用,但是实际中我们可能存在比较复杂的数据处理,比如数组,mo 可以进行数组的处理,但是在测试的过程中,一直失败,查看了官方的demo以及帮助命令发现可以通过参数 ...

  6. JS的ES5的扩展内容

    JS的ES5 1.严格模式: (1)什么是严格模式: 在全局或函数的第一条语句定义为:  'use strict' 如果浏览器不支持, 只解析为一条简单的语句, 没有任何副作用 (2)严格模式作用: ...

  7. 常用方法 Entitys转换为DataTable

    效率比较屁,将近可以用 public static DataTable EntitiesToDataTable<T>(List<T> entitys) { Type t = t ...

  8. [RN] React Native 删除第三方开源组件依赖包 后 还要做的 (以 删除 react-native-video为例)

    近期测试使用了下  react-native-video 使用一直不成功,后来想着删除掉, 使用命令: npm uninstall react-native-video 重新编译后,还是一直报错 后来 ...

  9. BZOJ 4816[SDOI2017]数字表格(莫比乌斯反演)

    题目链接 \(Description\) 用\(f_i\)表示\(fibonacci\)数列第\(i\)项,求\(\prod_{i=1}^{n}\prod_{j=1}^{m}f[gcd(i,j)]\) ...

  10. 高考数学答卷策略[K12论坛转载]

    一.试卷上给你的启发 1.试卷上有参考公式,80%是有用的,它为你的解题指引了方向: 2.解答题的各小问之间有一种阶梯关系,通常后面的问要使用前问的结论.如果前问是证明,即使不会证明结论,该结论在后问 ...