summaryrefslogtreecommitdiff
path: root/src/sims/dynamics/RegularPolygon.scala
diff options
context:
space:
mode:
authorJakob Odersky <jodersky@gmail.com>2009-11-05 21:02:40 +0000
committerJakob Odersky <jodersky@gmail.com>2009-11-05 21:02:40 +0000
commit9d20024aa35cd7f923ebfc1ed9a2ffbf2731da70 (patch)
tree4e97fadc391b310ee1cc7156fda590dff414b2c3 /src/sims/dynamics/RegularPolygon.scala
parent034bc5930ea6f01745f64a6070711d899d2c27ae (diff)
downloadsims-9d20024aa35cd7f923ebfc1ed9a2ffbf2731da70.tar.gz
sims-9d20024aa35cd7f923ebfc1ed9a2ffbf2731da70.tar.bz2
sims-9d20024aa35cd7f923ebfc1ed9a2ffbf2731da70.zip
Initial import.
Diffstat (limited to 'src/sims/dynamics/RegularPolygon.scala')
-rw-r--r--src/sims/dynamics/RegularPolygon.scala35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/sims/dynamics/RegularPolygon.scala b/src/sims/dynamics/RegularPolygon.scala
new file mode 100644
index 0000000..c5b8a13
--- /dev/null
+++ b/src/sims/dynamics/RegularPolygon.scala
@@ -0,0 +1,35 @@
+/*
+ * Simple Mechanics Simulator (SiMS)
+ * copyright (c) 2009 Jakob Odersky
+ * made available under the MIT License
+*/
+
+package sims.dynamics
+
+import Math._
+import sims.geometry._
+
+/**Ein regelmaessiges Polygon mit <code>n</code> Seiten, dass der Kreis mit radius <code>radius</code> umschreibt.
+ * @param n Anzahl der Seiten.
+ * @param radius Radius des umschreibenden Kreises.
+ * @param density Dichte.
+ */
+case class RegularPolygon(n: Int, radius: Double, density: Double) extends Shape with ConvexPolygon{
+ require(n >= 3, "Polygon must have at least 3 sides.")
+
+ /**Hoehe eines der konstituierneden Dreiecke des Polygons.*/
+ private val h: Double = radius * cos(Pi / n)
+ /**Halbe Breite eines der konstituierneden Dreiecke des Polygons.*/
+ private val b: Double = radius * sin(Pi / n)
+
+ def halfDiags = (for (i: Int <- (0 until n).toArray) yield (Vector2D(0, radius) rotate (2 * Pi * i / n))) map (_ rotate rotation)
+
+ def vertices = for (h <- halfDiags) yield pos + h
+
+ val volume = n * h * b
+
+ /**Traegheitsmoment eines der konstituierneden Dreiecke im Zentrum des Polygons.*/
+ private val Ic: Double = density * b * (3 * b + 16) * h * h * h * h / 54
+
+ val I = n * Ic
+}