= ATLAS =
== Description ==
This spkg builds ATLAS for Sage. It is build per default on Linux and
Solaris, but should also work on OSX and Cygwin.
== License ==
3-clause BSD
== SPKG Maintainers ==
* David Kirkby
* William Stein
* Volker Braun
== Upstream Contact ==
* Atlas devel mailing list.
* Clint Whaley has frequently answered questions from the Sage project
== Dependencies ==
* Python
== Special Update/Build Instructions ==
* src/lapack-x.y.z.tgz: The netlib lapack tarball. If you update this,
make sure you also update the LAPACK_TARBALL variable in spkg-install.
* src/ATLAS-lib: We are using a dummy autotools/libtools project
to repack the static ATLAS libraries into shared libraries.
* src/ARCHS: We ship some archdef tarballs to speed ATLAS build.
* spkg-install: If you update atlas to a new version make sure that the
ATLAS_OSTYPE, ATLAS_MACHTYPE, and ATLAS_ISAEXT variables in
spkg-install remain in sync with atlas' CONFIG/include/atlconf.h
* The package is never installed on OS X, unless you set SAGE_ATLAS_ARCH.
=== Patches ===
* patches/detect.patch: Fix Itanium2 support on modern
RHEL 5 and SLES 10 systems, work around -m64 issue on Itanium2,
and correctly detect number and speed of CPUs on a bunch of systems.
* patches/arm_hard_floats.patch: make sure soft floats are not enforced on ARM.
* patches/long_filenames.patch: fix for long filenames (>128 chars).
* patches/shell.patch: replace two instances of "test -e" by "test -f",
as the former is not portable (in particular for the Solaris shell).
* patches/Makefile.patch: fix clean target.
* patches/threads.patch: Avoid thread-related symbols
ATL_(Set|Reset|Free|Dec)AtomicCount symbols in single-threaded
library.
* patches/do_not_force_mutex.patch: always use assembly over mutex
since the mutex version fails to build a shared library. See #15045
for details.
* patches/glibc_scanf_workaround.patch: Workaround for the scanf bug
in glibc-2.18 that breaks the atlas auto-tuning system.
=== Configuration ===
The package can be configured via three environment variables:
* SAGE_ATLAS_LIB=path
If this environment variable is set, the libraries libatlas,
libcblas, liblapack, and libf77blas from the direcory "path" are
used and ATLAS is not compiled from source. The libraries can be
either static (endin in .a) or shared libraries (ending in .so or
.dylib).
* SAGE_ATLAS_ARCH=arch[,isaext1][,isaext2]...[,isaextN]
The given architectural default and instruction set extensions are
used instead of the empirical tuning. Available architectures are
POWER3, POWER4, POWER5, PPCG4, PPCG5, POWER6, POWER7, IBMz9,
IBMz10, IBMz196, x86x87, x86SSE1, x86SSE2, x86SSE3, P5, P5MMX,
PPRO, PII, PIII, PM, CoreSolo, CoreDuo, Core2Solo, Core2, Corei1,
Corei2, Atom, P4, P4E, Efficeon, K7, HAMMER, AMD64K10h, AMDDOZER,
UNKNOWNx86, IA64Itan, IA64Itan2, USI, USII, USIII, USIV, UST1, UST2,
UnknownUS, MIPSR1xK, MIPSICE9, ARMv6, ARMv7
and instruction set extensions are
VSX, AltiVec, AVXMAC, AVXFMA4, AVX, SSE3, SSE2, SSE1, 3DNow, NEON
In addition, you can also set
- SAGE_ATLAS_ARCH=fast picks defaults for a modern (2-3 year old)
CPU of your processor line, and
- SAGE_ATLAS_ARCH=base picks defaults that should work for a ~10
year old CPU.
For example,
SAGE_ATLAS_ARCH=Corei2,AVX,SSE3,SSE2,SSE1
would be appropriate for a Core i7 CPU.
* If SAGE_ATLAS_SAVE_ARCHDEF = <path> is given, then a new archdef
file is created and saved to the given path.