hugin-devs team mailing list archive
-
hugin-devs team
-
Mailing list archive
-
Message #07431
[Bug 1856336] Re: Running geometric optimizer changes displayed focal length
"The displayed focal length is calculated from the field of view" - this
requires elaboration.
The fundamental geometrical optics formula states (assuming infinitely
thin lens) :
1/distance_to_object + 1/distance_to_sensor = 1/focal_length
.
And we also have hyperfocal distance:
https://en.wikipedia.org/wiki/Hyperfocal_distance .
It's a mirror camera - not a rangefinder (
https://en.wikipedia.org/wiki/Rangefinder_camera ) one.
So, IMO, distance_to_object is firmly not known - even though the camera
can know and report distance_to_sensor.
If distance_to_object is not known, how can focal_length be then
calculated ?
And even if there is a way to calculate focal distance, then it's a bug
in UI - the UI should clearly separate reported by camera focal distance
and calculated one.
...
I restarted 'hugin' and using the same input data and
Geometric: Positions and view (y,p,r,v) I get focal length 21.315mm -
which is different from the above 22.982mm.
Then I quit 'hugin', restarted it again, and again using the same input
data and the same
Geometric: Positions and view (y,p,r,v) I get focal length 21.313mm -
which is different from the above 21.315mm.
So, all in all, looks like a functional (not UI) bug to me - for some
reasons the results are unrepeatable.
...
I know it looks like a can of worms.
--
You received this bug notification because you are a member of Hugin
Developers, which is subscribed to Hugin.
https://bugs.launchpad.net/bugs/1856336
Title:
Running geometric optimizer changes displayed focal length
Status in Hugin:
Opinion
Bug description:
I am a new 'hugin' user and I've been playing with it for about a week
encountering various problems. I hope I've managed to make some
systematization of the problems, so this report is the first in a
series of reports I'm going to file.
System info as hugin reports it:
"
Operating System: Linux 4.15.0-72-generic x86_64
Architecture: 64 bit
Free memory: 2055068 kiB
Hugin
Version: 2019.0.0.a369cbe55179
Path to resources: /usr/share/hugin/xrc/
Path to data: /usr/share/hugin/data/
Hugins camera and lens database: /home/sergei/.hugindata/camlens.db
Multi-threading using C++11 std::thread and OpenMP
Libraries
wxWidgets: wxWidgets 3.0.4
wxWidgets Library (wxGTK port)
Version 3.0.4 (Unicode: wchar_t, debug level: 1),
Runtime version of toolkit used is 2.24.
Compile-time GTK+ version is 2.24.32.
libpano13: 2.9.19
Boost: 1.65.1
Exiv2: 0.25.0
SQLite3: 3.22.0
Vigra: 1.11.0
LittleCMS2: 2.9
".
Location of input images: https://cloud.mail.ru/public/HmmR/35U75uuiB/
. Input images are DSC_0849.NEF .. DSC_0856.NEF files, i.e. 8 images
altogether. If you want to download any file from the the URL, right-
click on the file, and a drop-down menu with the following items in
Russian will appear:
Открыть в новой вкладке
Скачать
Сохранить в Облако
.
Select the second item, i.e. Скачать (which means Download), and the
regular browser download window will appear.
To reproduce the problem first import into 'hugin' input .NEF files
the usual way using the "Photos" tab. Have a look at
'correct_focal_length.png' file in the above web folder for
assistance.
I chose RawTherapee version 5.7 to import files into 'hugin', and the
profile file for RawTherapee is
'/usr/share/rawtherapee/profiles/Unclipped.pp3' (it comes with
RawTherapee). Just in case contents of the file:
"
[Exposure]
ClampOOG=false
Curve=0;
Curve2=0;
[Black & White]
BeforeCurve=0;
AfterCurve=0;
[Vibrance]
Enabled=false
[Color appearance]
Enabled=false
[Film Simulation]
Enabled=false
[RGB Curves]
LumaMode=false
[Color Management]
ApplyLookTable=false
[RAW]
CA=true
CAAutoIterations=2
".
As the files are imported into hugin and the list of .tif files
produced from the input .NEF files appears, click on any of the .tif
files - as one can see in 'correct_focal_length.png' file
'DSC_0849.tif' file is selected, and it is also the default anchor
file for both position and exposure. As a result of clicking on input
.tif file lens focal distance and crop factor are displayed - which in
this case are 18mm and 1.5 (again, see the 'correct_focal_length.png'
file) . The numbers are correct - I indeed set the zoom to 18mm and
the camera crop factor is 1.5 . I assume 'hugin' grabs this info from
the .NEF files as it should. In this case all input files have the
same focal length.
After importing input files I went to the "Feature making" part of the
GUI and detected control points fully automatically - see the
'correct_focal_length.png' file for details.
After detecting control points I went to the "Optimize" part of the
GUI and ran geometric optimizer - see the 'correct_focal_length.png'
file for details.
When geometric optimizer finished its work a window with its report
appeared, and I clicked OK. As a result of it displayed focal length
in the GUI changed to 22.982mm and the crop factor field became empty
- see 'wrong_focal_length.png' file for details in the above web
folder.
It should be noted that the 22.982 is about 23, and the keyword here
is "about". With the same set of input images the number changes
slightly from invoking to invoking - for example, I remember 23.001,
22.999, etc.
IMO such behavior is wrong - input focal length either comes from the
raw file, or from user input - it shouldn't be changed by 'hugin'.
Such behavior might indicate usage of uninitialized data or freed
memory or index overrun, etc. If I understand correctly how overall
'hugin' works, focal length is used to calculate view angle, so wrong
focal length can cause calculation of wrong view angles and thus lead
to wrong stitching.
To manage notifications about this bug go to:
https://bugs.launchpad.net/hugin/+bug/1856336/+subscriptions
References