-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfocallengthcounter.pas
64 lines (47 loc) · 1.49 KB
/
focallengthcounter.pas
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
unit focalLengthCounter;
{$mode objfpc}{$H+}
interface
uses
Classes, SysUtils;
const
//sqrt(sqr(24)+sqr(36))
//referenceDiagonal = 43.2666153056; //diagonal of 35mm full frame sensor
referenceDiagonal = sqrt(sqr(24)+sqr(36));
function diagonal(x, y: real): real; //x and y are the sizes of sensor
function cropFactor(x, y: real): real;
function focalLengthEquivalent(fl: real; cr: real): integer;
//https://en.wikipedia.org/wiki/Angle_of_view#Common_lens_angles_of_view
function horizontalFOV(width, focalLength: real): real;
function verticalFOV(height, focalLength: real): real;
function diagonalFOV(diagonal, focalLength: real): real;
implementation
function diagonal(x, y: real): real; //x and y are the sizes of sensor
begin
diagonal := Sqrt(sqr(x) + sqr(y));
//diagonal := abs(y)* sqrt(1 + sqr(x/y));
end;
function cropFactor(x, y: real): real;
var
diag: real;
begin
diag := diagonal(x, y);
cropFactor := referenceDiagonal / diag;
end; //cropFactor
function focalLengthEquivalent(fl: real; cr: real): integer;
begin
focalLengthEquivalent := round(fl * cr);
end;
function horizontalFOV(width, focalLength: real): real;
begin
horizontalFOV := (2 * ArcTan(width/(focalLength * 2))* 180 / Pi);
end;
function verticalFOV(height, focalLength: real): real;
begin
verticalFOV := (2 * ArcTan(height/(focalLength * 2))* 180 / Pi);
end;
function diagonalFOV(diagonal, focalLength: real): real;
begin
diagonalFOV := (2 * ArcTan(diagonal/(focalLength * 2))* 180 / Pi);
end;
begin
end.