二元二次模型的C++库
jij-cimod的Python项目详细描述
< H1> CIMOD:二元二次模型的C++头集库
C++ +EH3>
如何使用
您应该只在项目中包含一个标题src/binary_quadratic_model.hpp
。在
示例
C++ +EH3>#include"src/binary_quadratic_model.hpp"usingnamespacecimod;intmain(){// Set linear biases and quadratic biasesLinear<uint32_t,double>linear{{1,1.0},{2,2.0},{3,3.0},{4,4.0}};Quadratic<uint32_t,double>quadratic{{std::make_pair(1,2),12.0},{std::make_pair(1,3),13.0},{std::make_pair(1,4),14.0},{std::make_pair(2,3),23.0},{std::make_pair(2,4),24.0},{std::make_pair(3,4),34.0}};// Set offsetdoubleoffset=0.0;// Set variable typeVartypevartype=Vartype::BINARY;// Create a BinaryQuadraticModel instanceBinaryQuadraticModel<uint32_t,double>bqm(linear,quadratic,offset,vartype);//linear terms -> bqm.get_linear()//quadratic terms -> bqm.get_quadratic()return0;}
Python
^{pr2}$
安装
通过这个目录
$ python setup.py install
通过pip
$ pip install jij-cimod
基准
基准代码
importdimodimportcimodimporttimefil=open("benchmark","w")fil.write("N t_dimod t_cimod\n")defbenchmark(N,test_fw):linear={}quadratic={}spin={}# interactionsforiinrange(N):spin[i]=1foreleminrange(N):linear[elem]=2.0*elem;foriinrange(N):forjinrange(i+1,N):ifi!=j:quadratic[(i,j)]=(i+j)/(N)t1=time.time()# initializea=test_fw.BinaryQuadraticModel(linear,quadratic,0,test_fw.BINARY)a.change_vartype(test_fw.SPIN)# calculate energy for 50 times.for_inrange(50):print(a.energy(spin))t2=time.time()returnt2-t1d_arr=[]c_arr=[]forNin[25,50,100,200,300,400,600,800,1000,1600,2000,3200,5000]:print("N {}".format(N))d=benchmark(N,dimod)c=benchmark(N,cimod)print("{}{}{}".format(N,d,c))fil.write("{}{}{}\n".format(N,d,c))
软件版本
Package | Version |
---|---|
cimod | 1.0.3 |
dimod | 0.9.2 |
结果
- 项目
标签: