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-pl2.tar.gz" version "3.3.6-pl2" sha256 "a5de35c5c824a78a058ca54278c706cdf3d4abba1c56b63531c2cb05f5d57da2" bottle do cellar :any sha256 "293e6d290a437b18e0a1563622ca1e6bb3efc0574de8db461dc7066281fcf8e4" => :sierra sha256 "3b0c6440faf90169571c67ef1f6532db743adfb64ccb41e5786eaffc2a2d925f" => :el_capitan sha256 "c650cf7a95ab5d2935b726a692e6f08f7f93281e24d1e44536bac0d34b440ff3" => :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", "-L#{lib}", "-lfftw3", *ENV.cflags.to_s.split system "./fftw" end end