for(intnseq=0;nseq<num_seq;nseq++)if(local_tiles[nseq].length>0){// no if is not needed - bug fixed
uas_tiles[nseq]=local_tiles[nseq][0];
uas_tiles[nseq]=local_tiles[nseq][0];
}
}
...
@@ -5177,6 +5184,8 @@ public class CuasMotion {
...
@@ -5177,6 +5184,8 @@ public class CuasMotion {
doublexc,
doublexc,
doubleyc,
doubleyc,
doubleradius){
doubleradius){
intwidth=colorProcessor.getWidth();
intheight=colorProcessor.getHeight();
doubleradius2=radius*radius;
doubleradius2=radius*radius;
inticolor=color.getRGB()|0xff000000;// needed?
inticolor=color.getRGB()|0xff000000;// needed?
if(color!=null)colorProcessor.setColor(color);
if(color!=null)colorProcessor.setColor(color);
...
@@ -5184,7 +5193,11 @@ public class CuasMotion {
...
@@ -5184,7 +5193,11 @@ public class CuasMotion {
inty0=(int)Math.floor(yc-radius);
inty0=(int)Math.floor(yc-radius);
intx1=(int)Math.ceil(xc+radius);
intx1=(int)Math.ceil(xc+radius);
inty1=(int)Math.ceil(yc+radius);
inty1=(int)Math.ceil(yc+radius);
intwidth=colorProcessor.getWidth();
if((x0<0)||(y0<0)||(x1>=width)||(y1>=height)){
System.out.println("drawCircle(): outside of the window: xc="+xc+", yc="+yc+", width="+width+", height="+height+
", color="+color.toString());
return;
}
int[]pixels=(int[])colorProcessor.getPixels();
int[]pixels=(int[])colorProcessor.getPixels();
for(inty=y0;y<=y1;y++){
for(inty=y0;y<=y1;y++){
doubledy=y-yc;
doubledy=y-yc;
...
@@ -5193,7 +5206,8 @@ public class CuasMotion {
...
@@ -5193,7 +5206,8 @@ public class CuasMotion {
doubledx=x-xc;
doubledx=x-xc;
doubler2=dx*dx+dy2;
doubler2=dx*dx+dy2;
if(r2<=radius2){
if(r2<=radius2){
pixels[x+y*width]=icolor;
pixels[x+y*width]=icolor;// java.lang.ArrayIndexOutOfBoundsException: Index -144985 out of bounds for length 552960 at com.elphel.imagej.cuas.CuasMotion.drawCircle(CuasMotion.java:5197) at com.elphel.imagej.cuas.CuasMotion$33.run(CuasMotion.java:4662)
}
}
}
}
}
}
...
@@ -6903,7 +6917,7 @@ public class CuasMotion {
...
@@ -6903,7 +6917,7 @@ public class CuasMotion {
*/
*/
publicstaticint[][][]calcMatchingTargetsLengths(// calculate number of consecutive keyframes connected to each target
publicstaticint[][][]calcMatchingTargetsLengths(// calculate number of consecutive keyframes connected to each target
finaldouble[][][][]targets_multi,
finaldouble[][][][]targets_multi,
finalbooleancalc_linked,
finalbooleancalc_linked,// needed to calculate indices in the order of lengths. But only when there are few targets
finaldoublemax_mismatch,// if <=0, do not calculate mismatch_ba and filter
finaldoublemax_mismatch,// if <=0, do not calculate mismatch_ba and filter
finaldoubleslow_fast_mismatch,
finaldoubleslow_fast_mismatch,
finaldoublematch_len_pwr,// 0.5; // raise matching length to this power for calculating score
finaldoublematch_len_pwr,// 0.5; // raise matching length to this power for calculating score
...
@@ -9783,6 +9797,7 @@ public class CuasMotion {
...
@@ -9783,6 +9797,7 @@ public class CuasMotion {
}
}
finalvoidrecalcOmegas(
finalvoidrecalcOmegas(
booleanrecalc,
double[][][]target_single,
double[][][]target_single,
booleanbatch_mode,
booleanbatch_mode,
intdebugLevel){
intdebugLevel){
...
@@ -9806,9 +9821,11 @@ public class CuasMotion {
...
@@ -9806,9 +9821,11 @@ public class CuasMotion {
targets_multi,// final double [][][][] targets_multi,
targets_multi,// final double [][][][] targets_multi,
true,// final boolean good_only,
true,// final boolean good_only,
tilesX);// int tilesX) {
tilesX);// int tilesX) {
if(recalc){
recalcOmegas(
recalcOmegas(
targets_multi,// double [][][][] targets_multi,
targets_multi,// double [][][][] targets_multi,
debugLevel);// int debugLevel){
debugLevel);// int debugLevel){
}
getHalfBeforeAfterPixXY(
getHalfBeforeAfterPixXY(
targets_multi,// final double [][][][] targets_multi,
targets_multi,// final double [][][][] targets_multi,
publicdoublecuas_font_spacing=1.2;//height to size ratio. If 0 - will use default spacing ( ~=1.5)
publicbooleancuas_annot_missing=false;// Reserve a line for requested but missing parameters
// AZ/EL calibration
// AZ/EL calibration
@Deprecated
@Deprecated
publicdoublecuas_ifov=0.05;// degree per pixel Use gc.getIFOVDegrees() and gc.getIFOV() instead
publicdoublecuas_ifov=0.05;// degree per pixel Use gc.getIFOVDegrees() and gc.getIFOV() instead
...
@@ -920,7 +935,7 @@ min_str_neib_fpn 0.35
...
@@ -920,7 +935,7 @@ min_str_neib_fpn 0.35
publicdoublecuas_tmtch_frac=0.8;// target should match flight log in theis fraction of keyframes
publicdoublecuas_tmtch_frac=0.8;// target should match flight log in theis fraction of keyframes
publicintcuas_tmtch_ends=6;// 2; // maximal number of undetected first/last keyframes to compare to previous/next sequence
publicintcuas_tmtch_ends=6;// 2; // maximal number of undetected first/last keyframes to compare to previous/next sequence
publicintcuas_tmtch_gaps=10;// 4; // maximal number of consecutive undetected keyframes of the same target
publicintcuas_tmtch_gaps=10;// 4; // maximal number of consecutive undetected keyframes of the same target
publicdoublecuas_tmtch_pix=10.0;// maximal pixel mismatch for UAS target
publicdoublecuas_tmtch_pix=25.0;// maximal pixel mismatch for UAS target
publicdoublecuas_local_apix=2.0;// maximal absolute pixel mismatch for local targets matching (tightened)
publicdoublecuas_local_apix=2.0;// maximal absolute pixel mismatch for local targets matching (tightened)
publicdoublecuas_tmtch_apix=5.0;// 10.0; // maximal absolute pixel mismatch for the same target extrapolated with the average of the before/after lateral speeds
publicdoublecuas_tmtch_apix=5.0;// 10.0; // maximal absolute pixel mismatch for the same target extrapolated with the average of the before/after lateral speeds
publicdoublecuas_tmtch_rpix=1.0;// maximal pixel/s mismatch for the same target extrapolated with the average of the before/after lateral speeds
publicdoublecuas_tmtch_rpix=1.0;// maximal pixel/s mismatch for the same target extrapolated with the average of the before/after lateral speeds
...
@@ -933,6 +948,24 @@ min_str_neib_fpn 0.35
...
@@ -933,6 +948,24 @@ min_str_neib_fpn 0.35
// parameters for "radar" image generation
// parameters for "radar" image generation
publicdoublecuas_radar_range=1500.0;// maximal radar range in meters
publicdoublecuas_radar_range=1500.0;// maximal radar range in meters
publicintcuas_radar_height=950;// height of the radar finite range view (pix)