我在Fortran中使用metis 5。我通过手册中给出的简单示例使用了PartGraphRecursive函数。给出的代码不是工作条件。
program main
implicit none
integer,parameter::nvtxs=15, Edges=22
integer::xadj(nvtxs+1),adjncy(2*Edges)
integer::objval, part(nvtxs)
xadj=[0, 2, 5, 8, 11, 13, 16, 20, 24, 28, 31, 33, 36, 39, 42, 44]
adjncy=[1, 5, 0, 2, 6, 1, 3, 7, 2, 4, 8, 3, 9, 0, 6, 10, 1, 5, 7, 11, 2, 6, 8, 12, 3, 7, 9, 13, 4, 8, 14, 5, 11, 6, 10, 12, 7, 11, 13, 8, 12, 14, 9, 13]
call METIS_PartGraphRecursive(vortices,1,xadj,adjncy,,,,2,,,,objval,part)
end program main有人能完成这段代码吗?我不太清楚如何在METIS_PartGraphRecursive调用中使用不同的输入,因为我想使用的大多数输入都是空的。
附注:我正在使用带有pgf90 Fortran编译器的Linux,并且我使用以下命令来编译和链接该文件。
Pgf90 –o main main.f90 libmetis.alibmetis.a文件与main文件位于同一目录中。
发布于 2011-11-17 03:03:50
Fortran 2003模块ISO_C_BINDING定义了一个类型为(C_PTR)的常量C_NULL_PTR。您可以使用此模块定义到子例程的接口。
它可能是这样的
interface
subroutine METIS_PartGraphRecursive(n,xadj,adjncy,vwght,adjwgt,wgtflag,numflag,nparts,options,edgecut,part) bind(C)
use iso_c_binding
integer(c_int) :: !here the parameters you pass as integers
type(c_ptr),value :: !here the parameters you want to pass c_null_ptr to
end subroutine
endinterface您可以对所有参数使用类型(C_ptr)、值,但必须为它们定义指针并使用函数C_LOC
https://stackoverflow.com/questions/8155160
复制相似问题