1 package jp.nyatla.nyartoolkit.core.types;
\r
5 * 定点と傾きのパラメータで、直線を表現します。
\r
8 public class NyARVecLinear2d
\r
14 public static NyARVecLinear2d[] createArray(int i_length)
\r
16 NyARVecLinear2d[] r=new NyARVecLinear2d[i_length];
\r
17 for(int i=0;i<i_length;i++){
\r
18 r[i]=new NyARVecLinear2d();
\r
25 * 元のベクトルを指定します。この値には、thisを指定できます。
\r
27 public final void normalVec(NyARVecLinear2d i_src)
\r
33 public final void setValue(NyARVecLinear2d i_value)
\r
41 * このベクトルと指定した直線が作るCos値を返します。
\r
45 public final double getVecCos(NyARVecLinear2d i_v1)
\r
51 double d=(x1*x2+y1*y2)/Math.sqrt((x1*x1+y1*y1)*(x2*x2+y2*y2));
\r
54 public final double getAbsVecCos(NyARVecLinear2d i_v1)
\r
60 double d=(x1*x2+y1*y2)/Math.sqrt((x1*x1+y1*y1)*(x2*x2+y2*y2));
\r
64 * このベクトルと指定したベクトルが作るCos値を返します。
\r
69 public final double getVecCos(double i_dx,double i_dy)
\r
73 double d=(x1*i_dx+y1*i_dy)/Math.sqrt((x1*x1+y1*y1)*(i_dx*i_dx+i_dy*i_dy));
\r
76 public final double getAbsVecCos(double i_v2_x,double i_v2_y)
\r
80 double d=(x1*i_v2_x+y1*i_v2_y)/Math.sqrt((x1*x1+y1*y1)*(i_v2_x*i_v2_x+i_v2_y*i_v2_y));
\r
84 * このベクトルと、i_pos1とi_pos2を結ぶ線分が作るcos値の絶対値を返します。
\r
89 public final double getAbsVecCos(NyARDoublePoint2d i_pos1,NyARDoublePoint2d i_pos2)
\r
91 double d=getVecCos(i_pos2.x-i_pos1.x,i_pos2.y-i_pos1.y);
\r
102 public final boolean crossPos(NyARVecLinear2d i_vector1,NyARDoublePoint2d o_point)
\r
104 double a1= i_vector1.dy;
\r
105 double b1=-i_vector1.dx;
\r
106 double c1=(i_vector1.dx*i_vector1.y-i_vector1.dy*i_vector1.x);
\r
107 double a2= this.dy;
\r
108 double b2=-this.dx;
\r
109 double c2=(this.dx*this.y-this.dy*this.x);
\r
110 final double w1 = a1 * b2 - a2 * b1;
\r
114 o_point.x = (b1 * c2 - b2 * c1) / w1;
\r
115 o_point.y = (a2 * c1 - a1 * c2) / w1;
\r
119 * 直線と、i_sp1とi_sp2の作る線分との二乗距離値の合計を返します。
\r
127 public final double sqDistBySegmentLineEdge(NyARDoublePoint2d i_sp1,NyARDoublePoint2d i_sp2)
\r
132 sc=(this.dx*this.y-this.dy*this.x);
\r
140 w1 = sa * (-sa) - sb * sb;
\r
142 return Double.POSITIVE_INFINITY;
\r
144 //i_sp1と、i_linerの交点
\r
145 lc=-(sb*i_sp1.x-sa*i_sp1.y);
\r
146 x = ((sb * lc +sa * sc) / w1)-i_sp1.x;
\r
147 y = ((sb * sc - sa * lc) / w1)-i_sp1.y;
\r
148 double sqdist=x*x+y*y;
\r
150 lc=-(sb*i_sp2.x-sa*i_sp2.y);
\r
151 x = ((sb * lc + sa * sc) / w1)-i_sp2.x;
\r
152 y = ((sb * sc - sa * lc) / w1)-i_sp2.y;
\r
154 return sqdist+x*x+y*y;
\r
158 * i_lineの直線をセットします。x,yの値は、(i_x,i_y)を通過するi_lineの法線とi_lineの交点をセットします。
\r
163 public boolean setLinear(NyARLinear i_line,double i_x,double i_y)
\r
165 double la=i_line.b;
\r
166 double lb=-i_line.a;
\r
167 double lc=-(la*i_x+lb*i_y);
\r
169 final double w1 = -lb * lb - la * la;
\r
173 this.x=((la * lc - lb * i_line.c) / w1);
\r
174 this.y= ((la * i_line.c +lb * lc) / w1);
\r
180 * 点群から最小二乗法で直線を計算してセットします。
\r
181 * 通過点x,yは、点群の中央値を通過する、算出された直線の法線との交点です。
\r
183 * @param i_number_of_data
\r
186 public final boolean leastSquares(NyARDoublePoint2d[] i_points,int i_number_of_data)
\r
189 double sum_xy = 0, sum_x = 0, sum_y = 0, sum_x2 = 0;
\r
190 for (i=0; i<i_number_of_data; i++){
\r
191 NyARDoublePoint2d ptr=i_points[i];
\r
193 sum_xy += xw * ptr.y;
\r
198 double la=-(i_number_of_data * sum_x2 - sum_x*sum_x);
\r
199 double lb=-(i_number_of_data * sum_xy - sum_x * sum_y);
\r
200 double cc=(sum_x2 * sum_y - sum_xy * sum_x);
\r
201 double lc=-(la*sum_x+lb*sum_y)/i_number_of_data;
\r
203 final double w1 = -lb * lb - la * la;
\r
207 this.x=((la * lc - lb * cc) / w1);
\r
208 this.y= ((la * cc +lb * lc) / w1);
\r
214 * 正規化したベクトルを出力する{@link #leastSquares}です。
\r
216 * @param i_number_of_data
\r
219 public final boolean leastSquaresWithNormalize(NyARDoublePoint2d[] i_points,int i_number_of_data)
\r
221 boolean ret=this.leastSquares(i_points, i_number_of_data);
\r
222 double sq=1/Math.sqrt(this.dx*this.dx+this.dy*this.dy);
\r