lemon-project-template-glpk
comparison deps/glpk/INSTALL @ 11:4fc6ad2fb8a6
Test GLPK in src/main.cc
author | Alpar Juttner <alpar@cs.elte.hu> |
---|---|
date | Sun, 06 Nov 2011 21:43:29 +0100 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:92aa53a6f255 |
---|---|
1 INSTALLING GLPK ON YOUR COMPUTER | |
2 ******************************** | |
3 | |
4 Unpacking the distribution file | |
5 ------------------------------- | |
6 The GLPK package (like all other GNU software) is distributed in the | |
7 form of a packed archive. It is one file named `glpk-X.Y.tar.gz', where | |
8 `X' is the major version number and `Y' is the minor version number; | |
9 for example, the archive name might be `glpk-4.15.tar.gz'. | |
10 | |
11 In order to prepare the distribution for installation you should: | |
12 | |
13 1. Copy the GLPK distribution file to a working directory. | |
14 | |
15 2. Unpack the distribution file with the following command: | |
16 | |
17 gzip -d glpk-X.Y.tar.gz | |
18 | |
19 After unpacking the distribution file is automatically renamed to | |
20 `glpk-X.Y.tar'. | |
21 | |
22 3. Unarchive the distribution file with the following command: | |
23 | |
24 tar -x < glpk-X.Y.tar | |
25 | |
26 It automatically creates the subdirectory `glpk-X.Y' containing the | |
27 GLPK distribution. | |
28 | |
29 Configuring the package | |
30 ----------------------- | |
31 After unpacking and unarchiving the GLPK distribution you should | |
32 configure the package, i.e. automatically tune it for your platform. | |
33 | |
34 Normally, you should just `cd' to the directory `glpk-X.Y' and run the | |
35 `configure' script, e.g. | |
36 | |
37 ./configure | |
38 | |
39 The `configure' shell script attempts to guess correct values for | |
40 various system-dependent variables used during compilation. It uses | |
41 those values to create a `Makefile' in each directory of the package. | |
42 It also creates file `config.h' containing platform-dependent | |
43 definitions. Finally, it creates a shell script `config.status' that | |
44 you can run in the future to recreate the current configuration, a file | |
45 `config.cache' that saves the results of its tests to speed up | |
46 reconfiguring, and a file `config.log' containing compiler output | |
47 (useful mainly for debugging `configure'). | |
48 | |
49 Running `configure' takes about a few seconds. While it is running, it | |
50 displays some messages that tell you what it is doing. If you don't want | |
51 to see the messages, run `configure' with its standard output redirected | |
52 to `dev/null'; for example, `./configure > /dev/null'. | |
53 | |
54 By default both static and shared versions of the GLPK library will be | |
55 compiled. Compilation of the shared librariy can be turned off by | |
56 specifying the `--disable-shared' option to `configure', e.g. | |
57 | |
58 ./configure --disable-shared | |
59 | |
60 If you encounter problems building the library try using the above | |
61 option, because some platforms do not support shared libraries. | |
62 | |
63 The GLPK package has some optional features listed below. By default | |
64 all these features are disabled. To enable a feature the corresponding | |
65 option should be passed to the configure script. | |
66 | |
67 --with-gmp Enable using the GNU MP bignum library | |
68 | |
69 This feature allows the exact simplex solver to use the GNU MP | |
70 bignum library. If it is disabled, the exact simplex solver uses the | |
71 GLPK bignum module, which provides the same functionality as GNU MP, | |
72 however, it is much less efficient. | |
73 | |
74 For details about the GNU MP bignum library see its web page at | |
75 <http://gmplib.org/>. | |
76 | |
77 --with-zlib Enable using the zlib data compression library | |
78 | |
79 This feature allows GLPK API routines and the stand-alone solver to | |
80 read and write compressed data files performing compression and | |
81 decompression "on the fly" (compressed data files are recognized by | |
82 suffix `.gz' in the file name). It may be useful in case of large | |
83 MPS files to save the disk space. | |
84 | |
85 For details about the zlib compression library see its web page at | |
86 <http://www.zlib.net/>. | |
87 | |
88 --enable-dl The same as --enable-dl=ltdl | |
89 --enable-dl=ltdl Enable shared library support (GNU) | |
90 --enable-dl=dlfcn Enable shared library support (POSIX) | |
91 | |
92 Currently this feature is only needed to provide dynamic linking to | |
93 ODBC and MySQL shared libraries (see below). | |
94 | |
95 For details about the GNU shared library support see the manual at | |
96 <http://www.gnu.org/software/libtool/manual/>. | |
97 | |
98 --enable-odbc Enable using ODBC table driver (libiodbc) | |
99 --enable-odbc=unix Enable using ODBC table driver (libodbc) | |
100 | |
101 This feature allows transmitting data between MathProg model objects | |
102 and relational databases accessed through ODBC. | |
103 | |
104 For more details about this feature see the supplement "Using Data | |
105 Tables in the GNU MathProg Modeling Language" (doc/tables.*). | |
106 | |
107 --enable-mysql Enable using MySQL table driver (libmysql) | |
108 | |
109 This feature allows transmitting data between MathProg model objects | |
110 and MySQL relational databases. | |
111 | |
112 For more details about this feature see the supplement "Using Data | |
113 Tables in the GNU MathProg Modeling Language" (doc/tables.*). | |
114 | |
115 Compiling the package | |
116 --------------------- | |
117 Normally, you can compile (build) the package by typing the command: | |
118 | |
119 make | |
120 | |
121 It reads `Makefile' generated by `configure' and performs all necessary | |
122 jobs. | |
123 | |
124 If you want, you can override the `make' variables CFLAGS and LDFLAGS | |
125 like this: | |
126 | |
127 make CFLAGS=-O2 LDFLAGS=-s | |
128 | |
129 To compile the package in a different directory from the one containing | |
130 the source code, you must use a version of `make' that supports `VPATH' | |
131 variable, such as GNU `make'. `cd' to the directory where you want the | |
132 object files and executables to go and run the `configure' script. | |
133 `configure' automatically checks for the source code in the directory | |
134 that `configure' is in and in `..'. If for some reason `configure' is | |
135 not in the source code directory that you are configuring, then it will | |
136 report that it can't find the source code. In that case, run `configure' | |
137 with the option `--srcdir=DIR', where DIR is the directory that contains | |
138 the source code. | |
139 | |
140 Some systems require unusual options for compilation or linking that | |
141 the `configure' script does not know about. You can give `configure' | |
142 initial values for variables by setting them in the environment. Using | |
143 a Bourne-compatible shell, you can do that on the command line like | |
144 this: | |
145 | |
146 CC=c89 CFLAGS=-O2 LIBS=-lposix ./configure | |
147 | |
148 Or on systems that have the `env' program, you can do it like this: | |
149 | |
150 env CPPFLAGS=-I/usr/local/include LDFLAGS=-s ./configure | |
151 | |
152 Here are the `make' variables that you might want to override with | |
153 environment variables when running `configure'. | |
154 | |
155 For these variables, any value given in the environment overrides the | |
156 value that `configure' would choose: | |
157 | |
158 CC: C compiler program. The default is `cc'. | |
159 | |
160 INSTALL: Program used to install files. The default value is `install' | |
161 if you have it, otherwise `cp'. | |
162 | |
163 For these variables, any value given in the environment is added to the | |
164 value that `configure' chooses: | |
165 | |
166 DEFS: Configuration options, in the form `-Dfoo -Dbar ...'. | |
167 | |
168 LIBS: Libraries to link with, in the form `-lfoo -lbar ...'. | |
169 | |
170 Checking the package | |
171 -------------------- | |
172 To check the package, i.e. to run some tests included in the package, | |
173 you can use the following command: | |
174 | |
175 make check | |
176 | |
177 Installing the package | |
178 ---------------------- | |
179 Normally, to install the GLPK package you should type the following | |
180 command: | |
181 | |
182 make install | |
183 | |
184 By default, `make install' will install the package's files in | |
185 `usr/local/bin', `usr/local/lib', etc. You can specify an installation | |
186 prefix other than `/usr/local' by giving `configure' the option | |
187 `--prefix=PATH'. Alternately, you can do so by consistently giving a | |
188 value for the `prefix' variable when you run `make', e.g. | |
189 | |
190 make prefix=/usr/gnu | |
191 make prefix=/usr/gnu install | |
192 | |
193 After installing you can remove the program binaries and object files | |
194 from the source directory by typing `make clean'. To remove all files | |
195 that `configure' created (`Makefile', `config.status', etc.), just type | |
196 `make distclean'. | |
197 | |
198 The file `configure.ac' is used to create `configure' by a program | |
199 called `autoconf'. You only need it if you want to remake `configure' | |
200 using a newer version of `autoconf'. | |
201 | |
202 Uninstalling the package | |
203 ------------------------ | |
204 To uninstall the GLPK package, i.e. to remove all the package's files | |
205 from the system places, you can use the following command: | |
206 | |
207 make uninstall | |
208 | |
209 ======================================================================== |