| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 1 | .. highlightlang:: c | 
|  | 2 |  | 
|  | 3 | .. _floatobjects: | 
|  | 4 |  | 
|  | 5 | Floating Point Objects | 
|  | 6 | ---------------------- | 
|  | 7 |  | 
|  | 8 | .. index:: object: floating point | 
|  | 9 |  | 
|  | 10 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 11 | .. c:type:: PyFloatObject | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 12 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 13 | This subtype of :c:type:`PyObject` represents a Python floating point object. | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 14 |  | 
|  | 15 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 16 | .. c:var:: PyTypeObject PyFloat_Type | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 17 |  | 
|  | 18 | .. index:: single: FloatType (in modules types) | 
|  | 19 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 20 | This instance of :c:type:`PyTypeObject` represents the Python floating point | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 21 | type.  This is the same object as ``float`` and ``types.FloatType``. | 
|  | 22 |  | 
|  | 23 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 24 | .. c:function:: int PyFloat_Check(PyObject *p) | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 25 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 26 | Return true if its argument is a :c:type:`PyFloatObject` or a subtype of | 
|  | 27 | :c:type:`PyFloatObject`. | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 28 |  | 
|  | 29 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 30 | .. c:function:: int PyFloat_CheckExact(PyObject *p) | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 31 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 32 | Return true if its argument is a :c:type:`PyFloatObject`, but not a subtype of | 
|  | 33 | :c:type:`PyFloatObject`. | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 34 |  | 
|  | 35 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 36 | .. c:function:: PyObject* PyFloat_FromString(PyObject *str) | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 37 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 38 | Create a :c:type:`PyFloatObject` object based on the string value in *str*, or | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 39 | *NULL* on failure. | 
|  | 40 |  | 
|  | 41 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 42 | .. c:function:: PyObject* PyFloat_FromDouble(double v) | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 43 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 44 | Create a :c:type:`PyFloatObject` object from *v*, or *NULL* on failure. | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 45 |  | 
|  | 46 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 47 | .. c:function:: double PyFloat_AsDouble(PyObject *pyfloat) | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 48 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 49 | Return a C :c:type:`double` representation of the contents of *pyfloat*.  If | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 50 | *pyfloat* is not a Python floating point object but has a :meth:`__float__` | 
|  | 51 | method, this method will first be called to convert *pyfloat* into a float. | 
|  | 52 |  | 
|  | 53 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 54 | .. c:function:: double PyFloat_AS_DOUBLE(PyObject *pyfloat) | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 55 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 56 | Return a C :c:type:`double` representation of the contents of *pyfloat*, but | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 57 | without error checking. | 
|  | 58 |  | 
|  | 59 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 60 | .. c:function:: PyObject* PyFloat_GetInfo(void) | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 61 |  | 
|  | 62 | Return a structseq instance which contains information about the | 
|  | 63 | precision, minimum and maximum values of a float. It's a thin wrapper | 
|  | 64 | around the header file :file:`float.h`. | 
|  | 65 |  | 
|  | 66 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 67 | .. c:function:: double PyFloat_GetMax() | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 68 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 69 | Return the maximum representable finite float *DBL_MAX* as C :c:type:`double`. | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 70 |  | 
|  | 71 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 72 | .. c:function:: double PyFloat_GetMin() | 
| Georg Brandl | 54a3faa | 2008-01-20 09:30:57 +0000 | [diff] [blame] | 73 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 74 | Return the minimum normalized positive float *DBL_MIN* as C :c:type:`double`. | 
| Christian Heimes | 15ebc88 | 2008-02-04 18:48:49 +0000 | [diff] [blame] | 75 |  | 
| Georg Brandl | 60203b4 | 2010-10-06 10:11:56 +0000 | [diff] [blame^] | 76 | .. c:function:: int PyFloat_ClearFreeList() | 
| Christian Heimes | 15ebc88 | 2008-02-04 18:48:49 +0000 | [diff] [blame] | 77 |  | 
| Georg Brandl | 2ee470f | 2008-07-16 12:55:28 +0000 | [diff] [blame] | 78 | Clear the float free list. Return the number of items that could not | 
|  | 79 | be freed. |