Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
I
imagej-elphel
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
3
Issues
3
List
Board
Labels
Milestones
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Elphel
imagej-elphel
Commits
c5b6a7a7
Commit
c5b6a7a7
authored
6 years ago
by
Andrey Filippov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Prepareing data for rig bundle adjustment
parent
dd1befbb
master
cuda10.0
dct
foliage
gpu
lwir
lwir-distort
lwir-distort-test2
lwir16
lwir16-dbg1
orange
No related merge requests found
Changes
4
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
757 additions
and
104 deletions
+757
-104
BiQuadParameters.java
src/main/java/BiQuadParameters.java
+201
-34
GeometryCorrection.java
src/main/java/GeometryCorrection.java
+5
-0
ImageDtt.java
src/main/java/ImageDtt.java
+22
-17
TwoQuadCLT.java
src/main/java/TwoQuadCLT.java
+529
-53
No files found.
src/main/java/BiQuadParameters.java
View file @
c5b6a7a7
This diff is collapsed.
Click to expand it.
src/main/java/GeometryCorrection.java
View file @
c5b6a7a7
...
@@ -100,6 +100,11 @@ public class GeometryCorrection {
...
@@ -100,6 +100,11 @@ public class GeometryCorrection {
public
double
getDisparityRadius
()
{
public
double
getDisparityRadius
()
{
return
disparityRadius
;
return
disparityRadius
;
}
}
public
double
getBaseline
()
{
return
(
rigOffset
==
null
)?
Double
.
NaN
:
rigOffset
.
baseline
;
}
// correction of cameras mis-alignment
// correction of cameras mis-alignment
public
CorrVector
getCorrVector
(
double
[]
vector
){
public
CorrVector
getCorrVector
(
double
[]
vector
){
return
new
CorrVector
(
vector
);
return
new
CorrVector
(
vector
);
...
...
This diff is collapsed.
Click to expand it.
src/main/java/ImageDtt.java
View file @
c5b6a7a7
...
@@ -117,6 +117,7 @@ public class ImageDtt {
...
@@ -117,6 +117,7 @@ public class ImageDtt {
static
int
BI_ASTR_DIAGM_INDEX
=
21
;
//21 - strength for main diagonal pair of the aux camera
static
int
BI_ASTR_DIAGM_INDEX
=
21
;
//21 - strength for main diagonal pair of the aux camera
static
int
BI_ASTR_DIAGO_INDEX
=
22
;
//22 - strength for main diagonal pair of the aux camera
static
int
BI_ASTR_DIAGO_INDEX
=
22
;
//22 - strength for main diagonal pair of the aux camera
static
int
BI_STR_CROSS_INDEX
=
23
;
//23 - strength between the main the aux camera
static
int
BI_STR_CROSS_INDEX
=
23
;
//23 - strength between the main the aux camera
static
int
BI_TARGET_INDEX
=
24
;
//24 - target disparity
static
String
[]
BIDISPARITY_TITLES
=
{
static
String
[]
BIDISPARITY_TITLES
=
{
"disparity"
,
"disp_hor"
,
"disp_vert"
,
"disp_diagm"
,
"disp_diago"
,
"disparity"
,
"disp_hor"
,
"disp_vert"
,
"disp_diagm"
,
"disp_diago"
,
...
@@ -124,7 +125,7 @@ public class ImageDtt {
...
@@ -124,7 +125,7 @@ public class ImageDtt {
"bi-disparity"
,
"bi-disparity-dx"
,
"bi-disparity-dy"
,
"bi-disparity"
,
"bi-disparity-dx"
,
"bi-disparity-dy"
,
"strength"
,
"str_hor"
,
"str_vert"
,
"str_diagm"
,
"str_diago"
,
"strength"
,
"str_hor"
,
"str_vert"
,
"str_diagm"
,
"str_diago"
,
"astrength"
,
"astr_hor"
,
"astr_vert"
,
"astr_diagm"
,
"astr_diago"
,
"astrength"
,
"astr_hor"
,
"astr_vert"
,
"astr_diagm"
,
"astr_diago"
,
"bi-strength"
};
"bi-strength"
,
"target"
};
static
int
DISP_FULL_INDEX
=
0
;
// 0 - disparity for all directions of the main camera
static
int
DISP_FULL_INDEX
=
0
;
// 0 - disparity for all directions of the main camera
static
int
DISP_HOR_INDEX
=
1
;
// 1 - disparity for 2 horizontal pairs of the main camera
static
int
DISP_HOR_INDEX
=
1
;
// 1 - disparity for 2 horizontal pairs of the main camera
...
@@ -7572,8 +7573,9 @@ public class ImageDtt {
...
@@ -7572,8 +7573,9 @@ public class ImageDtt {
public
double
[][][][][][][]
clt_bi_quad
(
public
double
[][][][][][][]
clt_bi_quad
(
final
EyesisCorrectionParameters
.
CLTParameters
clt_parameters
,
final
EyesisCorrectionParameters
.
CLTParameters
clt_parameters
,
final
int
[][]
tile_op_main
,
// [tilesY][tilesX] - what to do - 0 - nothing for this tile
final
int
[][]
tile_op
,
// [tilesY][tilesX] - what to do - 0 - nothing for this tile
final
int
[][]
tile_op_aux
,
// [tilesY][tilesX] - what to do - 0 - nothing for this tile
// final int [][] tile_op_main, // [tilesY][tilesX] - what to do - 0 - nothing for this tile
// final int [][] tile_op_aux, // [tilesY][tilesX] - what to do - 0 - nothing for this tile
final
double
[][]
disparity_array
,
// [tilesY][tilesX] - individual per-tile expected disparity
final
double
[][]
disparity_array
,
// [tilesY][tilesX] - individual per-tile expected disparity
final
double
[][][]
image_data_main
,
// first index - number of image in a quad
final
double
[][][]
image_data_main
,
// first index - number of image in a quad
final
double
[][][]
image_data_aux
,
// first index - number of image in a quad
final
double
[][][]
image_data_aux
,
// first index - number of image in a quad
...
@@ -7772,21 +7774,21 @@ public class ImageDtt {
...
@@ -7772,21 +7774,21 @@ public class ImageDtt {
tileY
=
nTile
/
tilesX
;
tileY
=
nTile
/
tilesX
;
tileX
=
nTile
%
tilesX
;
tileX
=
nTile
%
tilesX
;
tIndex
=
tileY
*
tilesX
+
tileX
;
tIndex
=
tileY
*
tilesX
+
tileX
;
if
((
tile_op_main
[
tileY
][
tileX
]
==
0
)
&&
(
tile_op_main
[
tileY
][
tileX
]
==
0
))
continue
;
// nothing to do for this tile
if
(
tile_op
[
tileY
][
tileX
]
==
0
)
{
int
img_mask_main
=
getImgMask
(
tile_op_main
[
tileY
][
tileX
]);
// which images to use
if
(
disparity_bimap
!=
null
){
int
corr_mask_main
=
getPairMask
(
tile_op_main
[
tileY
][
tileX
]);
// which pairs to combine in the combo: 1 - top, 2 bottom, 4 - left, 8 - right
disparity_bimap
[
BI_TARGET_INDEX
][
tIndex
]
=
Double
.
NaN
;
int
img_mask_aux
=
getImgMask
(
tile_op_aux
[
tileY
][
tileX
]);
// which images to use
}
int
corr_mask_aux
=
getPairMask
(
tile_op_aux
[
tileY
][
tileX
]);
// which pairs to combine in the combo: 1 - top, 2 bottom, 4 - left, 8 - right
continue
;
// nothing to do for this tile
}
int
img_mask
=
getImgMask
(
tile_op
[
tileY
][
tileX
]);
// which images to use
int
corr_mask
=
getPairMask
(
tile_op
[
tileY
][
tileX
]);
// which pairs to combine in the combo: 1 - top, 2 bottom, 4 - left, 8 - right
// mask out pairs that use missing channels
// mask out pairs that use missing channels
// Is it currently used with diagonals?
// Is it currently used with diagonals?
// TODO: use masks from tile task
// TODO: use masks from tile task
for
(
int
i
=
0
;
i
<
corr_pairs
.
length
;
i
++){
for
(
int
i
=
0
;
i
<
corr_pairs
.
length
;
i
++){
if
((((
1
<<
corr_pairs
[
i
][
0
])
&
img_mask_main
)
==
0
)
||
(((
1
<<
corr_pairs
[
i
][
1
])
&
img_mask_main
)
==
0
))
{
if
((((
1
<<
corr_pairs
[
i
][
0
])
&
img_mask
)
==
0
)
||
(((
1
<<
corr_pairs
[
i
][
1
])
&
img_mask
)
==
0
))
{
corr_mask_main
&=
~
(
1
<<
i
);
corr_mask
&=
~
(
1
<<
i
);
}
if
((((
1
<<
corr_pairs
[
i
][
0
])
&
img_mask_aux
)
==
0
)
||
(((
1
<<
corr_pairs
[
i
][
1
])
&
img_mask_aux
)
==
0
))
{
corr_mask_aux
&=
~
(
1
<<
i
);
}
}
}
}
// boolean debugTile =(tileX == debug_tileX) && (tileY == debug_tileY);
// boolean debugTile =(tileX == debug_tileX) && (tileY == debug_tileY);
...
@@ -7802,6 +7804,9 @@ public class ImageDtt {
...
@@ -7802,6 +7804,9 @@ public class ImageDtt {
double
[][]
centersXY_aux
;
double
[][]
centersXY_aux
;
double
disparity_main
=
disparity_array
[
tileY
][
tileX
];
double
disparity_main
=
disparity_array
[
tileY
][
tileX
];
double
disparity_aux
=
disparity_main
*
geometryCorrection_aux
.
getDisparityRadius
()/
geometryCorrection_main
.
getDisparityRadius
();
double
disparity_aux
=
disparity_main
*
geometryCorrection_aux
.
getDisparityRadius
()/
geometryCorrection_main
.
getDisparityRadius
();
if
(
disparity_bimap
!=
null
){
disparity_bimap
[
BI_TARGET_INDEX
][
tIndex
]
=
disparity_main
;
}
centersXY_main
=
geometryCorrection_main
.
getPortsCoordinatesAndDerivatives
(
centersXY_main
=
geometryCorrection_main
.
getPortsCoordinatesAndDerivatives
(
false
,
// boolean use_rig_offsets,
false
,
// boolean use_rig_offsets,
corr_rots_main
,
// Matrix [] rots,
corr_rots_main
,
// Matrix [] rots,
...
@@ -8058,8 +8063,8 @@ public class ImageDtt {
...
@@ -8058,8 +8063,8 @@ public class ImageDtt {
extra_disparity_main
,
// final double extra_disparity,
extra_disparity_main
,
// final double extra_disparity,
quad_main
,
// final int quad, // number of subcameras
quad_main
,
// final int quad, // number of subcameras
numcol
,
// final int numcol, // number of colors
numcol
,
// final int numcol, // number of colors
img_mask_main
,
// int img_mask,
img_mask
,
//
_main, // int img_mask,
tile_op_main
,
// final int [][] tile_op, // [tilesY][tilesX] - what to do - 0 - nothing for this tile
tile_op
,
//
_main, // final int [][] tile_op, // [tilesY][tilesX] - what to do - 0 - nothing for this tile
clt_data_main
,
// final double [][][][] clt_data,
clt_data_main
,
// final double [][][][] clt_data,
texture_tiles_main
,
// final double [][][][] texture_tiles, // [tilesY][tilesX]["RGBA".length()][]; null - will skip images combining
texture_tiles_main
,
// final double [][][][] texture_tiles, // [tilesY][tilesX]["RGBA".length()][]; null - will skip images combining
filter
,
// final double [] filter,
filter
,
// final double [] filter,
...
@@ -8077,8 +8082,8 @@ public class ImageDtt {
...
@@ -8077,8 +8082,8 @@ public class ImageDtt {
extra_disparity_aux
,
// final double extra_disparity,
extra_disparity_aux
,
// final double extra_disparity,
quad_aux
,
// final int quad, // number of subcameras
quad_aux
,
// final int quad, // number of subcameras
numcol
,
// final int numcol, // number of colors
numcol
,
// final int numcol, // number of colors
img_mask_aux
,
// int img_mask,
img_mask
,
//
_aux, // int img_mask,
tile_op_aux
,
// final int [][] tile_op, // [tilesY][tilesX] - what to do - 0 - nothing for this tile
tile_op
,
//
_aux, // final int [][] tile_op, // [tilesY][tilesX] - what to do - 0 - nothing for this tile
clt_data_aux
,
// final double [][][][] clt_data,
clt_data_aux
,
// final double [][][][] clt_data,
texture_tiles_aux
,
// final double [][][][] texture_tiles, // [tilesY][tilesX]["RGBA".length()][]; null - will skip images combining
texture_tiles_aux
,
// final double [][][][] texture_tiles, // [tilesY][tilesX]["RGBA".length()][]; null - will skip images combining
filter
,
// final double [] filter,
filter
,
// final double [] filter,
...
...
This diff is collapsed.
Click to expand it.
src/main/java/TwoQuadCLT.java
View file @
c5b6a7a7
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment