2018-02-02 06:38:57 +00:00
|
|
|
class Petsc < Formula
|
|
|
|
desc "Portable, Extensible Toolkit for Scientific Computation"
|
|
|
|
homepage "https://www.mcs.anl.gov/petsc/"
|
|
|
|
url "http://ftp.mcs.anl.gov/pub/petsc/release-snapshots/petsc-lite-3.9.0.tar.gz"
|
|
|
|
sha256 "a233e0d7f69c98504a1c3548162c6024f7797dde5556b83b0f98ce7326251ca1"
|
|
|
|
|
2018-04-26 09:09:34 +00:00
|
|
|
bottle do
|
|
|
|
sha256 "504bab16d879f2738e1568880c9d40cc68cad49ed8c0d0bdaa165e0a102f8465" => :high_sierra
|
|
|
|
sha256 "6ac3fdff619cecf97dd34ec49358c3004d4b610b7d062d5cb9b06fd135d55f04" => :sierra
|
|
|
|
sha256 "6e1b61304f92067de7ab36d5da2696b4132e79488cbf6bd729dea17908ca3bd4" => :el_capitan
|
|
|
|
end
|
|
|
|
|
2018-02-02 06:38:57 +00:00
|
|
|
depends_on "hdf5"
|
|
|
|
depends_on "hwloc"
|
|
|
|
depends_on "metis"
|
|
|
|
depends_on "netcdf"
|
|
|
|
depends_on "open-mpi"
|
|
|
|
depends_on "scalapack"
|
|
|
|
depends_on "suite-sparse"
|
|
|
|
|
|
|
|
def install
|
|
|
|
ENV["CC"] = "mpicc"
|
|
|
|
ENV["CXX"] = "mpicxx"
|
|
|
|
ENV["F77"] = "mpif77"
|
|
|
|
ENV["FC"] = "mpif90"
|
|
|
|
system "./configure", "--prefix=#{prefix}",
|
|
|
|
"--with-debugging=0",
|
|
|
|
"--with-scalar-type=real",
|
|
|
|
"--with-x=0"
|
|
|
|
system "make", "all"
|
|
|
|
system "make", "install"
|
|
|
|
end
|
|
|
|
|
|
|
|
test do
|
|
|
|
test_case = "#{pkgshare}/examples/src/ksp/ksp/examples/tutorials/ex1.c"
|
|
|
|
system "mpicc", test_case, "-I#{include}", "-L#{lib}", "-lpetsc", "-o", "test"
|
|
|
|
output = shell_output("./test")
|
|
|
|
# This PETSc example prints several lines of output. The last line contains
|
|
|
|
# an error norm, expected to be small.
|
|
|
|
line = output.lines.last
|
|
|
|
assert_match /^Norm of error .+, Iterations/, line, "Unexpected output format"
|
|
|
|
error = line.split[3].to_f
|
|
|
|
assert (error >= 0.0 && error < 1.0e-13), "Error norm too large"
|
|
|
|
end
|
|
|
|
end
|