1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML3.2 EN">
<HTML>
<HEAD> <link rel="canonical" href="http://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/Sys/PetscBLASInt.html" />
<META NAME="GENERATOR" CONTENT="DOCTEXT">
<TITLE>PetscBLASInt</TITLE>
</HEAD>
<BODY BGCOLOR="FFFFFF">
<div id="version" align=right><b>petsc-3.14.5 2021-03-03</b></div>
<div id="bugreport" align=right><a href="mailto:petsc-maint@mcs.anl.gov?subject=Typo or Error in Documentation &body=Please describe the typo or error in the documentation: petsc-3.14.5 v3.14.5 docs/manualpages/Sys/PetscBLASInt.html "><small>Report Typos and Errors</small></a></div>
<A NAME="PetscBLASInt"><H1>PetscBLASInt</H1></A>
datatype used to represent 'int' parameters to BLAS/LAPACK functions.
<H3><FONT COLOR="#CC3333">Notes</FONT></H3>
Usually this is the same as <A HREF="../Sys/PetscInt.html#PetscInt">PetscInt</A>, but if PETSc was built with --with-64-bit-indices but
standard C/Fortran integers are 32 bit then this is NOT the same as <A HREF="../Sys/PetscInt.html#PetscInt">PetscInt</A> it remains 32 bit
(except on very rare BLAS/LAPACK implementations that support 64 bit integers see the notes below).
<P>
<A HREF="../Sys/PetscErrorCode.html#PetscErrorCode">PetscErrorCode</A> <A HREF="../Sys/PetscBLASIntCast.html#PetscBLASIntCast">PetscBLASIntCast</A>(a,&b) checks if the given <A HREF="../Sys/PetscInt.html#PetscInt">PetscInt</A> a will fit in a <A HREF="../Sys/PetscBLASInt.html#PetscBLASInt">PetscBLASInt</A>, if not it
generates a PETSC_ERR_ARG_OUTOFRANGE error
<P>
<H3><FONT COLOR="#CC3333">Installation Notes</FONT></H3>
./configure automatically determines the size of the integers used by BLAS/LAPACK except when --with-batch is used
in that situation one must know (by some other means) if the integers used by BLAS/LAPACK are 64 bit and if so pass the flag --known-64-bit-blas-indice
<P>
MATLAB ships with BLAS and LAPACK that use 64 bit integers, for example if you run ./configure with, the option
--with-blaslapack-lib=[/Applications/MATLAB_R2010b.app/bin/maci64/libmwblas.dylib,/Applications/MATLAB_R2010b.app/bin/maci64/libmwlapack.dylib]
<P>
MKL ships with both 32 and 64 bit integer versions of the BLAS and LAPACK. If you pass the flag -with-64-bit-blas-indices PETSc will link
against the 64 bit version, otherwise it use the 32 bit version
<P>
OpenBLAS can be built to use 64 bit integers. The ./configure options --download-openblas -with-64-bit-blas-indices will build a 64 bit integer version
<P>
External packages such as hypre, ML, SuperLU etc do not provide any support for passing 64 bit integers to BLAS/LAPACK so cannot
be used with PETSc when PETSc links against 64 bit integer BLAS/LAPACK. ./configure will generate an error if you attempt to link PETSc against any of
these external libraries while using 64 bit integer BLAS/LAPACK.
<P>
<P>
<H3><FONT COLOR="#CC3333">See Also</FONT></H3>
<A HREF="../Sys/PetscMPIInt.html#PetscMPIInt">PetscMPIInt</A>, <A HREF="../Sys/PetscInt.html#PetscInt">PetscInt</A>, <A HREF="../Sys/PetscBLASIntCast.html#PetscBLASIntCast">PetscBLASIntCast</A>()
<BR>
<P>
<P><B></B><H3><FONT COLOR="#CC3333">Level</FONT></H3>intermediate<BR>
<H3><FONT COLOR="#CC3333">Location</FONT></H3>
</B><A HREF="../../../include/petscsystypes.h.html#PetscBLASInt">include/petscsystypes.h</A>
<BR><A HREF="./index.html">Index of all Sys routines</A>
<BR><A HREF="../../index.html">Table of Contents for all manual pages</A>
<BR><A HREF="../singleindex.html">Index of all manual pages</A>
</BODY></HTML>
|