Editing Octave for Debian systems
Jump to navigation
Jump to search
The edit can be undone. Please check the comparison below to verify that this is what you want to do, and then publish the changes below to finish undoing the edit.
Latest revision | Your text | ||
Line 1: | Line 1: | ||
For Debian, and Debian based distributions such as Ubuntu, specific solutions. | |||
== | == Pre-compiled binaries == | ||
Binary packages for | Binary packages for Octave and many Octave-Forge packages are provided by all versions of Debian and Ubuntu. These are the most well-tested binaries available and should work best for most users. | ||
sudo apt-get install octave | sudo apt-get install octave | ||
Aside the {{codeline|octave}} package that installs GNU Octave, other pieces of it are split over multiple packages. These are {{codeline|octave-doc}}, {{codeline|octave-info}}, and {{codeline|octave-htmldoc}} for the documentation; {{codeline|liboctave-dev}} for the octave development header files and mkoctfile (required to install Octave Forge packages); and {{codeline|octave-dbg}} for the debugging symbols. | |||
For Debian stable users, there may also be newer packages available in backports, so don't forget to check there. | |||
Many Octave packages are also distributed by | === Octave packages === | ||
Many Octave packages are also distributed by your Linux distribution. These are tested to work the best with your Octave version. For example: | |||
sudo apt-get install octave-control octave-image octave-io octave-optim octave-signal octave-statistics | sudo apt-get install octave-control octave-image octave-io octave-optim octave-signal octave-statistics | ||
=== Octave's Personal Package Archive (PPA) for Ubuntu === | |||
For some Ubuntu releases the octave packages are too old (Ubuntu 12.04 only has Octave version 3.2). The [https://launchpad.net/~octave GNU Octave Team] on Launchpad maintains a PPA providing more up to date packages of Octave for all versions of Ubuntu. These are backported from Debian unstable (the Ubuntu Octave Team needs help testing and preparing the packages so if you can help with this, contact [[User:Mtmiller|Mike Miller]]). To set up your system to install these packages: | |||
sudo apt-add-repository ppa:octave/stable | sudo apt-add-repository ppa:octave/stable | ||
Line 23: | Line 25: | ||
sudo apt-get install octave | sudo apt-get install octave | ||
== | == Compiling from source == | ||
The ''only'' tricky part is to install the dependencies. Once that is solved, installing from source should be as easy as {{Codeline|./configure && make && make install}}. See the manual for [http://www.gnu.org/software/octave/doc/interpreter/Running-Configure-and-Make.html configure options]. | |||
The ''only'' tricky part is to install the | |||
=== Install dependencies === | === Install dependencies === | ||
Line 42: | Line 42: | ||
* may install packages that are no longer octave dependencies. | * may install packages that are no longer octave dependencies. | ||
==== The | ==== The even easier way (but experimental) ==== | ||
The | The [[MXE|MXE-octave]] package provides a way to compile Octave for different platforms. Dependencies and certain flags are handled automatically. | ||
==== The right way ==== | |||
The right way is to select and install all the dependencies as listed in the {{Path|INSTALL.OCTAVE}} file. The following are their package names in Debian repositories (they will have their own dependencies which your package manager will solve automatically). If you are building development versions, you'll require some more packages as listed on {{Path|etc/HACKING}} and {{Path|INSTALL}}. Many of them will already be installed on your system. Install the dependencies by typing | |||
sudo apt-get install | |||
followed by the package names of the table below. | |||
:{| class="wikitable" | |||
: | |- | ||
! Dependency !! Debian 8 Jessie (stable) !! Ubuntu 14.04 Trusty Tahr (LTS) | |||
|- | |||
!colspan="3" style="text-align:center;" | Required build tools | |||
|- | |||
| C compiler | |||
|| [https://packages.debian.org/jessie/gcc gcc] | |||
|| [http://packages.ubuntu.com/trusty/gcc gcc] | |||
|- | |||
| C++ compiler | |||
|| [https://packages.debian.org/jessie/g++ g++] | |||
|| [http://packages.ubuntu.com/trusty/g++ g++] | |||
|- | |||
| Fortran compiler | |||
|| [https://packages.debian.org/jessie/gfortran gfortran] | |||
|| [http://packages.ubuntu.com/trusty/gfortran gfortran] | |||
|- | |||
| GNU make | |||
|| [https://packages.debian.org/jessie/make make] | |||
|| [http://packages.ubuntu.com/trusty/make make] | |||
|- | |||
!colspan="3" style="text-align:center;"| Required external packages | |||
|- | |||
| BLAS | |||
|| [https://packages.debian.org/jessie/libblas-dev libblas-dev] | |||
|| [http://packages.ubuntu.com/trusty/libblas-dev libblas-dev] | |||
|- | |||
| LAPACK | |||
|| [https://packages.debian.org/jessie/liblapack-dev liblapack-dev] | |||
|| [http://packages.ubuntu.com/trusty/liblapack-dev liblapack-dev] | |||
|- | |||
| PCRE | |||
|| [https://packages.debian.org/jessie/libpcre3-dev libpcre3-dev] | |||
|| [http://packages.ubuntu.com/trusty/libpcre3-dev libpcre3-dev] | |||
|- | |||
!colspan="3" style="text-align:center;"| ''Strongly'' recommended. Check the [http://www.gnu.org/software/octave/doc/interpreter/External-Packages.html Octave manual] for more information. | |||
|- | |||
| ARPACK | |||
|| [https://packages.debian.org/jessie/libarpack2-dev libarpack2-dev] | |||
|| [http://packages.ubuntu.com/trusty/libarpack2-dev libarpack2-dev] | |||
|- | |||
| cURL | |||
|| [https://packages.debian.org/jessie/libcurl4-gnutls-dev libcurl4-gnutls-dev] | |||
|| [http://packages.ubuntu.com/trusty/libcurl4-gnutls-dev libcurl4-gnutls-dev] | |||
|- | |||
| epstool | |||
|| [https://packages.debian.org/jessie/epstool epstool] | |||
|| [http://packages.ubuntu.com/trusty/epstool epstool] | |||
|- | |||
| FFTW3 | |||
|| [https://packages.debian.org/jessie/libfftw3-dev libfftw3-dev] | |||
|| [http://packages.ubuntu.com/trusty/libfftw3-dev libfftw3-dev] | |||
|- | |||
| fig2dev | |||
|| [https://packages.debian.org/jessie/transfig transfig] | |||
|| [http://packages.ubuntu.com/trusty/transfig transfig] | |||
|- | |||
| FLTK | |||
|| [https://packages.debian.org/jessie/libfltk1.3-dev libfltk1.3-dev] | |||
|| [http://packages.ubuntu.com/trusty/libfltk1.3-dev libfltk1.3-dev] | |||
|- | |||
| fontconfig | |||
|| [https://packages.debian.org/jessie/libfontconfig1-dev libfontconfig1-dev] | |||
|| [http://packages.ubuntu.com/trusty/libfontconfig1-dev libfontconfig1-dev] | |||
|- | |||
| FreeType | |||
|| [https://packages.debian.org/jessie/libfreetype6-dev libfreetype6-dev] | |||
|| [http://packages.ubuntu.com/trusty/libfreetype6-dev libfreetype6-dev] | |||
|- | |||
| gl2ps | |||
|| [https://packages.debian.org/jessie/libgl2ps-dev libgl2ps-dev] | |||
|| [http://packages.ubuntu.com/trusty/libgl2ps-dev libgl2ps-dev] | |||
|- | |||
| GLPK | |||
|| [https://packages.debian.org/jessie/libglpk-dev libglpk-dev] | |||
|| [http://packages.ubuntu.com/trusty/libglpk-dev libglpk-dev] | |||
|- | |||
| GNU Readline | |||
|| [https://packages.debian.org/jessie/libreadline-dev libreadline-dev] | |||
|| [http://packages.ubuntu.com/trusty/libreadline-dev libreadline-dev] | |||
|- | |||
| gnuplot | |||
|| [https://packages.debian.org/jessie/gnuplot gnuplot] | |||
|| [http://packages.ubuntu.com/trusty/gnuplot gnuplot-x11] | |||
|- | |||
| GraphicsMagick++ | |||
|| [https://packages.debian.org/jessie/libgraphicsmagick++1-dev libgraphicsmagick++1-dev] | |||
|| [http://packages.ubuntu.com/trusty/libgraphicsmagick++1-dev libgraphicsmagick++1-dev] | |||
|- | |||
| HDF5 | |||
|| [https://packages.debian.org/jessie/libhdf5-serial-dev libhdf5-serial-dev] | |||
|| [http://packages.ubuntu.com/trusty/libhdf5-serial-dev libhdf5-serial-dev] | |||
|- | |||
| Java JDK | |||
|| [https://packages.debian.org/jessie/openjdk-7-jdk openjdk-7-jdk] | |||
|| [http://packages.ubuntu.com/trusty/openjdk-7-jdk openjdk-7-jdk] | |||
|- | |||
| libsndfile | |||
|| [https://packages.debian.org/jessie/libsndfile1-dev libsndfile1-dev] | |||
|| [http://packages.ubuntu.com/trusty/libsndfile1-dev libsndfile1-dev] | |||
|- | |||
| LLVM | |||
|| [https://packages.debian.org/jessie/llvm-dev llvm-dev] | |||
|| [http://packages.ubuntu.com/trusty/llvm-dev llvm-dev] | |||
|- | |||
| lpr | |||
|| [https://packages.debian.org/jessie/lpr lpr] | |||
|| [http://packages.ubuntu.com/trusty/lpr lpr] | |||
|- | |||
| makeinfo | |||
|| [https://packages.debian.org/jessie/texinfo texinfo] | |||
|| [http://packages.ubuntu.com/trusty/texinfo texinfo] | |||
|- | |||
| OpenGL | |||
|| [https://packages.debian.org/jessie/libgl1-mesa-dev libgl1-mesa-dev] | |||
|| [http://packages.ubuntu.com/trusty/libgl1-mesa-dev libgl1-mesa-dev] | |||
|- | |||
| OSMesa | |||
|| [https://packages.debian.org/jessie/libosmesa6-dev libosmesa6-dev] | |||
|| [http://packages.ubuntu.com/trusty/libosmesa6-dev libosmesa6-dev] | |||
|- | |||
| pstoedit | |||
|| [https://packages.debian.org/jessie/pstoedit pstoedit] | |||
|| [http://packages.ubuntu.com/trusty/pstoedit pstoedit] | |||
|- | |||
| PortAudio | |||
|| [https://packages.debian.org/jessie/portaudio19-dev portaudio19-dev] | |||
|| [http://packages.ubuntu.com/trusty/portaudio19-dev portaudio19-dev] | |||
|- | |||
| Qhull | |||
|| [https://packages.debian.org/jessie/libqhull-dev libqhull-dev] | |||
|| [http://packages.ubuntu.com/trusty/libqhull-dev libqhull-dev] | |||
|- | |||
| QRUPDATE | |||
|| [https://packages.debian.org/jessie/libqrupdate-dev libqrupdate-dev] | |||
|| [http://packages.ubuntu.com/trusty/libqrupdate-dev libqrupdate-dev] | |||
|- | |||
| QScintilla | |||
|| [https://packages.debian.org/jessie/libqscintilla2-dev libqscintilla2-dev] | |||
|| [http://packages.ubuntu.com/trusty/libqscintilla2-dev libqscintilla2-dev] | |||
|- | |||
| Qt | |||
|| | |||
[https://packages.debian.org/jessie/libqt4-dev libqt4-dev] | |||
[https://packages.debian.org/jessie/libqtcore4 libqtcore4] | |||
[https://packages.debian.org/jessie/libqtwebkit4 libqtwebkit4] | |||
[https://packages.debian.org/jessie/libqt4-network libqt4-network] | |||
[https://packages.debian.org/jessie/libqtgui4 libqtgui4] | |||
[https://packages.debian.org/jessie/libqt4-opengl-dev libqt4-opengl-dev] | |||
|| | |||
[http://packages.ubuntu.com/trusty/libqt4-dev libqt4-dev] | |||
[http://packages.ubuntu.com/trusty/libqtcore4 libqtcore4] | |||
[http://packages.ubuntu.com/trusty/libqtwebkit4 libqtwebkit4] | |||
[http://packages.ubuntu.com/trusty/libqt4-network libqt4-network] | |||
[http://packages.ubuntu.com/trusty/libqtgui4 libqtgui4] | |||
|- | |||
| SuiteSparse | |||
|| [https://packages.debian.org/jessie/libsuitesparse-dev libsuitesparse-dev] | |||
|| [http://packages.ubuntu.com/trusty/libsuitesparse-dev libsuitesparse-dev] | |||
|- | |||
| Texlive | |||
|| texlive | |||
|| texlive | |||
|- | |||
| Xft | |||
|| [https://packages.debian.org/jessie/libxft-dev libxft-dev] | |||
|| [http://packages.ubuntu.com/trusty/libxft-dev libxft-dev] | |||
|- | |||
| zlib | |||
|| [https://packages.debian.org/jessie/zlib1g-dev zlib1g-dev] | |||
|| [http://packages.ubuntu.com/trusty/zlib1g-dev zlib1g-dev] | |||
|- | |||
!colspan="3" style="text-align:center;"| Required to build from development sources | |||
|- | |||
| Autoconf | |||
|| [https://packages.debian.org/jessie/autoconf autoconf] | |||
|| [http://packages.ubuntu.com/trusty/autoconf autoconf] | |||
|- | |||
| Automake | |||
|| [https://packages.debian.org/jessie/automake automake] | |||
|| [http://packages.ubuntu.com/trusty/automake automake] | |||
|- | |||
| Bison | |||
|| [https://packages.debian.org/jessie/bison bison] | |||
|| [http://packages.ubuntu.com/trusty/bison bison] | |||
|- | |||
| Flex | |||
|| [https://packages.debian.org/jessie/flex flex] | |||
|| [http://packages.ubuntu.com/trusty/flex flex] | |||
|- | |||
| gperf | |||
|| [https://packages.debian.org/jessie/gperf gperf] | |||
|| [http://packages.ubuntu.com/trusty/gperf gperf] | |||
|- | |||
| gzip | |||
|| [https://packages.debian.org/jessie/gzip gzip] | |||
|| [http://packages.ubuntu.com/trusty/gzip gzip] | |||
|- | |||
| icoutils | |||
|| [https://packages.debian.org/jessie/icoutils icoutils] | |||
|| [http://packages.ubuntu.com/trusty/icoutils icoutils] | |||
|- | |||
| rsvg-convert | |||
|| [https://packages.debian.org/jessie/librsvg2-bin librsvg2-bin] | |||
|| [http://packages.ubuntu.com/trusty/librsvg2-bin librsvg2-bin] | |||
|- | |||
| libtool | |||
|| [https://packages.debian.org/jessie/libtool libtool] | |||
|| [http://packages.ubuntu.com/trusty/libtool libtool] | |||
|- | |||
| perl | |||
|| [https://packages.debian.org/jessie/perl perl] | |||
|| [http://packages.ubuntu.com/trusty/perl perl] | |||
|- | |||
| rsync | |||
|| [https://packages.debian.org/jessie/rsync rsync] | |||
|| [http://packages.ubuntu.com/trusty/rsync rsync] | |||
|- | |||
| tar | |||
|| [https://packages.debian.org/jessie/tar tar] | |||
|| [http://packages.ubuntu.com/trusty/tar tar] | |||
|} | |||
( | {{Warning|<ul><li>The Debian repositoriy has several libraries for dealing with HDF data files. The recommended is {{Codeline|libhdf5-serial-dev}}. However, the {{Forge|msh|msh package}} requires [http://www.geuz.org/gmsh/ gmsh] which is incompatible with it.</li> | ||
<li>The GraphicsMagick++ library (libgraphicsmagick++1-dev) on the Debian repositories was compiled with quantum 8 which limits reading images to 8 bit. The solution is to recompile [[GraphicsMagick]] with quantum 16 or 32 before building Octave.</li></ul>}} | |||
=== Configuration === | |||
As mentioned above, Octave can be compiled with the default settings using {{Codeline|./configure && make && make install}}. You can also tweak the setup using configure options. Some examples are given below for a Linux system. | |||
==== 64 bit ==== | |||
: | To get [https://www.gnu.org/software/octave/doc/interpreter/Compiling-Octave-with-64_002dbit-Indexing.html 64-bit] requires all linked libraries to support 64-bit variables. You can omit most of these except BLAS which gives a fatal error. This is remedied by compiling [http://www.openblas.net/ OpenBLAS] with edits to its Makefile.rule so that BINARY=64 INTERFACE64=1. | ||
<code>./configure LD_LIBRARY_PATH=/opt/OpenBLAS/lib CPPFLAGS=-I/opt/OpenBLAS/include LDFLAGS=-L/opt/OpenBLAS/lib --enable-64</code>. | |||
==== Java JIT ==== | |||
To get the just-in-time compiler, you should specify the location of the java compiler since the autodetection script often fails. | |||
<code>./configure JAVA_HOME="/usr/lib/jvm/java-7-openjdk-amd64" --enable-jit</code> | |||
==== HDF5 ==== | ==== HDF5 ==== | ||
With current Debian versions you may get the following when building from source: | |||
HDF5 library not found. Octave will not be able to save or load HDF5 data files. | HDF5 library not found. Octave will not be able to save or load HDF5 data files. | ||
The problem is that there are multiple versions of the hdf5 package. Octave was written with the serial version in mind but it is likely to work with the others (OpenMPI and Mpich). Due to the naming scheme done in Debian, it | The problem is that there are multiple versions of the hdf5 package. Octave was written with the serial version in mind but it is likely to work with the others (OpenMPI and Mpich). Due to the naming scheme done in Debian, it is required to specify the location of the libraries. See bug {{bug|38928}} for details but basically, use the following when running configure: | ||
./configure CPPFLAGS=-I/usr/include/hdf5/serial LDFLAGS=-L/usr/lib/$(dpkg-architecture -qDEB_HOST_MULTIARCH)/hdf5/serial | |||
[[Category:Building]] | [[Category:Building]] | ||
[[Category:Installation]] | [[Category:Installation]] | ||
[[Category: | [[Category:Debian]] |