1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
23 #include <tools/solar.h>
28 // allowed range 0..14, must be even
31 // scale for ...Big() -Functions
34 #define FIX_P3 (FIX_POST-FIX_P2)
37 #define FIX_P3 FIX_POST
41 #define FIX_ADD (1<<(FIX_POST-1))
47 #define FIX_A2 (1<<(FIX_P2-1))
53 #define FIX_A3 (1<<(FIX_P3-1))
72 Fix( int i
) { x
=(long(i
)<<FIX_POST
); }
73 Fix( short l
) { x
=(long(l
)<<FIX_POST
); }
74 Fix( sal_uInt16 l
) { x
=(long(l
)<<FIX_POST
); }
75 Fix( long l
) { x
=(l
<<FIX_POST
); }
76 Fix( long Z
, long N
) { x
=(Z
<<FIX_POST
)/N
; }
78 void SetInternVal( long nVal
) { x
=nVal
; }
79 long GetInternVal() const { return x
; }
81 void operator+= ( const Fix
& a
) { x
+=a
.x
; }
82 void operator-= ( const Fix
& a
) { x
-=a
.x
; }
83 void operator*= ( const Fix
& a
) { x
=(x
*a
.x
+FIX_ADD
)>>FIX_POST
; }
84 void operator/= ( const Fix
& a
) { x
=(x
<<FIX_POST
)/a
.x
; }
85 friend Fix
operator- ( const Fix
& a
);
87 void MultBig( const Fix
& a
)
88 { x
=((((a
.x
+FIX_A2
)>>FIX_P2
)*x
+FIX_A3
)>>FIX_P3
); }
89 void DivBig( const Fix
& a
)
90 { x
=((x
<<FIX_P3
)/a
.x
)<<FIX_P2
; }
92 friend sal_Bool
operator> ( const Fix
& a
, const Fix
& b
) { return a
.x
> b
.x
; }
93 friend sal_Bool
operator< ( const Fix
& a
, const Fix
& b
) { return a
.x
< b
.x
; }
95 operator long() const { return (x
+FIX_ADD
) >> FIX_POST
; }
96 operator double() const { return double(x
)/(1<<FIX_POST
); }
98 friend Fix
operator+ ( const Fix
& a
, const Fix
& b
);
99 friend Fix
operator- ( const Fix
& a
, const Fix
& b
);
100 friend Fix
operator* ( const Fix
& a
, const Fix
& b
);
101 friend Fix
operator/ ( const Fix
& a
, const Fix
& b
);
103 friend FixCpx
operator-( const FixCpx
& a
);
117 FixCpx() : r(), i() {}
118 FixCpx( Fix a
) : r( a
), i() {}
119 FixCpx( Fix a
, Fix b
) : r( a
), i( b
) {}
121 Fix
& GetReal() { return r
; }
122 Fix
& GetImag() { return i
; }
124 void operator*= ( const FixCpx
& ra
);
125 void MultBig( const FixCpx
& ra
, const FixCpx
& rb
);
127 friend FixCpx
operator+ ( const FixCpx
& a
, const FixCpx
& b
);
128 friend FixCpx
operator- ( const FixCpx
& a
, const FixCpx
& b
);
129 friend FixCpx
operator* ( const FixCpx
& a
, const FixCpx
& b
);
130 friend FixCpx
operator/ ( const FixCpx
& a
, const FixCpx
& b
);
131 friend FixCpx
operator- ( const FixCpx
& a
);
134 inline Fix
operator- ( const Fix
& a
)
141 inline Fix
operator+ ( const Fix
& a
, const Fix
& b
)
147 inline Fix
operator- ( const Fix
& a
, const Fix
& b
)
153 inline Fix
operator* ( const Fix
& a
, const Fix
& b
)
155 long l
=(a
.x
*b
.x
+FIX_ADD
)>>FIX_POST
;
159 inline Fix
operator/ ( const Fix
& a
, const Fix
& b
)
161 long l
=(a
.x
<<FIX_POST
)/b
.x
;
165 inline FixCpx
operator- ( const FixCpx
& a
)
174 inline FixCpx
operator+ ( const FixCpx
& a
, const FixCpx
& b
)
176 return FixCpx( a
.r
+b
.r
, a
.i
+b
.i
);
179 inline FixCpx
operator- ( const FixCpx
& a
, const FixCpx
& b
)
181 return FixCpx( a
.r
-b
.r
, a
.i
-b
.i
);
184 inline void FixCpx::operator*= ( const FixCpx
& ra
)
186 Fix rr
= ra
.r
*r
-ra
.i
*i
;
191 inline FixCpx
operator* ( const FixCpx
& a
, const FixCpx
& b
)
193 return FixCpx( a
.r
*b
.r
-a
.i
*b
.i
, a
.r
*b
.i
+a
.i
*b
.r
);
196 inline FixCpx
operator/ ( const FixCpx
& a
, const FixCpx
& b
)
198 return FixCpx( (a
.r
*b
.r
+a
.i
*b
.i
)/(b
.r
*b
.r
+b
.i
*b
.i
),
199 (b
.r
*a
.r
-a
.r
*b
.i
)/(b
.r
*b
.r
+b
.i
*b
.i
) );
202 // -----------------------------------------------------------------------
204 Fix
ImpMultBig2( const Fix
& a
, const Fix
& b
);
206 sal_uInt16
ImpSqrt( sal_uLong nRadi
);
207 FixCpx
ImpExPI( sal_uInt16 nPhi
);
209 #endif // _MCVMATH_HXX
211 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */