bir daire içinde kesişen kısmının boyutunu almak için nasıl bu görüntünün siyah kısmının boyutunu gerek WebsiteJava
, R, ikinci dairenin yarıçapı ve arasındaki mesafe r çemberin yarıçapı pict http://mathworld.wolfram.com/images/equations/Circle-CircleIntersection/Inline41.gif
olarak alma son cevap d: ve bu web sitesine işaret edilmiştir iki merkez.
bu boyutunu almak için kullanmaya çalıştı kodu şuydu:
float r = getRadius1();
float R = e.getRadius1();
float deltaX = Math.abs((getX() + getRadius()) - (e.getX() + e.getRadius()));
float deltaY = Math.abs((getY() + getRadius()) - (e.getY() + e.getRadius()));
float d = (float) Math.sqrt(Math.pow(deltaX, 2) + Math.pow(deltaY, 2));
float part, part2, part3;
//Chopping it in parts, because it's easier.
part = (float) (Math.pow(r,2) * Math.acos(
Math.toRadians((Math.pow(d, 2) + Math.pow(r, 2) - Math.pow(R, 2))/(2*d*r))));
part2 = (float) (Math.pow(R,2) * Math.acos(
Math.toRadians((Math.pow(d, 2) + Math.pow(R, 2) - Math.pow(r, 2))/(2*d*R))));
part3 = (float) (0.5 * Math.sqrt((-d + r + R) * (d+r-R) * (d-r+R) * (d+r+R)));
float res = part + part2 - part3;
Main.log(res + " " + part + " " + part2 + " " + part3+ " "
+ r + " " + R + " " + d);
//logs the data and System.out's it
Bazı testler yaptım
ve çıkış şuydu:
1345.9663 621.6233 971.1231 246.78008 20.0 25.0 43.528286
Böylece belirtir örtüşen parçanın boyutu dairenin kendisinden daha büyüktü (r^2 * PI
).
Neyi yanlış yaptım?
Daha az gösterim hatası alacağından "float" yerine "double" kullanırım, ancak sizin açıklamanız için yeterli değil. ;) –
Bize deltaX ve Y için formül gösterebilir misiniz, çünkü doğru görünmüyorlar? GetRadius() ve getRadius1() arasındaki fark nedir? –
Neden getRadius1() ve e.getRadius1() var? R yarıçapını almayı mı unuttunuz? – Max