class Fftw < Formula desc "C routines to compute the Discrete Fourier Transform" homepage "http://www.fftw.org" url "http://fftw.org/fftw-3.3.6-pl1.tar.gz" version "3.3.6-pl1" sha256 "1ef4aa8427d9785839bc767f3eb6a84fcb5e9a37c31ed77a04e7e047519a183d" bottle do cellar :any sha256 "fd1efca44c0a587c8743aedc05190864c12a56acf5a23aaf2b628bd80c832415" => :sierra sha256 "d52d2f1479813ff7b2b11459195d1034236bda52925ffd0705b1a83b9b8830a7" => :el_capitan sha256 "b2fd9cf818a8d76caee42d1c979765ac1acc48243be45457e75f3eb5463f41b9" => :yosemite end option "with-fortran", "Enable Fortran bindings" option "with-mpi", "Enable MPI parallel transforms" option "with-openmp", "Enable OpenMP parallel transforms" depends_on :fortran => :optional depends_on :mpi => [:cc, :optional] needs :openmp if build.with? "openmp" def install args = ["--enable-shared", "--disable-debug", "--prefix=#{prefix}", "--enable-threads", "--disable-dependency-tracking"] simd_args = ["--enable-sse2"] simd_args << "--enable-avx" if ENV.compiler == :clang && Hardware::CPU.avx? && !build.bottle? simd_args << "--enable-avx2" if ENV.compiler == :clang && Hardware::CPU.avx2? && !build.bottle? args << "--disable-fortran" if build.without? "fortran" args << "--enable-mpi" if build.with? "mpi" args << "--enable-openmp" if build.with? "openmp" # single precision # enable-sse2, enable-avx and enable-avx2 work for both single and double precision system "./configure", "--enable-single", *(args + simd_args) system "make", "install" # clean up so we can compile the double precision variant system "make", "clean" # double precision # enable-sse2, enable-avx and enable-avx2 work for both single and double precision system "./configure", *(args + simd_args) system "make", "install" # clean up so we can compile the long-double precision variant system "make", "clean" # long-double precision # no SIMD optimization available system "./configure", "--enable-long-double", *args system "make", "install" end test do # Adapted from the sample usage provided in the documentation: # http://www.fftw.org/fftw3_doc/Complex-One_002dDimensional-DFTs.html (testpath/"fftw.c").write <<-TEST_SCRIPT.undent #include int main(int argc, char* *argv) { fftw_complex *in, *out; fftw_plan p; long N = 1; in = (fftw_complex*) fftw_malloc(sizeof(fftw_complex) * N); out = (fftw_complex*) fftw_malloc(sizeof(fftw_complex) * N); p = fftw_plan_dft_1d(N, in, out, FFTW_FORWARD, FFTW_ESTIMATE); fftw_execute(p); /* repeat as needed */ fftw_destroy_plan(p); fftw_free(in); fftw_free(out); return 0; } TEST_SCRIPT system ENV.cc, "-o", "fftw", "fftw.c", "-lfftw3", *ENV.cflags.to_s.split system "./fftw" end end