1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388
|
\newpage
\section{Installation}
In some situations installation of Gfan is easy while in other situations it can be very complicated. If you are satisfied with an old version of Gfan, then you might just use the package manager on the system.
If you are using Linux and have root-access then the following might work
\begin{verbatim}
sudo apt-get install gfan
\end{verbatim}
or
\begin{verbatim}
sudo emerge gfan
\end{verbatim}
depending on your distribution and package manager. If you succeed, it is good to know which version was installed. Run
\begin{verbatim}
gfan _version
\end{verbatim}
Should this command fail, then you are using an old version of gfan.
%If you are using MacOS the easiest way to install Gfan is to use precompiled executables: go to the Gfan webpage, go to the binaries.html subpage, and follow the instructions there.
As an alternative to using package managers as above you can try to locate an executable file named ``gfan'' in the installation of other math software. SageMath, for example, contains a gfan executable. You also have the possibility of installing a precompiled executables: go to the Gfan webpage, go to the binaries.html subpage, and follow the instructions there. There is however only very few executables available.
%% Rewrite this section.
%% The apt-get linux trouble disappears if all includes of cdd files are of form ``cdd/set\_oper.h''. Now of course if we cannot run apt-get because we are not root we need to install cddlib manually. Here we should use configure to specify how that is done correctly. We should use --prefix=, --includedir=, and possibly --libdir=.
%% The same thing goes for gmp???? EXCEPT THAT FOR SOME REASON gmp is allowed to be in /usr/include .
%% Here is a good phrase: ``If you have root access to your maching and are running a linux system with a package manager you may install gmp and cddlib in one go by doing
%% sudo apt-get install libcdd-dev
%% Now go to Section ???''
%% \label{sec:installation}
%% If you are using Linux the following might work
%% \begin{verbatim}
%% sudo apt-get install gfan
%% \end{verbatim}
%% or
%% \begin{verbatim}
%% sudo emerge gfan
%% \end{verbatim}
%% depending on your distribution and package manager. If you succeed, it is good to know which version was installed. Run
%% \begin{verbatim}
%% gfan _version
%% \end{verbatim}
%% Should this command fail, then you are using an old version of gfan.
The rest of this section eplains how to install Gfan by compiling it from source on a Linux/Unix-like
system with a modern version of gcc. You must already have this compiler installed on your system to follow the instructions. \name has been compiled
successfully with gcc version~11.2.0. {\bf Two libraries are needed in order
to compile \name: {cddlib} and { gmp}.} Users of Microsoft
Windows may be able to use these installation instructions if they
first install Cygwin. A new feature in \name version 0.4 is the
possibility to link to the SoPlex \cite{wunderling} library. This does
not add to the functionality of \name but improves speed of the
polyhedral computations. In an attempt to keep the installation instructions simple, instructions for how to use SoPlex are given in a separate section, Subsection \ref{subsec:soplex}. {\color{red} If you are a lucky Linux user it will suffice to follow the red part of these instructions.}
\subsection{Installation of the gmp library}
GMP stands for GNU Multi Precision arithmetic library. This library
must be installed on your system before you can install cddlib and
gfan.
%With the
%current {\tt Makefile} of \name gmp must have been installed by the
%root superuser.
{\color{red}
{\bf On some GNU/Linux systems the library is already installed.}}
%\name can be compiled with gmp version 4.1.2.
If your system does not already
have gmp installed (which is the case if you have a usual Mac OS X
installation) follow the directions in this section.
\vspace{0.3cm}
IF YOU ARE USING Mac OS X AND YOU ARE NOT AN EXPERT FOLLOW THE INSTRUCTIONS IN SECTION~\ref{sec:fink} INSTEAD.
\vspace{0.3cm}
\noindent
Make a new directory and download {\tt gmp-4.2.2.tar.gz} from
\centerline{\tt http://gmplib.org/}
\noindent
for example by typing
\begin{verbatim}
cd ~
mkdir tempdir
cd tempdir
wget http://ftp.sunet.se/pub/gnu/gmp/gmp-4.2.2.tar.gz
\end{verbatim}
Extract the file and go to the thereby created directory:
\begin{verbatim}
tar -xzvf gmp-4.2.2.tar.gz
cd gmp-4.2.2
\end{verbatim}
Run the configure script and specify the installation directory:
\begin{verbatim}
./configure --prefix=$HOME/gfan/gmp
\end{verbatim}
%$
The above line specifies the installation directory which in this case
will be the folder {\tt gfan/gmp} in your home directory. If you already have
a directory by that name its content may be destroyed by the subsequent commands.
Compile the gmp library and install it:
\begin{verbatim}
make
make install
\end{verbatim}
Finally, a very important step when working with gmp: Let the program
perform a self-test:
\begin{verbatim}
make check
\end{verbatim}
The gmp installation is now complete. The gmp files can be found in your
home directory under {\tt gfan/gmp}.
\subsubsection{Installing the gmp library on Mac OS X using fink}
\label{sec:fink}
{\bf This subsubsection might very well be outdated.}\\
Current versions of Mac OS X and the gmp library have a compatibility
problem causing gmp to be compiled with errors if compiled without
modifications. There exist packages of gmp for Mac OS X on the internet
which have been compiled incorrectly. We recommend that Mac OS users
use the packages provided by fink.
\vspace{0.3cm}
\noindent
Install fink by following the instructions given on the page
\centerline{\tt http://www.finkproject.org/download/index.php?phpLang=en}
\noindent
Having installed fink now simply type
\begin{verbatim}
fink install gmp
\end{verbatim}
The gmp library is now installed in the directory {\tt /sw}.
\subsection{Installation of the cddlib library}
Cddlib \cite{cdd} is a library for doing exact polyhedral
computations, including solving linear programming problems. \name can
be compiled with cddlib version 094. Older versions of cddlib will not
work with \name version 0.2 or later.
% The library can be installed
%anywhere in the file system, so superuser access is not needed.
Notice that cddlib itself needs gmp to compile. We give
instructions on how to install cddlib.
% If this does not work have a look in the cddlib manual.
\vspace{0.3cm}
\noindent
\color{red}
Make a directory for the compilation process if you did not do that already:
\begin{verbatim}
cd ~
mkdir tempdir
cd tempdir
\end{verbatim}
\noindent
Download the file {\tt cddlib-094i.tar.gz} from
\begin{verbatim}
https://people.inf.ethz.ch/fukudak/cdd_home/Cddtarfiles_pub/
\end{verbatim}
% https://people.inf.ethz.ch/fukudak/cdd_home/
% http://www.ifor.math.ethz.ch/~fukuda/cdd_home/cdd.html
% http://www.cs.mcgill.ca/~fukuda/soft/cdd_home/cdd.html
into that directory.
Decompress the file and change directory to the directory being created:
\begin{verbatim}
tar -xzvf cddlib-094i.tar.gz
cd cddlib-094i
\end{verbatim}
Run the configure script. \color{black} Here you have the chance of telling cddlib where to find gmp and where to install itself.
\begin{verbatim}
./configure --prefix="$HOME/gfan/cddlib"
CFLAGS="-I$HOME/gfan/gmp/include -L$HOME/gfan/gmp/lib"
\end{verbatim}
%$
(On a single line).
The above options say that cddlib should be installed in your home directory under {\tt gfan/cddlib} and where to look for gmp. If gmp was installed by fink (see Section~\ref{sec:fink}) you should run
\begin{verbatim}
./configure --prefix="$HOME/gfan/cddlib"
CFLAGS="-I/sw/include -L/sw/lib"
\end{verbatim}
instead. {\bf If gmp was already installed on your system in its default location run}
\color{red}
\begin{verbatim}
./configure --prefix="$HOME/gfan/cddlib"
\end{verbatim}
\color{black}
%$
The content of {\tt gfan/cddlib} might be destroyed by the subsequent commands.
Compile and install cddlib:
\color{red}
\begin{verbatim}
make
make install
\end{verbatim}
\color{black}
You can now find the installed cddlib library files in your home directory under {\tt gfan/cddlib}.
\noindent
If you had super user access you could also just have run
\begin{verbatim}
./configure
\end{verbatim}
when you configured cddlib. This would cause cddlib to be installed in its default place.
\subsection{\name installation}
\label{subsec:installation}
\color{red}
Download the file {\tt \nameversion .tar.gz} from the \name
homepage located at:
% \centerline{\tt http://www.soopadoopa.dk/anders/gfan/gfan.html.}
% \centerline{\tt http://home.imf.au.dk/ajensen/software/gfan/gfan.html}
\begin{verbatim}
http://home.math.au.dk/jensen/software/gfan/gfan.html
\end{verbatim}
to your folder {\texttt tempdir}.
\noindent
Extract the file and enter the new directory by typing
\begin{alltt}
cd ~
cd tempdir
tar -xzvf \nameversion.tar.gz
cd \nameversion
\end{alltt}
\color{black}
Gfan does not have a configure script, so you tell Gfan where to find gmp and cdd when you compile the program. For example you should type
\begin{verbatim}
make
\end{verbatim}
or
\color{red}
\begin{verbatim}
make cddpath=$HOME/gfan/cddlib
\end{verbatim}
\color{black}
%$
or
\begin{verbatim}
make cddpath=$HOME/gfan/cddlib gmppath=$HOME/gfan/gmp
\end{verbatim}
%$
or
\begin{verbatim}
make cddpath=$HOME/gfan/cddlib gmppath=/sw
\end{verbatim}
%$
depending on where you installed the libraries to compile the program.
If the compiler complains about not being able to find include files when compiling, doing
\begin{verbatim}
make cddnoprefix=true
\end{verbatim}
might help.
If you managed to compile and produce the file ``gfan'' you may wish to test the compiled \name before installing:
\begin{verbatim}
./gfan _test
\end{verbatim}
The final step is to install the compiled program. Type
\color{red}
\begin{verbatim}
make PREFIX=$HOME/gfan install
\end{verbatim}
%$
\color{black}or
\begin{verbatim}
make install
\end{verbatim}
depending on where you want Gfan installed. (The second line attempts to install it in {\tt /usr/local} by default). If you chose to install in
the directory {\tt gfan} in your home folder \color{red}you will now find the
file {\tt gfan} in the subdirectory {\tt gfan/bin} of your home folder together with a set of symbolic links\color{black},
for example {\tt gfan\_buchberger}.
You can go to the subdirectory and type {\tt ./\exename{} --help} and {\tt ./\exename{}\_buchberger --help} in
the shell to test them. Or you can ask Gfan to compute the reduced Gr\"obner bases of an ideal by typing
\begin{alltt}
./\exename{}\_bases
\end{alltt}
followed by, for example,
\begin{verbatim}
Q[a,b,c]
{a^3+b^2c-a,c^2-2/3b}
\end{verbatim}
\begin{remark}
If for some reason you did get {\tt gfan} compiled but did not get the symbolic links made like {\tt gfan\_buchberger} you can still run that program by typing {\tt gfan \_buchberger} instead of {\tt gfan\_buchberger}.
\end{remark}
\subsection{SoPlex (for the advanced user only)}
\label{subsec:soplex}
{\bf These instructions do not work for linking with new versions of SoPlex.}
Linking Gfan to SoPlex can lead to huge performance
improvements. Notice however, that the strict license of SoPlex
propagates through the software to your paper, requiring that you cite
SoPlex appropriately if you choose to publish results based on SoPlex.
Furthermore, with the standard SoPlex license you are only allowed to
use SoPlex for non-commercial, academic work.
Download SoPlex here (version 1.3.2 has been used successfully):
\begin{verbatim}
http://soplex.zib.de/download.shtml
\end{verbatim}
After download, follow the installation instructions
\begin{verbatim}
http://www.zib.de/Optimization/Software/Soplex/html/INST.html
\end{verbatim}
After having installed SoPlex, you must tell \name where SoPlex is located. Do this by editing the lines
\begin{footnotesize}
\begin{verbatim}
SOPLEX_PATH = $(HOME)/math/software/soplex-1.3.2
SOPLEX_LINKOPTIONS = -lz $(SOPLEX_PATH)/lib/libsoplex.darwin.x86.gnu.opt.a
\end{verbatim}
\end{footnotesize}
of the file \texttt{Makefile} in your \name directory. Most likely
you need to change \texttt{darwin} to \texttt{linux} in the last line.
Finally you need to recompile \name. First run \texttt{make clean} and
then \texttt{make} with the options from
Subsection~\ref{subsec:installation} together with the
option \texttt{soplex=true}. Then do a \texttt{make install} as
described in Subsection~\ref{subsec:installation}.
%Please keep on reading --- in the next section we will see how to install all the additional \name programs.
%\subsection{Installation to invoke additional features}
%If you have root access to the system it is recommended that you type
%\begin{verbatim}
%make install
%\end{verbatim}
%in your shell after having compiled \name. This will copy the file {\tt \exename} to the directory {\tt /usr/local/bin} and \name will now be accessible from any directory and by any user by typing
%\begin{alltt}
%\exename
%\end{alltt}
%The {\tt make install} step above also creates symbolic links for the additional programs included in \name (like {\tt \exename \_buchberger} or {\tt \exename \_render}). If you chose not to run {\tt make install} you can install the additional programs in \name by typing
%\begin{alltt}
%./\exename installlinks
%\end{alltt}
%This will create a set of symbolic links to {\tt \exename} in the current directory. Invoking {\tt \exename} with one of these new names will have a different meaning. For example you may use {\tt \exename \_buchberger} to compute a single Gr\"obner basis. These programs have a help file which can be displayed by invoking the programs with the option {\tt --help}. The contents of the help files are also listed in Section \ref{sec:applist}.
%\subsection{MacOS}
%\subsubsection{Installing gmp from source}
%\subsubsection{Installing with fink}
%\begin{description}
%\item{gmp} dgdgdfdg
%\item{cddlib}
%Download the file {\tt cddlib-094b.tar.gz} from
%\begin{verbatim}
%http://www.cs.mcgill.ca/~fukuda/soft/cdd_home/cdd.html
%\end{verbatim}
%into a directory. Decompress the file using {\tt gzip -d
% cddlib-094b.tar.gz} and extract the tar archive using {\tt tar -xvf
% cddlib-094b.tar}. Change directory to the newly created directory
%{\tt cddlib-094b} and run
%\begin{verbatim}
%./configure --prefix="$HOME/cddlib" CFLAGS="-I/sw/include -L/sw/lib"
%\end{verbatim}
%When the following command is run the directory ``cddlib'' is created in your home directory. If it already exists the directory is destroyed.
%\begin{verbatim}
%make install
%\end{verbatim}
%\end{description}
%\begin{center}
% {\bf The complete list of functionalities available in CaTS and the
% programs they need are listed at the end of the manual.}
%\end{center}
|