系统配置#

当 NumPy 被构建时,系统配置的信息会被记录,并通过 NumPy 的 C API 提供给扩展模块使用.这些定义大多在 numpyconfig.h 中(包含在 ndarrayobject.h 中).公共符号以 NPY_* 为前缀.NumPy 还提供了一些用于查询当前使用平台信息的函数.

对于私人使用,NumPy 还在 NumPy 包含目录中构建了一个 config.h,该文件不会被 NumPy 导出(即使用 numpy C API 的 python 扩展不会看到这些符号),以避免命名空间污染.

数据类型大小#

NPY_SIZEOF_{CTYPE} 常量被定义,以便 sizeof 信息可用于预处理器.

NPY_SIZEOF_SHORT#

sizeof(short)

NPY_SIZEOF_INT#

sizeof(int)

NPY_SIZEOF_LONG#

sizeof(long)

NPY_SIZEOF_LONGLONG#

sizeof(longlong) 其中 longlong 在平台上适当地定义.

NPY_SIZEOF_PY_LONG_LONG#
NPY_SIZEOF_FLOAT#

sizeof(float)

NPY_SIZEOF_DOUBLE#

sizeof(double)

NPY_SIZEOF_LONG_DOUBLE#
NPY_SIZEOF_LONGDOUBLE#

sizeof(longdouble)

NPY_SIZEOF_PY_INTPTR_T#

指针 void *intptr_t/Py_intptr_t 的大小.

NPY_SIZEOF_INTP#

此平台上 size_t 的大小(sizeof(size_t)

平台信息#

NPY_CPU_X86#
NPY_CPU_AMD64#
NPY_CPU_IA64#
NPY_CPU_PPC#
NPY_CPU_PPC64#
NPY_CPU_SPARC#
NPY_CPU_SPARC64#
NPY_CPU_S390#
NPY_CPU_PARISC#

在 1.3.0 版本加入.

平台的CPU架构;只有上述之一被定义.

定义在 numpy/npy_cpu.h

NPY_LITTLE_ENDIAN#
NPY_BIG_ENDIAN#
NPY_BYTE_ORDER#

在 1.3.0 版本加入.

GNU Libc 的 endian.h 宏的可移植替代品.如果是大端序,:c:data:NPY_BYTE_ORDER == NPY_BIG_ENDIAN,小端序架构类似.

定义在 numpy/npy_endian.h 中.

int PyArray_GetEndianness()#

在 1.3.0 版本加入.

返回当前平台的大小端序.可以是 NPY_CPU_BIGNPY_CPU_LITTLENPY_CPU_UNKNOWN_ENDIAN 之一.

NPY_CPU_BIG#
NPY_CPU_LITTLE#
NPY_CPU_UNKNOWN_ENDIAN#

编译器指令#

NPY_LIKELY#
NPY_UNLIKELY#
NPY_UNUSED#