Source code for naginterfaces.library.info

# -*- coding: utf-8 -*-
r"""
Module Summary
--------------
Interfaces for the NAG Mark 30.3 `info` Chapter.

``info`` - Library Identification

The functions in this module provide information about the NAG Library.

Information about the precise implementation of the NAG Library in use will be needed when communicating with the NAG Technical Support Service (see `Support from NAG <https://support.nag.com/numeric/nl/nagdoc_30.3/flhtml/genint/essint-support.html>`__).

For full information please refer to the NAG Library document

https://support.nag.com/numeric/nl/nagdoc_30.3/flhtml/a00/a00intro.html

See Also
--------
``naginterfaces.library.examples.info`` :
    This subpackage contains examples for the ``info`` module.
    See also the :ref:`library_info_ex` subsection.

Notes
-----
The function ``impl_details_separate`` is not supported in this product. Please use ``impl_details`` instead.
"""

# NAG Copyright 2017-2024.

from ..base import info as _b_info

[docs]def impl_details(): u""" NAG Library Engine identification, details of implementation and mark. .. _a00aa-py2-py-doc: For full information please refer to the NAG Library documents for a00aa and a00ad https://support.nag.com/numeric/nl/nagdoc_30.3/flhtml/a00/a00aaf.html https://support.nag.com/numeric/nl/nagdoc_30.3/flhtml/a00/a00adf.html **Returns** **result** : dict The Engine information dictionary, with the following keys: ``'build_id'`` : str or None An identifier for the implementation, or **None** if not known. ``'compilers'`` : dict The compilers used for the implementation, with the following keys: ``'C'`` : dict Information on the C compiler used, with the following keys: ``'title'`` : str Identifier for this compiler. ``'flags'`` : str Base set of flags used with this compiler. ``'C++'`` : dict Information on the C++ compiler used, with the following keys: ``'title'`` : str Identifier for this compiler. ``'flags'`` : str Base set of flags used with this compiler. ``'Fortran'`` : dict Information on the Fortran compiler used, with the following keys: ``'title':`` str Identifier for this compiler. ``'flags'`` : str Base set of flags used with this compiler. ``'hardware'`` : str The intended target hardware for the implementation. ``'integer_bits'`` : int The bit width of integers used in the implementation. ``'mark'`` : tuple Triplet of ints for the Mark number of the implementation. ``'os'`` : str The intended target operating system for the implementation. (Other OS variants may be compatible.) ``'precision'`` : str The base floating-point precision model used in the implementation. ``'product_code'`` : str The product code for the implementation. ``'title'`` : str The title of the implementation. ``'vendor_lib'`` : str or None The subsidiary vendor library used by the implementation, or **None** if self contained. **Notes** In the NAG Library the equivalent C functions for this routine are ``nag_implementation_details`` and ``nag_implementation_separated_details``. """ return _b_info.impl_details()
[docs]def licence(): r""" ``licence`` provides a convenient means of checking the availability of a valid licence key on licence-managed implementations before starting computations that will use NAG Library functions. In particular, the use of this function is highly recommended in programs that call NAG Library functions within multithreaded sections (e.g., OpenMP parallel regions). The function need only be called once, before the start of the first multithreaded section. .. _a00ac-py2-py-doc: For full information please refer to the NAG Library document for a00ac https://support.nag.com/numeric/nl/nagdoc_30.3/flhtml/a00/a00acf.html **Returns** **lic** : bool :math:`\mathbf{True}` if a licence is available. .. _a00ac-py2-py-notes: **Notes** ``licence`` returns the logical value :math:`\mathbf{True}` if a valid licence is found, otherwise :math:`\mathbf{False}` is returned. On non licence-managed implementations, :math:`\mathbf{True}` is always returned. """ raise NotImplementedError