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
3f6c6c63
Commit
3f6c6c63
authored
Apr 03, 2017
by
Andrey Filippov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
plane detection
parent
8904657f
Changes
8
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
1677 additions
and
104 deletions
+1677
-104
CLTPass3d.java
src/main/java/CLTPass3d.java
+2
-1
DisparityProcessor.java
src/main/java/DisparityProcessor.java
+5
-3
EyesisCorrectionParameters.java
src/main/java/EyesisCorrectionParameters.java
+38
-1
GeometryCorrection.java
src/main/java/GeometryCorrection.java
+312
-3
QuadCLT.java
src/main/java/QuadCLT.java
+1
-1
SuperTiles.java
src/main/java/SuperTiles.java
+660
-23
TilePlanes.java
src/main/java/TilePlanes.java
+474
-0
TileProcessor.java
src/main/java/TileProcessor.java
+185
-72
No files found.
src/main/java/CLTPass3d.java
View file @
3f6c6c63
...
...
@@ -516,7 +516,7 @@ public class CLTPass3d{
}
public
void
setSuperTiles
(
public
SuperTiles
setSuperTiles
(
double
step_near
,
double
step_far
,
double
step_threshold
,
...
...
@@ -536,6 +536,7 @@ public class CLTPass3d{
strength_floor
,
strength_pow
,
stBlurSigma
);
return
this
.
superTiles
;
}
public
double
[]
showDisparityHistogram
()
{
...
...
src/main/java/DisparityProcessor.java
View file @
3f6c6c63
...
...
@@ -398,7 +398,7 @@ public class DisparityProcessor {
ImageDtt
.
startAndJoin
(
threads
);
double
[][]
dbg_data
=
{
measured_disparity
,
disp_data
[
0
],
disp_data
[
1
],
dbg_pull
[
0
],
dbg_pull
[
1
],
dbg_pull
[
2
],
strength
};
String
[]
titles
=
{
"measured"
,
"[0]"
,
"[1]"
,
"avg"
,
"meas"
,
"pull"
,
"strength"
};
if
((
debugLevel
>
0
)
&&
((
pass
==
0
)
||
(
pass
>=
(
num_passes
-
2
)))){
if
((
debugLevel
>
2
)
&&
((
pass
==
0
)
||
(
pass
>=
(
num_passes
-
2
)))){
sdfa_instance
.
showArrays
(
dbg_data
,
tilesX
,
tilesY
,
true
,
"disp_smoothed"
,
titles
);
}
...
...
@@ -978,7 +978,9 @@ public class DisparityProcessor {
int
ty1
=
ty
+
TRANSITIONS
[
tDir
][
dirChoice
][
1
];
int
tDir1
=
TRANSITIONS
[
tDir
][
dirChoice
][
2
];
// Was already here (in the same direction?
if
(
field
[
ty1
][
tx1
][
tDir1
]
==
FLD_WALKED
)
{
if
((
tx1
<
0
)
||
(
ty1
<
0
)
||
(
tx1
>
tilesX
)
||
(
ty1
>
tilesY
)){
prohib
=
true
;
}
else
if
(
field
[
ty1
][
tx1
][
tDir1
]
==
FLD_WALKED
)
{
// 325
break
walking
;
}
else
if
(
field
[
ty1
][
tx1
][
tDir1
]
==
FLD_EMPTY
)
{
tx
=
tx1
;
...
...
@@ -1103,7 +1105,7 @@ public class DisparityProcessor {
geom
[
nTile
]
=
new
int
[
8
];
int
[]
dbg_geom
=
geom
[
nTile
];
int
[]
dbg_neib
=
{
neighbors
[
nTile
-
tilesX
],
neighbors
[
nTile
+
1
]
,
neighbors
[
nTile
+
tilesX
],
neighbors
[
nTile
-
1
]};
// int [] dbg_neib = {neighbors[nTile - tilesX],neighbors[nTile + 1] , neighbors[nTile + tilesX],neighbors[nTile - 1]}; // out of bounds
int
neib
=
neighbors
[
nTile
];
if
(
neib
!=
0b11111111
){
// do nothing for internal tiles
int
tileY
=
nTile
/
tilesX
;
...
...
src/main/java/EyesisCorrectionParameters.java
View file @
3f6c6c63
...
...
@@ -2028,6 +2028,7 @@ public class EyesisCorrectionParameters {
public
double
min_clstr_max
=
0.25
;
// Minimal maximal strength of the cluster
public
int
fill_gaps
=
4
;
// same as in grow - 1: 4 directions by 1 step, 2: 8 directions by 1 step. +2*n - alternating hor/vert
public
int
fill_final
=
50
;
// same as fill_gaps, on the final pass
public
int
min_clstr_block
=
3
;
// number of tiles in a cluster to block (just non-background?)
public
int
bgnd_grow
=
2
;
// number of tiles to grow (1 - hor/vert, 2 - hor/vert/diagonal)
...
...
@@ -2113,7 +2114,7 @@ public class EyesisCorrectionParameters {
public
double
stStepNear
=
0.5
;
// Disaprity histogram step for near objects
public
double
stStepThreshold
=
1.0
;
// Disaprity threshold to switch cfrom linear to logarithmic steps
public
double
stMinDisparity
=
0.0
;
// Minimal disparity (center of a bin)
public
double
stMaxDisparity
=
50
.0
;
// Maximal disparity (center of a bin)
public
double
stMaxDisparity
=
15
.0
;
// Maximal disparity (center of a bin)
public
double
stFloor
=
0.15
;
// Subtract from strength, discard negative
public
double
stPow
=
1.0
;
// raise strength to this power
public
double
stSigma
=
1.5
;
// Blur disparity histogram (sigma in bins)
...
...
@@ -2141,6 +2142,13 @@ public class EyesisCorrectionParameters {
public
double
grow_disp_step
=
6.0
;
// Increase disparity (from maximal tried) if nothing found in that tile // TODO: handle enclosed dips?
public
double
grow_min_diff
=
0.5
;
// Grow more only if at least one channel has higher variance from others for the tile
public
double
plDispNorm
=
3.0
;
// Normalize disparities to the average if above (now only for eigenvalue comparison)
public
int
plMinPoints
=
5
;
// Minimal number of points for plane detection
public
double
plTargetEigen
=
0.1
;
// Remove outliers until main axis eigenvalue (possibly scaled by plDispNorm) gets below
public
double
plFractOutliers
=
0.3
;
// Maximal fraction of outliers to remove
public
int
plMaxOutliers
=
20
;
// Maximal number of outliers to remove
// other debug images
public
boolean
show_ortho_combine
=
false
;
// Show 'ortho_combine'
public
boolean
show_refine_supertiles
=
false
;
// show 'refine_disparity_supertiles'
...
...
@@ -2266,6 +2274,7 @@ public class EyesisCorrectionParameters {
properties
.
setProperty
(
prefix
+
"min_clstr_max"
,
this
.
min_clstr_max
+
""
);
properties
.
setProperty
(
prefix
+
"fill_gaps"
,
this
.
fill_gaps
+
""
);
properties
.
setProperty
(
prefix
+
"fill_final"
,
this
.
fill_final
+
""
);
properties
.
setProperty
(
prefix
+
"min_clstr_block"
,
this
.
min_clstr_block
+
""
);
properties
.
setProperty
(
prefix
+
"bgnd_grow"
,
this
.
bgnd_grow
+
""
);
...
...
@@ -2372,6 +2381,12 @@ public class EyesisCorrectionParameters {
properties
.
setProperty
(
prefix
+
"grow_disp_step"
,
this
.
grow_disp_step
+
""
);
properties
.
setProperty
(
prefix
+
"grow_min_diff"
,
this
.
grow_min_diff
+
""
);
properties
.
setProperty
(
prefix
+
"plDispNorm"
,
this
.
plDispNorm
+
""
);
properties
.
setProperty
(
prefix
+
"plMinPoints"
,
this
.
plMinPoints
+
""
);
properties
.
setProperty
(
prefix
+
"plTargetEigen"
,
this
.
plTargetEigen
+
""
);
properties
.
setProperty
(
prefix
+
"plFractOutliers"
,
this
.
plFractOutliers
+
""
);
properties
.
setProperty
(
prefix
+
"plMaxOutliers"
,
this
.
plMaxOutliers
+
""
);
properties
.
setProperty
(
prefix
+
"show_ortho_combine"
,
this
.
show_ortho_combine
+
""
);
properties
.
setProperty
(
prefix
+
"show_refine_supertiles"
,
this
.
show_refine_supertiles
+
""
);
properties
.
setProperty
(
prefix
+
"show_bgnd_nonbgnd"
,
this
.
show_bgnd_nonbgnd
+
""
);
...
...
@@ -2490,6 +2505,7 @@ public class EyesisCorrectionParameters {
if
(
properties
.
getProperty
(
prefix
+
"fill_gaps"
)!=
null
)
this
.
fill_gaps
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"fill_gaps"
));
if
(
properties
.
getProperty
(
prefix
+
"fill_final"
)!=
null
)
this
.
fill_final
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"fill_final"
));
if
(
properties
.
getProperty
(
prefix
+
"min_clstr_block"
)!=
null
)
this
.
min_clstr_block
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"min_clstr_block"
));
if
(
properties
.
getProperty
(
prefix
+
"bgnd_grow"
)!=
null
)
this
.
bgnd_grow
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"bgnd_grow"
));
...
...
@@ -2593,6 +2609,12 @@ public class EyesisCorrectionParameters {
if
(
properties
.
getProperty
(
prefix
+
"grow_disp_step"
)!=
null
)
this
.
grow_disp_step
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"grow_disp_step"
));
if
(
properties
.
getProperty
(
prefix
+
"grow_min_diff"
)!=
null
)
this
.
grow_min_diff
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"grow_min_diff"
));
if
(
properties
.
getProperty
(
prefix
+
"plDispNorm"
)!=
null
)
this
.
plDispNorm
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"plDispNorm"
));
if
(
properties
.
getProperty
(
prefix
+
"plMinPoints"
)!=
null
)
this
.
plMinPoints
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"plMinPoints"
));
if
(
properties
.
getProperty
(
prefix
+
"plTargetEigen"
)!=
null
)
this
.
plTargetEigen
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"plTargetEigen"
));
if
(
properties
.
getProperty
(
prefix
+
"plFractOutliers"
)!=
null
)
this
.
plFractOutliers
=
Double
.
parseDouble
(
properties
.
getProperty
(
prefix
+
"plFractOutliers"
));
if
(
properties
.
getProperty
(
prefix
+
"plMaxOutliers"
)!=
null
)
this
.
plMaxOutliers
=
Integer
.
parseInt
(
properties
.
getProperty
(
prefix
+
"plMaxOutliers"
));
if
(
properties
.
getProperty
(
prefix
+
"show_ortho_combine"
)!=
null
)
this
.
show_ortho_combine
=
Boolean
.
parseBoolean
(
properties
.
getProperty
(
prefix
+
"show_ortho_combine"
));
if
(
properties
.
getProperty
(
prefix
+
"show_refine_supertiles"
)!=
null
)
this
.
show_refine_supertiles
=
Boolean
.
parseBoolean
(
properties
.
getProperty
(
prefix
+
"show_refine_supertiles"
));
if
(
properties
.
getProperty
(
prefix
+
"show_bgnd_nonbgnd"
)!=
null
)
this
.
show_bgnd_nonbgnd
=
Boolean
.
parseBoolean
(
properties
.
getProperty
(
prefix
+
"show_bgnd_nonbgnd"
));
...
...
@@ -2725,6 +2747,7 @@ public class EyesisCorrectionParameters {
gd
.
addNumericField
(
"Minimal maximal strength of the cluster"
,
this
.
min_clstr_max
,
3
);
gd
.
addNumericField
(
"Fill gaps betsween clusters, see comments for 'grow'"
,
this
.
fill_gaps
,
0
);
gd
.
addNumericField
(
"Same as fill_gaps above, on the final pass"
,
this
.
fill_final
,
0
);
gd
.
addNumericField
(
"Number of tiles in a cluster to block (just non-background?)"
,
this
.
min_clstr_block
,
0
);
gd
.
addNumericField
(
"Number of tiles to grow tile selection (1 - hor/vert, 2 - hor/vert/diagonal)"
,
this
.
bgnd_grow
,
0
);
...
...
@@ -2835,6 +2858,13 @@ public class EyesisCorrectionParameters {
gd
.
addNumericField
(
"Trust measured disparity within +/- this value"
,
this
.
grow_disp_trust
,
6
);
gd
.
addNumericField
(
"Increase disparity (from maximal tried) if nothing found in that tile"
,
this
.
grow_disp_step
,
6
);
gd
.
addNumericField
(
"Grow more only if at least one channel has higher variance from others for the tile"
,
this
.
grow_min_diff
,
6
);
gd
.
addMessage
(
"--- Planes detection ---"
);
gd
.
addNumericField
(
"Normalize disparities to the average if above"
,
this
.
plDispNorm
,
6
);
gd
.
addNumericField
(
"Minimal number of points for plane detection"
,
this
.
plMinPoints
,
0
);
gd
.
addNumericField
(
"Remove outliers until main axis eigenvalue (possibly scaled by plDispNorm) gets below"
,
this
.
plTargetEigen
,
6
);
gd
.
addNumericField
(
"Maximal fraction of outliers to remove"
,
this
.
plFractOutliers
,
6
);
gd
.
addNumericField
(
"Maximal number of outliers to remove"
,
this
.
plMaxOutliers
,
0
);
gd
.
addMessage
(
"--- Other debug images ---"
);
gd
.
addCheckbox
(
"Show 'ortho_combine'"
,
this
.
show_ortho_combine
);
gd
.
addCheckbox
(
"Show 'refine_disparity_supertiles'"
,
this
.
show_refine_supertiles
);
...
...
@@ -2960,6 +2990,7 @@ public class EyesisCorrectionParameters {
this
.
min_clstr_max
=
gd
.
getNextNumber
();
this
.
fill_gaps
=
(
int
)
gd
.
getNextNumber
();
this
.
fill_final
=
(
int
)
gd
.
getNextNumber
();
this
.
min_clstr_block
=
(
int
)
gd
.
getNextNumber
();
this
.
bgnd_grow
=
(
int
)
gd
.
getNextNumber
();
...
...
@@ -3065,6 +3096,12 @@ public class EyesisCorrectionParameters {
this
.
grow_disp_step
=
gd
.
getNextNumber
();
this
.
grow_min_diff
=
gd
.
getNextNumber
();
this
.
plDispNorm
=
gd
.
getNextNumber
();
this
.
plMinPoints
=
(
int
)
gd
.
getNextNumber
();
this
.
plTargetEigen
=
gd
.
getNextNumber
();
this
.
plFractOutliers
=
gd
.
getNextNumber
();
this
.
plMaxOutliers
=
(
int
)
gd
.
getNextNumber
();
this
.
show_ortho_combine
=
gd
.
getNextBoolean
();
this
.
show_refine_supertiles
=
gd
.
getNextBoolean
();
this
.
show_bgnd_nonbgnd
=
gd
.
getNextBoolean
();
// first on second pass
...
...
src/main/java/GeometryCorrection.java
View file @
3f6c6c63
This diff is collapsed.
Click to expand it.
src/main/java/QuadCLT.java
View file @
3f6c6c63
...
...
@@ -5059,7 +5059,7 @@ public class QuadCLT {
geometryCorrection
,
threadsMax
,
// maximal number of threads to launch
updateStatus
,
debugLevel
);
2
);
//
debugLevel);
// get images for predefined regions and disparities. First - with just fixed scans 1 .. list.size()
tp
.
showScan
(
...
...
src/main/java/SuperTiles.java
View file @
3f6c6c63
This diff is collapsed.
Click to expand it.
src/main/java/TilePlanes.java
0 → 100644
View file @
3f6c6c63
This diff is collapsed.
Click to expand it.
src/main/java/TileProcessor.java
View file @
3f6c6c63
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