1

我正在尝试运行一个简单的程序来学习如何使用 CUDD 包版本 3.0.0。我下载了软件包并安装了它:( 1- ./configure 2- make 3- make check)。

我创建了以下简单程序:

  #include <stdio.h>
  #include "cudd.h"
  #include "util.h"

  int main (int argc, char *argv[])
  {
       printf("Its working");
       DdManager *gbm; /* Global BDD manager. */
       char filename[30];
       gbm = Cudd_Init(0,0,CUDD_UNIQUE_SLOTS,CUDD_CACHE_SLOTS,0); 
       DdNode *bdd = Cudd_bddNewVar(gbm); 
       Cudd_Ref(bdd); 
       Cudd_Quit(gbm);
       return 0;
   }

我想创建一个makefile来编译它,我该怎么做?此外,如果我想通过命令行编译它,我该如何链接它的库?

4

1 回答 1

2

在版本 3 中,CUDD 对其构建系统进行了大修,因此用于编译使用 CUDD 的程序的旧 HOWTO 不再适用。

为了简化构建过程,我通常建议针对 CUDD 进行静态构建——这允许您运行稍后编译的程序,而无需提供 CUDD 库的路径和/或将 CUDD 库安装到“/usr/lib”中。

为此,首先使用以下命令重新编译 cudd:

 ./configure --enable-dddmp --enable-obj --enable-shared --enable-static; make

这可确保构建静态库以及您以后可能需要的 CUDD 可选组件。

然后,您可以从命令行编译示例程序,如下所示:

gcc test.c -o testprogram -I /path/to/cudd-3.0.0/cudd -I /path/to/cudd-3.0.0/util -I /path/to/cudd-3.0.0/ -static -L /path/to/cudd-3.0.0/cudd/.libs/ -lcudd -lm

还有其他针对 CUDD 进行编译的方法,但我个人不太喜欢全局安装库。如果您开始使用 CUDD 的更多功能,则可能需要添加更多包含目录以供编译器查找 CUDD .h 文件,并且可能需要更多库。请注意,所有以“-static”开头的参数都是上面编译命令中的链接器参数,而其他参数是用于编译器的 - 当您开始编写 Makefile 以自动化构建过程时,了解这一点很重要。示例 Makefile 如下所示:

CFLAGS = -I /path/to/cudd-3.0.0/cudd -I /path/to/cudd-3.0.0/util -I /path/to/cudd-3.0.0/
LFLAGS = -static -L /path/to/cudd-3.0.0/cudd/.libs/ -lcudd -lm

default: testprogram

testprogram: test.o
    $(CC) test.o -o testprogram $(LFLAGS)

test.o: test.c
    $(CC) test.c -c -o test.o $(CFLAGS)

请查阅更全面的文档以了解如何编写 Makefile 或使用替代构建系统。请注意,在上述文件中,“连续四个空格”需要为制表符才能使 Makefile 工作。如果您将它存储在与名称“Makefile”下的“test.c”相同的目录中,则运行“make”应该构建程序。

于 2017-03-09T08:29:28.830 回答