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
0349faa4
Commit
0349faa4
authored
Aug 12, 2022
by
Andrey Filippov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed MB correction for very small blurs, added thin wire over sky to
sky detection
parent
256632ef
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
141 additions
and
44 deletions
+141
-44
GpuQuad.java
src/main/java/com/elphel/imagej/gpu/GpuQuad.java
+28
-14
IntersceneMatchParameters.java
...lphel/imagej/tileprocessor/IntersceneMatchParameters.java
+37
-8
OpticalFlow.java
...ain/java/com/elphel/imagej/tileprocessor/OpticalFlow.java
+25
-4
QuadCLTCPU.java
...main/java/com/elphel/imagej/tileprocessor/QuadCLTCPU.java
+51
-18
No files found.
src/main/java/com/elphel/imagej/gpu/GpuQuad.java
View file @
0349faa4
...
@@ -3822,6 +3822,8 @@ public class GpuQuad{ // quad camera description
...
@@ -3822,6 +3822,8 @@ public class GpuQuad{ // quad camera description
final
boolean
[]
valid_tiles
,
final
boolean
[]
valid_tiles
,
final
int
threadsMax
)
// maximal number of threads to launch
final
int
threadsMax
)
// maximal number of threads to launch
{
{
final
double
min_sub
=
1
e
-
12
;
final
double
min_len
=
0.1
;
// pix
int
num_pairs
=
Correlation2d
.
getNumPairs
(
num_cams
);
int
num_pairs
=
Correlation2d
.
getNumPairs
(
num_cams
);
//change to fixed 511?
//change to fixed 511?
final
int
task_code
=
((
1
<<
num_pairs
)-
1
)
<<
GPUTileProcessor
.
TASK_CORR_BITS
;
// correlation only
final
int
task_code
=
((
1
<<
num_pairs
)-
1
)
<<
GPUTileProcessor
.
TASK_CORR_BITS
;
// correlation only
...
@@ -3875,6 +3877,14 @@ public class GpuQuad{ // quad camera description
...
@@ -3875,6 +3877,14 @@ public class GpuQuad{ // quad camera description
dx
/=
mb_len
;
// unit vector
dx
/=
mb_len
;
// unit vector
dy
/=
mb_len
;
dy
/=
mb_len
;
mb_len
*=
mb_tau
;
// now in pixels
mb_len
*=
mb_tau
;
// now in pixels
/*
double [] centerXY_sub = centerXY;
if (mb_len < min_len) {
tp_task.setScale(1.0);
tp_task_sub.task = 0; // disable
tp_task.setScale(-min_sub);
} else {
*/
double
mb_offs
=
1.0
;
// try 1 pixel. Maybe adjust for non-ortho, e.g. sqrt(2) for diagonal?
double
mb_offs
=
1.0
;
// try 1 pixel. Maybe adjust for non-ortho, e.g. sqrt(2) for diagonal?
double
min_offs
=
mb_len_scale
*
mb_len
;
double
min_offs
=
mb_len_scale
*
mb_len
;
if
(
mb_offs
<
min_offs
)
{
if
(
mb_offs
<
min_offs
)
{
...
@@ -3882,13 +3892,17 @@ public class GpuQuad{ // quad camera description
...
@@ -3882,13 +3892,17 @@ public class GpuQuad{ // quad camera description
}
}
dx
*=
mb_offs
;
dx
*=
mb_offs
;
dy
*=
mb_offs
;
dy
*=
mb_offs
;
double
[]
centerXY_sub
=
{
centerXY
[
0
]+
dx
,
centerXY
[
1
]+
dy
};
double
[]
centerXY_sub
=
new
double
[]
{
centerXY
[
0
]+
dx
,
centerXY
[
1
]+
dy
};
tp_task_sub
.
setCenterXY
(
centerXY_sub
);
tp_task_sub
.
setCenterXY
(
centerXY_sub
);
double
exp_offs
=
Math
.
exp
(-
mb_offs
/
mb_len
);
double
exp_offs
=
Math
.
exp
(-
mb_offs
/
mb_len
);
double
gain
=
1.0
/(
1.0
-
exp_offs
);
double
gain
=
1.0
/(
1.0
-
exp_offs
);
double
gain_sub
=
-
gain
*
exp_offs
;
double
gain_sub
=
-
gain
*
exp_offs
;
if
(
gain_sub
>
-
min_sub
)
{
gain_sub
=
-
min_sub
;
}
tp_task
.
setScale
(
gain
);
tp_task
.
setScale
(
gain
);
tp_task_sub
.
setScale
(
gain_sub
);
tp_task_sub
.
setScale
(
gain_sub
);
// }
boolean
bad_margins
=
false
;
boolean
bad_margins
=
false
;
if
(
calcPortsCoordinatesAndDerivatives
)
{
// for non-GPU?
if
(
calcPortsCoordinatesAndDerivatives
)
{
// for non-GPU?
double
[][]
disp_dist
=
new
double
[
quad_main
][];
// used to correct 3D correlations (not yet used here)
double
[][]
disp_dist
=
new
double
[
quad_main
][];
// used to correct 3D correlations (not yet used here)
...
...
src/main/java/com/elphel/imagej/tileprocessor/IntersceneMatchParameters.java
View file @
0349faa4
...
@@ -152,6 +152,12 @@ public class IntersceneMatchParameters {
...
@@ -152,6 +152,12 @@ public class IntersceneMatchParameters {
public
double
sky_bottom_override
=
-
300
;
// maximal average sky value to override lowest_sky_row test
public
double
sky_bottom_override
=
-
300
;
// maximal average sky value to override lowest_sky_row test
public
int
sky_override_shrink
=
10
;
// shrink detected sky before finding hottest tile there
public
int
sky_override_shrink
=
10
;
// shrink detected sky before finding hottest tile there
// Increase fom if there are enough LMA-defined similar tiles around
public
double
disp_boost_min
=
0.5
;
public
double
disp_boost_diff
=
0.35
;
public
int
disp_boost_neibs
=
2
;
public
double
disp_boost_amount
=
2.0
;
// Some "AGC" to adjust how much to discard
// Some "AGC" to adjust how much to discard
public
int
margin
=
1
;
// do not use tiles if their centers are closer to the image edge
public
int
margin
=
1
;
// do not use tiles if their centers are closer to the image edge
...
@@ -545,15 +551,18 @@ public class IntersceneMatchParameters {
...
@@ -545,15 +551,18 @@ public class IntersceneMatchParameters {
gd
.
addNumericField
(
"Hottest sky tile to override lowest row"
,
this
.
sky_bottom_override
,
5
,
7
,
""
,
gd
.
addNumericField
(
"Hottest sky tile to override lowest row"
,
this
.
sky_bottom_override
,
5
,
7
,
""
,
"If the detected sky is all cold enough, bypass lowest row test, allow to raise camera."
);
"If the detected sky is all cold enough, bypass lowest row test, allow to raise camera."
);
gd
.
addNumericField
(
"Shrink before finding hottest sky"
,
this
.
sky_override_shrink
,
0
,
3
,
""
,
gd
.
addNumericField
(
"Shrink before finding hottest sky"
,
this
.
sky_override_shrink
,
0
,
3
,
""
,
"Shrink detected sky before looking for the hottest skyt tile (blurred skyline in wet atmosphere)."
);
"Shrink detected sky before looking for the hottest sky tile (blurred skyline in wet atmosphere)."
);
gd
.
addMessage
(
"Boost FOM if there are enough LMA-defined good neighbors around (Thin wires over the sky)"
);
gd
.
addNumericField
(
"Minimal disparity"
,
this
.
disp_boost_min
,
5
,
7
,
"pix"
,
"Minimal LMA-defined disparity to boost FOM."
);
gd
.
addNumericField
(
"Disparity difference"
,
this
.
disp_boost_diff
,
5
,
7
,
"pix"
,
"Maximal disparity difference to neighbor to count."
);
gd
.
addNumericField
(
"Number of good neighbors"
,
this
.
disp_boost_neibs
,
0
,
3
,
""
,
"Number of neighbors (of 8) to have small disparity difference to boost FOM."
);
gd
.
addNumericField
(
"Boost amount"
,
this
.
disp_boost_amount
,
5
,
7
,
"x"
,
"Multiply FOM by this value if number of neighbors is exactly minimal. Sacale proportional to the total number of neighbors."
);
gd
.
addTab
(
"Inter-Match"
,
"Parameters for full-resolution scene matching"
);
gd
.
addTab
(
"Inter-Match"
,
"Parameters for full-resolution scene matching"
);
// gd.addTab("Interscene Equalization","Equalization of the interscene correlation confidence to improve camera X,Y,Z matching");
gd
.
addMessage
(
"Interscene match parameters"
);
gd
.
addMessage
(
"Interscene match parameters"
);
...
@@ -931,6 +940,11 @@ public class IntersceneMatchParameters {
...
@@ -931,6 +940,11 @@ public class IntersceneMatchParameters {
this
.
sky_bottom_override
=
gd
.
getNextNumber
();
this
.
sky_bottom_override
=
gd
.
getNextNumber
();
this
.
sky_override_shrink
=(
int
)
gd
.
getNextNumber
();
this
.
sky_override_shrink
=(
int
)
gd
.
getNextNumber
();
this
.
disp_boost_min
=
gd
.
getNextNumber
();
this
.
disp_boost_diff
=
gd
.
getNextNumber
();
this
.
disp_boost_neibs
=
(
int
)
gd
.
getNextNumber
();
this
.
disp_boost_amount
=
gd
.
getNextNumber
();
this
.
margin
=
(
int
)
gd
.
getNextNumber
();
this
.
margin
=
(
int
)
gd
.
getNextNumber
();
this
.
sensor_mask_inter
=
(
int
)
gd
.
getNextNumber
();
this
.
sensor_mask_inter
=
(
int
)
gd
.
getNextNumber
();
this
.
use_partial
=
gd
.
getNextBoolean
();
this
.
use_partial
=
gd
.
getNextBoolean
();
...
@@ -1206,6 +1220,11 @@ public class IntersceneMatchParameters {
...
@@ -1206,6 +1220,11 @@ public class IntersceneMatchParameters {
properties
.
setProperty
(
prefix
+
"sky_bottom_override"
,
this
.
sky_bottom_override
+
""
);
// double
properties
.
setProperty
(
prefix
+
"sky_bottom_override"
,
this
.
sky_bottom_override
+
""
);
// double
properties
.
setProperty
(
prefix
+
"sky_override_shrink"
,
this
.
sky_override_shrink
+
""
);
// int
properties
.
setProperty
(
prefix
+
"sky_override_shrink"
,
this
.
sky_override_shrink
+
""
);
// int
properties
.
setProperty
(
prefix
+
"disp_boost_min"
,
this
.
disp_boost_min
+
""
);
// double
properties
.
setProperty
(
prefix
+
"disp_boost_diff"
,
this
.
disp_boost_diff
+
""
);
// int
properties
.
setProperty
(
prefix
+
"disp_boost_neibs"
,
this
.
disp_boost_neibs
+
""
);
// double
properties
.
setProperty
(
prefix
+
"disp_boost_amount"
,
this
.
disp_boost_amount
+
""
);
// double
properties
.
setProperty
(
prefix
+
"margin"
,
this
.
margin
+
""
);
// int
properties
.
setProperty
(
prefix
+
"margin"
,
this
.
margin
+
""
);
// int
properties
.
setProperty
(
prefix
+
"sensor_mask_inter"
,
this
.
sensor_mask_inter
+
""
);
// int
properties
.
setProperty
(
prefix
+
"sensor_mask_inter"
,
this
.
sensor_mask_inter
+
""
);
// int
properties
.
setProperty
(
prefix
+
"use_partial"
,
this
.
use_partial
+
""
);
// boolean
properties
.
setProperty
(
prefix
+
"use_partial"
,
this
.
use_partial
+
""
);
// boolean
...
@@ -1434,6 +1453,11 @@ public class IntersceneMatchParameters {
...
@@ -1434,6 +1453,11 @@ public class IntersceneMatchParameters {
if
(
properties
.
getProperty
(
prefix
+
"sky_bottom_override"
)!=
null
)
this
.
sky_bottom_override
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"sky_bottom_override"
));
if
(
properties
.
getProperty
(
prefix
+
"sky_bottom_override"
)!=
null
)
this
.
sky_bottom_override
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"sky_bottom_override"
));
if
(
properties
.
getProperty
(
prefix
+
"sky_override_shrink"
)!=
null
)
this
.
sky_override_shrink
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"sky_override_shrink"
));
if
(
properties
.
getProperty
(
prefix
+
"sky_override_shrink"
)!=
null
)
this
.
sky_override_shrink
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"sky_override_shrink"
));
if
(
properties
.
getProperty
(
prefix
+
"disp_boost_min"
)!=
null
)
this
.
disp_boost_min
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"disp_boost_min"
));
if
(
properties
.
getProperty
(
prefix
+
"disp_boost_diff"
)!=
null
)
this
.
disp_boost_diff
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"disp_boost_diff"
));
if
(
properties
.
getProperty
(
prefix
+
"disp_boost_neibs"
)!=
null
)
this
.
disp_boost_neibs
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"disp_boost_neibs"
));
if
(
properties
.
getProperty
(
prefix
+
"disp_boost_amount"
)!=
null
)
this
.
disp_boost_amount
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"disp_boost_amount"
));
if
(
properties
.
getProperty
(
prefix
+
"margin"
)!=
null
)
this
.
margin
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"margin"
));
if
(
properties
.
getProperty
(
prefix
+
"margin"
)!=
null
)
this
.
margin
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"margin"
));
if
(
properties
.
getProperty
(
prefix
+
"sensor_mask_inter"
)!=
null
)
this
.
sensor_mask_inter
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"sensor_mask_inter"
));
if
(
properties
.
getProperty
(
prefix
+
"sensor_mask_inter"
)!=
null
)
this
.
sensor_mask_inter
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"sensor_mask_inter"
));
if
(
properties
.
getProperty
(
prefix
+
"use_partial"
)!=
null
)
this
.
use_partial
=
Boolean
.
parseBoolean
(
properties
.
getProperty
(
prefix
+
"use_partial"
));
if
(
properties
.
getProperty
(
prefix
+
"use_partial"
)!=
null
)
this
.
use_partial
=
Boolean
.
parseBoolean
(
properties
.
getProperty
(
prefix
+
"use_partial"
));
...
@@ -1679,6 +1703,11 @@ public class IntersceneMatchParameters {
...
@@ -1679,6 +1703,11 @@ public class IntersceneMatchParameters {
imp
.
sky_bottom_override
=
this
.
sky_bottom_override
;
imp
.
sky_bottom_override
=
this
.
sky_bottom_override
;
imp
.
sky_override_shrink
=
this
.
sky_override_shrink
;
imp
.
sky_override_shrink
=
this
.
sky_override_shrink
;
imp
.
disp_boost_min
=
this
.
disp_boost_min
;
imp
.
disp_boost_diff
=
this
.
disp_boost_diff
;
imp
.
disp_boost_neibs
=
this
.
disp_boost_neibs
;
imp
.
disp_boost_amount
=
this
.
disp_boost_amount
;
imp
.
margin
=
this
.
margin
;
imp
.
margin
=
this
.
margin
;
imp
.
sensor_mask_inter
=
this
.
sensor_mask_inter
;
imp
.
sensor_mask_inter
=
this
.
sensor_mask_inter
;
imp
.
use_partial
=
this
.
use_partial
;
imp
.
use_partial
=
this
.
use_partial
;
...
...
src/main/java/com/elphel/imagej/tileprocessor/OpticalFlow.java
View file @
0349faa4
...
@@ -2802,7 +2802,7 @@ public class OpticalFlow {
...
@@ -2802,7 +2802,7 @@ public class OpticalFlow {
for
(
int
ithread
=
0
;
ithread
<
threads
.
length
;
ithread
++)
{
for
(
int
ithread
=
0
;
ithread
<
threads
.
length
;
ithread
++)
{
threads
[
ithread
]
=
new
Thread
()
{
threads
[
ithread
]
=
new
Thread
()
{
public
void
run
()
{
public
void
run
()
{
for
(
int
nTile
=
ai
.
getAndIncrement
();
nTile
<
tiles
;
nTile
=
ai
.
getAndIncrement
())
if
(!
Double
.
isNaN
(
disparity_ref
[
nTile
]))
{
for
(
int
nTile
=
ai
.
getAndIncrement
();
nTile
<
tiles
;
nTile
=
ai
.
getAndIncrement
())
if
(!
Double
.
isNaN
(
disparity_ref
[
nTile
]))
{
// null !!!
double
disparity
=
disparity_ref
[
nTile
];
double
disparity
=
disparity_ref
[
nTile
];
int
tileY
=
nTile
/
tilesX
;
int
tileY
=
nTile
/
tilesX
;
int
tileX
=
nTile
%
tilesX
;
int
tileX
=
nTile
%
tilesX
;
...
@@ -4139,6 +4139,11 @@ public class OpticalFlow {
...
@@ -4139,6 +4139,11 @@ public class OpticalFlow {
int
lowest_sky_row
=
clt_parameters
.
imp
.
lowest_sky_row
;
int
lowest_sky_row
=
clt_parameters
.
imp
.
lowest_sky_row
;
double
sky_bottom_override
=
clt_parameters
.
imp
.
sky_bottom_override
;
double
sky_bottom_override
=
clt_parameters
.
imp
.
sky_bottom_override
;
int
sky_override_shrink
=
clt_parameters
.
imp
.
sky_override_shrink
;
int
sky_override_shrink
=
clt_parameters
.
imp
.
sky_override_shrink
;
double
disp_boost_min
=
clt_parameters
.
imp
.
disp_boost_min
;
// 0.5;
double
disp_boost_diff
=
clt_parameters
.
imp
.
disp_boost_diff
;
// 0.35;
int
disp_boost_neibs
=
clt_parameters
.
imp
.
disp_boost_neibs
;
// 2;
double
disp_boost_amount
=
clt_parameters
.
imp
.
disp_boost_amount
;
// 2.0;
boolean
[]
ref_blue_sky
=
null
;
// turn off "lma" in the ML output
boolean
[]
ref_blue_sky
=
null
;
// turn off "lma" in the ML output
...
@@ -4279,6 +4284,10 @@ public class OpticalFlow {
...
@@ -4279,6 +4284,10 @@ public class OpticalFlow {
sky_bottom_override
,
// double sky_temp_override, // really cold average seed - ignore lowest_sky_row filter
sky_bottom_override
,
// double sky_temp_override, // really cold average seed - ignore lowest_sky_row filter
sky_override_shrink
,
// int shrink_for_temp, // shrink before finding hottest sky
sky_override_shrink
,
// int shrink_for_temp, // shrink before finding hottest sky
sky_highest_min
,
// = 100; // lowest absolute value should not be higher (requires photometric)
sky_highest_min
,
// = 100; // lowest absolute value should not be higher (requires photometric)
disp_boost_min
,
// double disp_boost_min, // = 0.5;
disp_boost_diff
,
//double disp_boost_diff, // = 0.35;
disp_boost_neibs
,
//int disp_boost_neibs, // = 2;
disp_boost_amount
,
//double disp_boost_amount, // = 2.0;
dsi
[
TwoQuadCLT
.
DSI_STRENGTH_AUX
],
// double [] strength,
dsi
[
TwoQuadCLT
.
DSI_STRENGTH_AUX
],
// double [] strength,
dsi
[
TwoQuadCLT
.
DSI_SPREAD_AUX
],
// double [] spread,
dsi
[
TwoQuadCLT
.
DSI_SPREAD_AUX
],
// double [] spread,
dsi
[
TwoQuadCLT
.
DSI_DISPARITY_AUX_LMA
],
// double [] spread,
dsi
[
TwoQuadCLT
.
DSI_DISPARITY_AUX_LMA
],
// double [] spread,
...
@@ -4333,6 +4342,10 @@ public class OpticalFlow {
...
@@ -4333,6 +4342,10 @@ public class OpticalFlow {
sky_bottom_override
,
// double sky_temp_override, // really cold average seed - ignore lowest_sky_row filter
sky_bottom_override
,
// double sky_temp_override, // really cold average seed - ignore lowest_sky_row filter
sky_override_shrink
,
// int shrink_for_temp, // shrink before finding hottest sky
sky_override_shrink
,
// int shrink_for_temp, // shrink before finding hottest sky
sky_highest_min
,
// = 100; // lowest absolute value should not be higher (requires photometric)
sky_highest_min
,
// = 100; // lowest absolute value should not be higher (requires photometric)
disp_boost_min
,
// double disp_boost_min, // = 0.5;
disp_boost_diff
,
//double disp_boost_diff, // = 0.35;
disp_boost_neibs
,
//int disp_boost_neibs, // = 2;
disp_boost_amount
,
//double disp_boost_amount, // = 2.0;
dsi
[
TwoQuadCLT
.
DSI_STRENGTH_AUX
],
// double [] strength,
dsi
[
TwoQuadCLT
.
DSI_STRENGTH_AUX
],
// double [] strength,
dsi
[
TwoQuadCLT
.
DSI_SPREAD_AUX
],
// double [] spread,
dsi
[
TwoQuadCLT
.
DSI_SPREAD_AUX
],
// double [] spread,
dsi
[
TwoQuadCLT
.
DSI_DISPARITY_AUX_LMA
],
//double [] disp_lma,
dsi
[
TwoQuadCLT
.
DSI_DISPARITY_AUX_LMA
],
//double [] disp_lma,
...
@@ -4456,6 +4469,7 @@ public class OpticalFlow {
...
@@ -4456,6 +4469,7 @@ public class OpticalFlow {
last_diff
);
last_diff
);
}
}
// Refine with LMA
// Refine with LMA
scenes_xyzatr
[
scene_index
]
=
adjustPairsLMAInterscene
(
scenes_xyzatr
[
scene_index
]
=
adjustPairsLMAInterscene
(
clt_parameters
,
// CLTParameters clt_parameters,
clt_parameters
,
// CLTParameters clt_parameters,
quadCLTs
[
ref_index
],
// QuadCLT reference_QuadCLT,
quadCLTs
[
ref_index
],
// QuadCLT reference_QuadCLT,
...
@@ -4595,6 +4609,7 @@ public class OpticalFlow {
...
@@ -4595,6 +4609,7 @@ public class OpticalFlow {
clt_parameters
,
// CLTParameters clt_parameters,
clt_parameters
,
// CLTParameters clt_parameters,
reliable_ref
,
// boolean [] reliable_ref, // null or bitmask of reliable reference tiles
reliable_ref
,
// boolean [] reliable_ref, // null or bitmask of reliable reference tiles
quadCLTs
,
// QuadCLT [] quadCLTs,
quadCLTs
,
// QuadCLT [] quadCLTs,
!
batch_mode
,
// boolean test_motion_blur,
debugLevel
)
;
// int debugLevel)
debugLevel
)
;
// int debugLevel)
// should update earliest_scene
// should update earliest_scene
if
((
ref_index
-
earliest_scene
+
1
)
<
min_num_scenes
)
{
if
((
ref_index
-
earliest_scene
+
1
)
<
min_num_scenes
)
{
...
@@ -14066,9 +14081,10 @@ public double[][] correlateIntersceneDebug( // only uses GPU and quad
...
@@ -14066,9 +14081,10 @@ public double[][] correlateIntersceneDebug( // only uses GPU and quad
CLTParameters
clt_parameters
,
CLTParameters
clt_parameters
,
boolean
[]
reliable_ref
,
// null or bitmask of reliable reference tiles
boolean
[]
reliable_ref
,
// null or bitmask of reliable reference tiles
QuadCLT
[]
quadCLTs
,
QuadCLT
[]
quadCLTs
,
boolean
test_motion_blur
,
int
debugLevel
)
int
debugLevel
)
{
{
boolean
test_motion_blur
=
true
;
// boolean test_motion_blur = true;//false
boolean
mb_en
=
clt_parameters
.
imp
.
mb_en
;
boolean
mb_en
=
clt_parameters
.
imp
.
mb_en
;
double
mb_tau
=
clt_parameters
.
imp
.
mb_tau
;
// 0.008; // time constant, sec
double
mb_tau
=
clt_parameters
.
imp
.
mb_tau
;
// 0.008; // time constant, sec
...
@@ -14831,6 +14847,11 @@ public double[][] correlateIntersceneDebug( // only uses GPU and quad
...
@@ -14831,6 +14847,11 @@ public double[][] correlateIntersceneDebug( // only uses GPU and quad
double
max_rms
,
double
max_rms
,
int
debug_level
)
int
debug_level
)
{
{
boolean
use_lma_dsi
=
clt_parameters
.
imp
.
use_lma_dsi
;
if
(
ref_disparity
==
null
)
{
ref_disparity
=
reference_QuadClt
.
getDLS
()[
use_lma_dsi
?
1
:
0
];
}
// TODO: set reference as new version of adjustPairsLMAInterscene() assumes it set
// TODO: set reference as new version of adjustPairsLMAInterscene() assumes it set
int
margin
=
clt_parameters
.
imp
.
margin
;
int
margin
=
clt_parameters
.
imp
.
margin
;
double
[][]
pXpYD_ref
=
transformToScenePxPyD
(
// full size - [tilesX*tilesY], some nulls
double
[][]
pXpYD_ref
=
transformToScenePxPyD
(
// full size - [tilesX*tilesY], some nulls
...
...
src/main/java/com/elphel/imagej/tileprocessor/QuadCLTCPU.java
View file @
0349faa4
...
@@ -458,11 +458,18 @@ public class QuadCLTCPU {
...
@@ -458,11 +458,18 @@ public class QuadCLTCPU {
double
sky_temp_override
,
// really cold average seed - ignore lowest_sky_row filter
double
sky_temp_override
,
// really cold average seed - ignore lowest_sky_row filter
int
shrink_for_temp
,
// shrink before finding hottest sky
int
shrink_for_temp
,
// shrink before finding hottest sky
double
sky_highest_min
,
// = -50; // 100; // lowest absolute value should not be higher (requires photometric)
double
sky_highest_min
,
// = -50; // 100; // lowest absolute value should not be higher (requires photometric)
double
disp_boost_min
,
// = 0.5;
double
disp_boost_diff
,
// = 0.35;
int
disp_boost_neibs
,
// = 2;
double
disp_boost_amount
,
// = 2.0;
int
width
,
int
width
,
double
[]
strength
,
double
[]
strength
,
double
[]
spread
,
double
[]
spread
,
double
[]
disparity
,
double
[]
disparity
,
double
[]
avg_val
,
double
[]
avg_val
,
int
debugLevel
)
{
// >0 to show
int
debugLevel
)
{
// >0 to show
if
((
strength
==
null
)
||
(
spread
==
null
))
{
if
((
strength
==
null
)
||
(
spread
==
null
))
{
return
null
;
return
null
;
...
@@ -556,11 +563,36 @@ public class QuadCLTCPU {
...
@@ -556,11 +563,36 @@ public class QuadCLTCPU {
String
[]
dbg_in_titles
=
{
"fom"
,
"strength"
,
"spread"
,
"disparity"
,
"avg_val"
,
"tscale"
};
String
[]
dbg_in_titles
=
{
"fom"
,
"strength"
,
"spread"
,
"disparity"
,
"avg_val"
,
"tscale"
};
String
[]
dbg_titles
=
{
"sky"
,
"seed"
,
"max"
,
"shrank"
,
"full_shrank"
,
"neck_shrank"
,
"reexpand"
};
String
[]
dbg_titles
=
{
"sky"
,
"seed"
,
"max"
,
"shrank"
,
"full_shrank"
,
"neck_shrank"
,
"reexpand"
};
if
(
debugLevel
>
0
)
{
double
[][]
dbg_img
=
(
debugLevel
>
0
)
?
new
double
[
dbg_titles
.
length
][
strength
.
length
]:
null
;
TileNeibs
tn
=
new
TileNeibs
(
width
,
strength
.
length
/
width
);
boolean
[]
sky_tiles
=
new
boolean
[
strength
.
length
];
boolean
[]
prohibit_tiles
=
new
boolean
[
strength
.
length
];
double
[]
fom
=
new
double
[
strength
.
length
];
double
[]
fom
=
new
double
[
strength
.
length
];
for
(
int
i
=
0
;
i
<
fom
.
length
;
i
++)
{
for
(
int
i
=
0
;
i
<
sky_tiles
.
length
;
i
++)
{
fom
[
i
]
=
Math
.
max
(
strength
[
i
],
min_strength
)
*
spread
[
i
]
*
temp_scales
[
i
];
fom
[
i
]
=
Math
.
max
(
strength
[
i
],
min_strength
)
*
spread
[
i
];
if
(
temp_scales
!=
null
)
{
fom
[
i
]
*=
temp_scales
[
i
];
}
}
if
(
disp_boost_amount
>
0
)
{
for
(
int
nTile
=
0
;
nTile
<
sky_tiles
.
length
;
nTile
++)
if
(
disparity
[
nTile
]
>=
disp_boost_min
){
int
num_neibs
=
0
;
for
(
int
dir
=
0
;
dir
<
8
;
dir
++)
{
int
nTile1
=
tn
.
getNeibIndex
(
nTile
,
dir
);
if
((
nTile1
>=
0
)
&&
(
Math
.
abs
(
disparity
[
nTile
]
-
disparity
[
nTile1
])
<=
disp_boost_diff
))
{
num_neibs
++;
}
}
}
if
(
num_neibs
>=
disp_boost_neibs
)
{
fom
[
nTile
]
*=
disp_boost_amount
*
num_neibs
/
disp_boost_neibs
;
}
}
}
if
(
debugLevel
>
0
)
{
(
new
ShowDoubleFloatArrays
()).
showArrays
(
(
new
ShowDoubleFloatArrays
()).
showArrays
(
new
double
[][]
{
fom
,
strength
,
spread
,
disparity
,
avg_val
,
temp_scales
},
new
double
[][]
{
fom
,
strength
,
spread
,
disparity
,
avg_val
,
temp_scales
},
width
,
width
,
...
@@ -570,20 +602,14 @@ public class QuadCLTCPU {
...
@@ -570,20 +602,14 @@ public class QuadCLTCPU {
dbg_in_titles
);
// dsrbg_titles);
dbg_in_titles
);
// dsrbg_titles);
}
}
double
[][]
dbg_img
=
(
debugLevel
>
0
)
?
new
double
[
dbg_titles
.
length
][
strength
.
length
]:
null
;
boolean
[]
sky_tiles
=
new
boolean
[
strength
.
length
];
boolean
[]
prohibit_tiles
=
new
boolean
[
strength
.
length
];
for
(
int
i
=
0
;
i
<
sky_tiles
.
length
;
i
++)
{
for
(
int
i
=
0
;
i
<
sky_tiles
.
length
;
i
++)
{
double
d
=
Math
.
max
(
strength
[
i
],
min_strength
)
*
spread
[
i
];
prohibit_tiles
[
i
]
=
(
fom
[
i
]
>=
sky_lim
);
if
(
temp_scales
!=
null
)
{
sky_tiles
[
i
]
=
(
fom
[
i
]
<
sky_seed
)
&&
!(
disparity
[
i
]
>
disparity_seed
);
d
*=
temp_scales
[
i
];
}
prohibit_tiles
[
i
]
=
(
d
>=
sky_lim
);
int
row
=
i
/
width
;
// sky_tiles[i] = (row < seed_rows) && (d < sky_seed) && !(disparity[i] > disparity_seed);
sky_tiles
[
i
]
=
(
d
<
sky_seed
)
&&
!(
disparity
[
i
]
>
disparity_seed
);
}
}
//seed_rows
//seed_rows
if
(
dbg_img
!=
null
)
{
if
(
dbg_img
!=
null
)
{
for
(
int
i
=
0
;
i
<
sky_tiles
.
length
;
i
++)
{
for
(
int
i
=
0
;
i
<
sky_tiles
.
length
;
i
++)
{
...
@@ -591,7 +617,6 @@ public class QuadCLTCPU {
...
@@ -591,7 +617,6 @@ public class QuadCLTCPU {
dbg_img
[
2
][
i
]
=
prohibit_tiles
[
i
]?
0
:
1
;
dbg_img
[
2
][
i
]
=
prohibit_tiles
[
i
]?
0
:
1
;
}
}
}
}
TileNeibs
tn
=
new
TileNeibs
(
width
,
sky_tiles
.
length
/
width
);
tn
.
shrinkSelection
(
tn
.
shrinkSelection
(
sky_shrink
,
// int shrink, // grow tile selection by 1 over non-background tiles 1: 4 directions, 2 - 8 directions, 3 - 8 by 1, 4 by 1 more
sky_shrink
,
// int shrink, // grow tile selection by 1 over non-background tiles 1: 4 directions, 2 - 8 directions, 3 - 8 by 1, 4 by 1 more
sky_tiles
,
// boolean [] tiles,
sky_tiles
,
// boolean [] tiles,
...
@@ -724,6 +749,10 @@ public class QuadCLTCPU {
...
@@ -724,6 +749,10 @@ public class QuadCLTCPU {
double
sky_temp_override
,
// really cold average seed - ignore lowest_sky_row filter
double
sky_temp_override
,
// really cold average seed - ignore lowest_sky_row filter
int
shrink_for_temp
,
// shrink before finding hottest sky
int
shrink_for_temp
,
// shrink before finding hottest sky
double
sky_highest_max
,
// = 100; // lowest absolute value should not be higher (requires photometric)
double
sky_highest_max
,
// = 100; // lowest absolute value should not be higher (requires photometric)
double
disp_boost_min
,
// = 0.5;
double
disp_boost_diff
,
// = 0.35;
int
disp_boost_neibs
,
// = 2;
double
disp_boost_amount
,
// = 2.0;
double
[]
strength
,
double
[]
strength
,
double
[]
spread
,
double
[]
spread
,
double
[]
disp_lma
,
double
[]
disp_lma
,
...
@@ -746,6 +775,10 @@ public class QuadCLTCPU {
...
@@ -746,6 +775,10 @@ public class QuadCLTCPU {
sky_temp_override
,
// double sky_temp_override, // really cold average seed - ignore lowest_sky_row filter
sky_temp_override
,
// double sky_temp_override, // really cold average seed - ignore lowest_sky_row filter
shrink_for_temp
,
// int shrink_for_temp, // shrink before finding hottest sky
shrink_for_temp
,
// int shrink_for_temp, // shrink before finding hottest sky
sky_highest_max
,
// = 100; // lowest absolute value should not be higher (requires photometric)
sky_highest_max
,
// = 100; // lowest absolute value should not be higher (requires photometric)
disp_boost_min
,
// = 0.5;
disp_boost_diff
,
// = 0.35;
disp_boost_neibs
,
// = 2;
disp_boost_amount
,
// = 2.0;
width
,
width
,
strength
,
strength
,
spread
,
spread
,
...
...
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