1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
(*
* Rational numbers
* Copyright (c) 2003 Michael Niedermayer <michaelni@gmx.at>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*)
(* This is a part of Pascal porting of ffmpeg. Originally by Victor Zinetz for Delphi and Free Pascal on Windows.
For Mac OS X, some modifications were made by The Creative CAT, denoted as CAT
in the source codes *)
unit rational;
{$MODE DELPHI} (* CAT *)
{$PACKENUM 4} (* every enum type variables uses 4 bytes, CAT *)
{$PACKRECORDS C} (* GCC compatible, Record Packing, CAT *)
interface (* unit windows is deleted by CAT *)
const
(* version numbers are changed by The Creative CAT *)
av__util = 'libavutil.49';
type
(*
* Rational number num/den. *)
PAVRational = ^TAVRational;
TAVRational = record
num: integer; ///< numerator
den: integer; ///< denominator
end;
(**
* returns 0 if a==b, 1 if a>b and -1 if a<b.
*)
function av_cmp_q(a: TAVRational; b: TAVRational): integer;
(**
* converts the given AVRational to a double.
*)
function av_q2d(a: TAVRational): double;
(**
* reduce a fraction.
* this is usefull for framerate calculations
* @param max the maximum allowed for dst_nom & dst_den
* @return 1 if exact, 0 otherwise
*)
function av_reduce(dst_nom: pinteger; dst_den: PInteger; nom: int64; den: int64; max: int64): integer;
cdecl; external av__util;
function av_mul_q(b: TAVRational; c: TAVRational): TAVRational;
cdecl; external av__util;
function av_div_q(b: TAVRational; c: TAVRational): TAVRational;
cdecl; external av__util;
function av_add_q(b: TAVRational; c: TAVRational): TAVRational;
cdecl; external av__util;
function av_sub_q(b: TAVRational; c: TAVRational): TAVRational;
cdecl; external av__util;
function av_d2q(d: double; max: integer): TAVRational;
cdecl; external av__util;
implementation
function av_cmp_q (a: TAVRational; b: TAVRational): integer;
var
tmp: int64;
begin
tmp := a.num * b.den - b.num * a.den;
if tmp <> 0 then Result := (tmp shr 63) or 1 (* fixed by CAT *)
else Result := 0
end;
function av_q2d(a: TAVRational): double;
begin
Result := a.num / a.den;
end;
end.
|