I have forgotten
my Password

Or login with:

  • Facebookhttp://facebook.com/
  • Googlehttps://www.google.com/accounts/o8/id
  • Yahoohttps://me.yahoo.com
COST (GBP)
this unit 2.00
sub units 2.00
+
0
MathsGeometryArea

ellipse

Computes the area of the ellipse segment determined by the intersection of an ellipse and a line parallel to the reference line.
Controller: CodeCogs

Dependents

Info

Interface

C++

Ellipse

 
doubleellipsedoublea
doubleb
doubleh )[inline]
This module computes the area of the ellipse segment formed between an ellipse that is tangent to a reference line and another line parallel to this reference line, found at a given distance from it.

Solution

Let us consider an ellipse \inline \mathcal{E} with semiaxis a parallel to the reference line and semiaxis b perpendicular to this reference line, with the equation: The center of the ellipse is at \inline  (0,b). We also consider a line \inline  d parallel to the reference line at a distance \inline  h \geq 0 from it. The filled shape in the next image represents the area we must find.

MISSING IMAGE!

1/ellipse01-378.jpg cannot be found in /users/1/ellipse01-378.jpg. Please contact the submission author.

In order to compute the area by integration, we need to make the substitutions \inline x \rightarrow y and \inline y \rightarrow x, which makes the figure rotate \inline  90^\circ clockwise. The filled shape in the next image represents half the area we must find.

MISSING IMAGE!

1/ellipse02-378.jpg cannot be found in /users/1/ellipse02-378.jpg. Please contact the submission author.

The new ellipse is tangent to the Y-axis and its center is found at \inline  (b,0), while the area of the shape remains the same after this coordinates transformation. In order to compute it we will first consider the equation of the equation of the new ellipse: with positive \inline  y solution of the form:

Purchase a Licence for more information.

Example 1

#include <codecogs/maths/geometry/area/ellipse.h>
#include <stdio.h>
 
int main()
{
  // the value of the height
  double h = 0.973;
 
  // the length of the semiaxes for the first ellipse (a>b)
  double a1 = 1.925, b1 = 1.309; 
  // display the lenghts of the semiaxes for the first ellipse and the value of the height
  printf("a1 = %.3lf\nb1 = %.3lf\nh = %.3lf\n\n", a1, b1, h);
  // display the area for the first ellipse
  printf("Area is %.5lf\n\n",Geometry::Area::ellipse(a1, b1, h));
 
  // the length of the semiaxes for the second ellipse (a<b)
  double a2 = 1.125, b2 = 2.345;
  // display the lenghts of the semiaxes for the second ellipse and the value of the height
  printf("a2 = %.3lf\nb2 = %.3lf\nh = %.3lf\n\n", a2, b2, h);
  // display the area for the first ellipse
  printf("Area is %.5lf\n",Geometry::Area::ellipse(a2, b2, h));
 
  return 0;
}

Output:
a1 = 1.925
b1 = 1.309
h = 0.973
 
Area is 2.67888
 
a2 = 1.125
b2 = 2.345
h = 0.973
 
Area is 1.24346

Parameters

asemiaxis of the ellipse parallel to the reference line
bsemiaxis of the ellipse perpendicular to the reference line
hthe distance between line d and the reference line

Returns

The area of the desired shape.

Authors

Lucian Bentea, Eduard Bentea (September 2006)
Source Code

Source code is available when you buy a Commercial licence.

Not a member, then Register with CodeCogs. Already a Member, then Login.