310实验室OTL问题----将写好的C++文件转换成Python文件,并将数据可视化

如图:文件夹

第一处:optimizer文件夹下的:optimizer.h文件中添加你所写代码的头文件  #include <OTL/Optimizer/Reference-NSGA-II/Reference-NSGA-II.h>

第二处:在Switch.h文件中添加 代码,格式请模仿文件中的内容 #define EXPORT_Reference_NSGA_II

第三处:因为我们一般编码都是以实数形式编码的,所以修改optimizer.real 下的文件Optimizer.h 文件的内容,格式模仿文件中的内容typedef otl::optimizer::reference_nsga_ii::Reference_NSGA_II<TReal, TDecision, TRandom &> TReference_NSGA_II;,然后增写实现 刚在Optimizer.h文件中的函数是在Optimizer.cpp中,注意在这里,如果是要获得一个引用值得话,需要这样.def("GetCrossover", &TReference_NSGA_II::GetCrossover, boost::python::return_value_policy<boost::python::reference_existing_object>()),如果仅获得一个值得话,则不需要boost::python::return_value_policy<boost::python::reference_existing_object>()

这样,PyOTL中(作为C++与Python的一种桥接)设置完成。

修改PyOptimization中的内容:

第一处:找到optimizer文件夹下的__init__.py,然后修改,格式模仿其文件中的模式。一种是 _make_xxx函数,一种是 make_xxx 函数。

第二处,如果需要运行代码,选择在最外层的optimization.py,如果代码正确,c++和python桥接成功,产生的数据将保存在documents文件下的database的路径中,数据库的路径由自己修改。如果需要修改运行的参数,则在optimization.ini文件中修改,如果是评价则在evalution.ini中修改相关配置。如果需要查看效果图,可以点击visualize.py运行,则可以看到效果图。

最后,如果需要测评的话,运行evalution.py后,将数据库文件(系统默认是在documents文件下)放在使用sqliteman工具查看即可

时间: 2024-11-11 08:08:46

310实验室OTL问题----将写好的C++文件转换成Python文件,并将数据可视化的相关文章

310实验室OTL问题(2)

1.PyOptimization代码学习心得 (1).该部分由三个分块组成(按完成的相应的任务).第一部分,运行函数. 以optimization.py为入口程序,其思路是:首先获取路径,然后,初始化problem,optimize的参数.然后,选择测试函数问题如:DTLZ2,获取相关参数的值,初始化的参数值由路径中的键值赋值.problem中包括(交叉,变异,问题测试等的相关的参数赋值).然后,调用pyotl中的代码执行C++程序,然后将数据存储到数据库中.

用c语言写一个函数把十进制转换成十六进制(转)

#include "stdio.h" int main() { int num=0;int a[100]; int i=0; int m=0;int yushu; char hex[16]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};printf("请输入一个十进制整数:"); scanf("%d",&num); while(num>0) { y

写一个函数将传入的字符串转换成驼峰表示法

/* *已知有字符foo="get-element-by-id".写一个function将其转换成驼峰表示法"getElementById" */ var o = { trans:function (msg){ var i, tempArr = msg.split('-'), len = tempArr.length; for(i = 1; i < len; i++){ tempArr[i] = tempArr[i].charAt(0).toUpperCase

Dom4j 读取一个XML文件和将String写成XML文件

dom4j保存文件xml格式和读取XML文件内容,代码如下: package com.qmjs.imut import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.io.InputStream; import org.apache.log4j.Logger; import org.dom4j.Document; import org.dom4j.DocumentHelper; i

用C#Winform写个简单的批量清空文件内容和删除文件的小工具

用C#Winform写个简单的批量清空文件内容和删除文件的小工具 本文介绍这个简单得不能再简单的小项目.做这个项目,有以下目的. 1 当然是做个能用的工具 2 学习使用Github 关于用VS2013创建一个项目并添加到Github的教程,请参考(http://www.admin10000.com/document/4004.html).简单来说,就是先用VS创建项目:然后在Github网站上创建一个Respo(本项目的代码托管项目),记下(https://*.git)那个地址:最后用"提交&q

一个文件中有40亿个整数,每个整数为四个字节,内存为1GB,写出一个算法:求出这个文件里的整数里不包含的一个整数

4个字节表示的整数,总共只有2^32约等于4G个可能.为了简单起见,可以假设都是无符号整数.分配500MB内存,每一bit代表一个整数,刚好可以表示完4个字节的整数,初始值为0.基本思想每读入一个数,就把它对应的bit位置为1,处理完40G个数后,对500M的内存遍历,找出一个bit为0的位,输出对应的整数就是未出现的.算法流程:1)分配500MB内存buf,初始化为02)unsigned int x=0x1;  for each int j in file  buf=buf|x<<j;  e

02_Android写xml文件和读xml文件

?? 新建Android项目 编写AndroidManifest.xml,使本Android项目具有单元测试功能和写外设的权限. <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.itheima28.xmldemo" a

以写代学:python 文件打开,写入,复制

变量=open("要打开的文件",打开方式) 打开方式有三种,读.写.执行,默认打开方式为读,若是采用写的方式,文件若存在,则清空所有内容,若不存在,则创建新的文件,例如 f = open("/bin/ls")      //加引号表示文件名,不加为变量 f.read()          //括号中为空,表示把文件中的所有都读出来,括号中有数表示"按需读取",单位为字节 f.readline(大小)      //读取文件的一行 f.readl

自己动手写CPU之第五阶段(2)——OpenMIPS对数据相关问题的解决措施

将陆续上传本人写的新书<自己动手写CPU>(尚未出版),今天是第16篇,我尽量每周四篇 5.2 OpenMIPS对数据相关问题的解决措施 OpenMIPS处理器采用数据前推的方法来解决流水线数据相关问题.通过补充完善图4-4原始的数据流图,添加部分信号使得可以完成数据前推的工作,如图5-7所示.主要是将执行阶段的结果.访存阶段的结果前推到译码阶段,参与译码阶段选择运算源操作数的过程. 图5-8给出了为实现数据前推而对OpenMIPS系统结构所做的修改.有两个方面. (1)将处于流水线执行阶段的