~oif-team/ubuntu/natty/qt4-x11/xi2.1

« back to all changes in this revision

Viewing changes to src/corelib/kernel/qmath.h

  • Committer: Bazaar Package Importer
  • Author(s): Alessandro Ghersi
  • Date: 2009-11-02 18:30:08 UTC
  • mfrom: (1.2.2 upstream)
  • mto: (15.2.5 experimental)
  • mto: This revision was merged to the branch mainline in revision 88.
  • Revision ID: james.westby@ubuntu.com-20091102183008-b6a4gcs128mvfb3m
Tags: upstream-4.6.0~beta1
ImportĀ upstreamĀ versionĀ 4.6.0~beta1

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/****************************************************************************
2
2
**
3
3
** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
 
4
** All rights reserved.
4
5
** Contact: Nokia Corporation (qt-info@nokia.com)
5
6
**
6
7
** This file is part of the QtCore module of the Qt Toolkit.
7
8
**
8
9
** $QT_BEGIN_LICENSE:LGPL$
9
 
** Commercial Usage
10
 
** Licensees holding valid Qt Commercial licenses may use this file in
11
 
** accordance with the Qt Commercial License Agreement provided with the
12
 
** Software or, alternatively, in accordance with the terms contained in
13
 
** a written agreement between you and Nokia.
 
10
** No Commercial Usage
 
11
** This file contains pre-release code and may not be distributed.
 
12
** You may use this file in accordance with the terms and conditions
 
13
** contained in the Technology Preview License Agreement accompanying
 
14
** this package.
14
15
**
15
16
** GNU Lesser General Public License Usage
16
17
** Alternatively, this file may be used under the terms of the GNU Lesser
20
21
** ensure the GNU Lesser General Public License version 2.1 requirements
21
22
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22
23
**
23
 
** In addition, as a special exception, Nokia gives you certain
24
 
** additional rights. These rights are described in the Nokia Qt LGPL
25
 
** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26
 
** package.
27
 
**
28
 
** GNU General Public License Usage
29
 
** Alternatively, this file may be used under the terms of the GNU
30
 
** General Public License version 3.0 as published by the Free Software
31
 
** Foundation and appearing in the file LICENSE.GPL included in the
32
 
** packaging of this file.  Please review the following information to
33
 
** ensure the GNU General Public License version 3.0 requirements will be
34
 
** met: http://www.gnu.org/copyleft/gpl.html.
35
 
**
36
 
** If you are unsure which license is appropriate for your use, please
37
 
** contact the sales department at http://www.qtsoftware.com/contact.
 
24
** In addition, as a special exception, Nokia gives you certain additional
 
25
** rights.  These rights are described in the Nokia Qt LGPL Exception
 
26
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
 
27
**
 
28
** If you have questions regarding the use of this file, please contact
 
29
** Nokia at qt-info@nokia.com.
 
30
**
 
31
**
 
32
**
 
33
**
 
34
**
 
35
**
 
36
**
 
37
**
38
38
** $QT_END_LICENSE$
39
39
**
40
40
****************************************************************************/
52
52
 
53
53
QT_MODULE(Core)
54
54
 
 
55
#define QT_SINE_TABLE_SIZE 256
 
56
 
 
57
extern Q_CORE_EXPORT const qreal qt_sine_table[QT_SINE_TABLE_SIZE];
 
58
 
55
59
inline int qCeil(qreal v)
56
60
{
57
61
#ifdef QT_USE_MATH_H_FLOATS
58
62
    if (sizeof(qreal) == sizeof(float))
59
 
        return int(ceilf(v));
 
63
        return int(ceilf(float(v)));
60
64
    else
61
65
#endif
62
66
        return int(ceil(v));
66
70
{
67
71
#ifdef QT_USE_MATH_H_FLOATS
68
72
    if (sizeof(qreal) == sizeof(float))
69
 
        return int(floorf(v));
 
73
        return int(floorf(float(v)));
70
74
    else
71
75
#endif
72
76
        return int(floor(v));
76
80
{
77
81
#ifdef QT_USE_MATH_H_FLOATS
78
82
    if (sizeof(qreal) == sizeof(float))
79
 
        return sinf(v);
 
83
        return sinf(float(v));
80
84
    else
81
85
#endif
82
86
        return sin(v);
86
90
{
87
91
#ifdef QT_USE_MATH_H_FLOATS
88
92
    if (sizeof(qreal) == sizeof(float))
89
 
        return cosf(v);
 
93
        return cosf(float(v));
90
94
    else
91
95
#endif
92
96
        return cos(v);
96
100
{
97
101
#ifdef QT_USE_MATH_H_FLOATS
98
102
    if (sizeof(qreal) == sizeof(float))
99
 
        return acosf(v);
 
103
        return acosf(float(v));
100
104
    else
101
105
#endif
102
106
        return acos(v);
106
110
{
107
111
#ifdef QT_USE_MATH_H_FLOATS
108
112
    if (sizeof(qreal) == sizeof(float))
109
 
        return sqrtf(v);
 
113
        return sqrtf(float(v));
110
114
    else
111
115
#endif
112
116
        return sqrt(v);
116
120
{
117
121
#ifdef QT_USE_MATH_H_FLOATS
118
122
    if (sizeof(qreal) == sizeof(float))
119
 
        return logf(v);
 
123
        return logf(float(v));
120
124
    else
121
125
#endif
122
126
        return log(v);
126
130
{
127
131
#ifdef QT_USE_MATH_H_FLOATS
128
132
    if (sizeof(qreal) == sizeof(float))
129
 
        return powf(x, y);
 
133
        return powf(float(x), float(y));
130
134
    else
131
135
#endif
132
136
        return pow(x, y);
133
137
}
134
138
 
 
139
#ifndef M_PI
 
140
#define M_PI (3.14159265358979323846)
 
141
#endif
 
142
 
 
143
inline qreal qFastSin(qreal x)
 
144
{
 
145
    int si = int(x * (0.5 * QT_SINE_TABLE_SIZE / M_PI)); // Would be more accurate with qRound, but slower.
 
146
    qreal d = x - si * (2.0 * M_PI / QT_SINE_TABLE_SIZE);
 
147
    int ci = si + QT_SINE_TABLE_SIZE / 4;
 
148
    si &= QT_SINE_TABLE_SIZE - 1;
 
149
    ci &= QT_SINE_TABLE_SIZE - 1;
 
150
    return qt_sine_table[si] + (qt_sine_table[ci] - 0.5 * qt_sine_table[si] * d) * d;
 
151
}
 
152
 
 
153
inline qreal qFastCos(qreal x)
 
154
{
 
155
    int ci = int(x * (0.5 * QT_SINE_TABLE_SIZE / M_PI)); // Would be more accurate with qRound, but slower.
 
156
    qreal d = x - ci * (2.0 * M_PI / QT_SINE_TABLE_SIZE);
 
157
    int si = ci + QT_SINE_TABLE_SIZE / 4;
 
158
    si &= QT_SINE_TABLE_SIZE - 1;
 
159
    ci &= QT_SINE_TABLE_SIZE - 1;
 
160
    return qt_sine_table[si] - (qt_sine_table[ci] + 0.5 * qt_sine_table[si] * d) * d;
 
161
}
 
162
 
135
163
QT_END_NAMESPACE
136
164
 
137
165
QT_END_HEADER