1つの画像を値として考えたものと表しています。
このようにラベリング処理されたものがあるとします。
それをラベルごとの座標の重心を求めたいです。
例えば 1の場合(5、0)(6、0)(7、0)(4、1)(5、1)(6、1)(4、2)(5、2)(6、2)(5、3)(6、3)で
(5+6+7+4+5+6+4+5+6+5+6)/11=5 小数点はなし
(0+0+0+1+1+1+2+2+2+3+3)/11=1 小数点はなし
(5、1)
という風なプログラムを作っています
void zyusin(Img img){ Img limg; int sx,sy; int x,y,label1x=0,label1y=0,label2x=0,label2y=0; int label1=0,label2=0; limg.sx=sx; limg.sy=sy; for(y=0;y<sy;y++){ for(x=0;x<sx;x++){ if(limg.d[0][y][x]==1){ label1++; }else if(limg.d[0][y][x]==2){ label2++; } } } for(y=0;y<sy;y++){ for(x=0;x<sx;x++){ if(limg.d[0][y][x]==1){ label1x=label1x+x; label1y=label1y+y; }if(limg.d[0][y][x]==2){ label2x=label2x+x; label2y=label2y+y; } } } label1x=label1x/label1; label1y=label1y/label1; label2x=label2x/label2; label2y=label2y/label2; printf("1 %d,%d\n2 %d,%d",label1x,label1y,label2x,label2y); }
個別にソースを提示しないで(最低限コンパイルが通る形で)まとめて下さい。
・・・インデントの整合性確認もコンパイルも出来ない・・・
回答1件
あなたの回答
tips
プレビュー