• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdeedu API Reference
  • KDE Home
  • Contact Us
 

step/stepcore

  • sources
  • kde-4.12
  • kdeedu
  • step
  • stepcore
gravitation.cc
Go to the documentation of this file.
1 /* This file is part of StepCore library.
2  Copyright (C) 2007 Vladimir Kuznetsov <ks.vladimir@gmail.com>
3 
4  StepCore library is free software; you can redistribute it and/or modify
5  it under the terms of the GNU General Public License as published by
6  the Free Software Foundation; either version 2 of the License, or
7  (at your option) any later version.
8 
9  StepCore library is distributed in the hope that it will be useful,
10  but WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  GNU General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License
15  along with StepCore; if not, write to the Free Software
16  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18 
19 #include "gravitation.h"
20 #include "particle.h"
21 #include "rigidbody.h"
22 #include <cmath>
23 #include <QtGlobal>
24 
25 namespace StepCore
26 {
27 
28 STEPCORE_META_OBJECT(GravitationForce, QT_TRANSLATE_NOOP("ObjectClass", "GravitationForce"), QT_TR_NOOP("Gravitation force"), 0,
29  STEPCORE_SUPER_CLASS(Item) STEPCORE_SUPER_CLASS(Force),
30  STEPCORE_PROPERTY_RW(double, gravitationConst, QT_TRANSLATE_NOOP("PropertyName", "gravitationConst"), STEPCORE_FROM_UTF8(QT_TRANSLATE_NOOP("Units", "N m²/kg²")),
31  QT_TR_NOOP("Gravitation constant"), gravitationConst, setGravitationConst))
32 
33 STEPCORE_META_OBJECT(GravitationForceErrors, QT_TRANSLATE_NOOP("ObjectClass", "GravitationForceErrors"), QT_TR_NOOP("Errors class for GravitationForce"), 0,
34  STEPCORE_SUPER_CLASS(ObjectErrors),
35  STEPCORE_PROPERTY_RW(double, gravitationConstVariance, QT_TRANSLATE_NOOP("PropertyName", "gravitationConstVariance"), STEPCORE_FROM_UTF8(QT_TRANSLATE_NOOP("Units", "N m²/kg²")),
36  QT_TR_NOOP("Gravitation constant variance"), gravitationConstVariance, setGravitationConstVariance))
37 
38 STEPCORE_META_OBJECT(WeightForce, QT_TRANSLATE_NOOP("ObjectClass", "WeightForce"), QT_TR_NOOP("Weight force"), 0,
39  STEPCORE_SUPER_CLASS(Item) STEPCORE_SUPER_CLASS(Force),
40  STEPCORE_PROPERTY_RW(double, weightConst, QT_TRANSLATE_NOOP("PropertyName", "weightConst"), STEPCORE_FROM_UTF8(QT_TRANSLATE_NOOP("Units", "m/s²")), QT_TR_NOOP("Weight constant"),
41  weightConst, setWeightConst))
42 
43 STEPCORE_META_OBJECT(WeightForceErrors, QT_TRANSLATE_NOOP("ObjectClass", "WeightForceErrors"), QT_TR_NOOP("Errors class for WeightForce"), 0,
44  STEPCORE_SUPER_CLASS(ObjectErrors),
45  STEPCORE_PROPERTY_RW(double, weightConstVariance, QT_TRANSLATE_NOOP("PropertyName", "weightConstVariance"), STEPCORE_FROM_UTF8(QT_TRANSLATE_NOOP("Units", "m/s²")),
46  QT_TR_NOOP("Weight constant variance"), weightConstVariance, setWeightConstVariance))
47 
48 GravitationForce* GravitationForceErrors::gravitationForce() const
49 {
50  return static_cast<GravitationForce*>(owner());
51 }
52 
53 WeightForce* WeightForceErrors::weightForce() const
54 {
55  return static_cast<WeightForce*>(owner());
56 }
57 
58 GravitationForce::GravitationForce(double gravitationConst)
59  : _gravitationConst(gravitationConst)
60 {
61  gravitationForceErrors()->setGravitationConstVariance(
62  square(Constants::GravitationalError));
63 }
64 
65 void GravitationForce::calcForce(bool calcVariances)
66 {
67  const BodyList::const_iterator end = world()->bodies().end();
68  for(BodyList::const_iterator b1 = world()->bodies().begin(); b1 != end; ++b1) {
69  if(!(*b1)->metaObject()->inherits<Particle>()) continue;
70  for(BodyList::const_iterator b2 = b1+1; b2 != end; ++b2) {
71  if(!(*b2)->metaObject()->inherits<Particle>()) continue;
72  Particle* p1 = static_cast<Particle*>(*b1);
73  Particle* p2 = static_cast<Particle*>(*b2);
74 
75  Vector2d r = p2->position() - p1->position();
76  double rnorm2 = r.squaredNorm();
77  Vector2d force = _gravitationConst * p1->mass() * p2->mass() * r / (rnorm2*sqrt(rnorm2));
78  p1->applyForce(force);
79  force = -force;
80  p2->applyForce(force);
81 
82  if(calcVariances) {
83  // XXX: CHECKME
84  ParticleErrors* pe1 = p1->particleErrors();
85  ParticleErrors* pe2 = p2->particleErrors();
86  Vector2d rV = pe2->positionVariance() + pe1->positionVariance();
87  Vector2d forceV = force.cwise().square() .cwise()* (
88  Vector2d(gravitationForceErrors()->_gravitationConstVariance / square(_gravitationConst) +
89  pe1->massVariance() / square(p1->mass()) +
90  pe2->massVariance() / square(p2->mass())) +
91  Vector2d(rV[0] * square(1/r[0] - 3*r[0]/rnorm2) + rV[1] * square(3*r[1]/rnorm2),
92  rV[1] * square(1/r[1] - 3*r[1]/rnorm2) + rV[0] * square(3*r[0]/rnorm2)));
93  pe1->applyForceVariance(forceV);
94  pe2->applyForceVariance(forceV);
95  }
96  }
97  }
98 }
99 
100 WeightForce::WeightForce(double weightConst)
101  : _weightConst(weightConst)
102 {
103  weightForceErrors()->setWeightConstVariance(
104  square(Constants::WeightAccelError));
105 }
106 
107 void WeightForce::calcForce(bool calcVariances)
108 {
109  Vector2d g(0., -_weightConst);
110 
111  const BodyList::const_iterator end = world()->bodies().end();
112  for(BodyList::const_iterator b1 = world()->bodies().begin(); b1 != end; ++b1) {
113  if((*b1)->metaObject()->inherits<Particle>()) {
114  Particle* p1 = static_cast<Particle*>(*b1);
115  p1->applyForce(g*p1->mass());
116  if(calcVariances) {
117  ParticleErrors* pe1 = p1->particleErrors();
118  Vector2d forceV(0., square(_weightConst)*pe1->massVariance()+
119  square(p1->mass())*weightForceErrors()->weightConstVariance());
120  pe1->applyForceVariance(forceV);
121  }
122  } else if((*b1)->metaObject()->inherits<RigidBody>()) {
123  RigidBody* rb1 = static_cast<RigidBody*>(*b1);
124  rb1->applyForce(g*rb1->mass(), rb1->position());
125  if(calcVariances) {
126  RigidBodyErrors* rbe1 = rb1->rigidBodyErrors();
127  Vector2d forceV(0., square(_weightConst)*rbe1->massVariance()+
128  square(rb1->mass())*weightForceErrors()->weightConstVariance());
129  rbe1->applyForceVariance(g*rb1->mass(), rb1->position(),
130  forceV, rbe1->positionVariance());
131  }
132  }
133  }
134 }
135 
136 } // namespace StepCore
137 
StepCore::Particle::mass
double mass() const
Get mass of the particle.
Definition: particle.h:138
StepCore::RigidBody::applyForce
void applyForce(const Vector2d &force, const Vector2d &position)
Apply force (and torque) to the body at given position (in World coordinates)
Definition: rigidbody.cc:170
StepCore::ParticleErrors::massVariance
double massVariance() const
Get mass variance.
Definition: particle.h:77
rigidbody.h
RigidBody class.
StepCore::World::bodies
const BodyList & bodies() const
Get list of all items (not including sub-items) in the World.
Definition: world.h:427
StepCore::RigidBodyErrors::massVariance
double massVariance() const
Get mass variance.
Definition: rigidbody.h:99
StepCore::WeightForceErrors::weightForce
WeightForce * weightForce() const
Get owner as WeightForce.
StepCore::WeightForce::WeightForce
WeightForce(double weightConst=Constants::WeightAccel)
Constructs WeightForce.
Definition: gravitation.cc:100
StepCore::GravitationForceErrors::setGravitationConstVariance
void setGravitationConstVariance(double gravitationConstVariance)
Set gravitationConst variance.
Definition: gravitation.h:54
StepCore::Vector2d
Eigen::Vector2d Vector2d
Two-dimensional vector with double components.
Definition: vector.h:29
StepCore::GravitationForce::GravitationForce
GravitationForce(double gravitationConst=Constants::Gravitational)
Constructs GravitationForce.
Definition: gravitation.cc:58
StepCore::RigidBody::position
const Vector2d & position() const
Get position of the center of mass of the body.
Definition: rigidbody.h:160
StepCore::ParticleErrors::applyForceVariance
void applyForceVariance(const Vector2d &forceVariance)
Increment force variance.
Definition: particle.h:73
StepCore::RigidBodyErrors::applyForceVariance
void applyForceVariance(const Vector2d &force, const Vector2d &position, const Vector2d &forceVariance, const Vector2d &positionVariance)
Apply force (and torque) variance to the body at given position (in World coordinates) ...
Definition: rigidbody.cc:177
StepCore::STEPCORE_SUPER_CLASS
STEPCORE_SUPER_CLASS(CollisionSolver)
StepCore::RigidBody
Rigid body.
Definition: rigidbody.h:144
StepCore::Particle::particleErrors
ParticleErrors * particleErrors()
Get (and possibly create) ParticleErrors object.
Definition: particle.h:164
StepCore::STEPCORE_FROM_UTF8
setAngleVariance setAngularVelocityVariance STEPCORE_FROM_UTF8(QT_TRANSLATE_NOOP("Units","rad/s²"))
StepCore::Item::world
World * world() const
Get pointer to World in which this object lives.
Definition: world.h:91
StepCore::QT_TRANSLATE_NOOP
QT_TRANSLATE_NOOP("ObjectClass","GJKCollisionSolver")
StepCore::WeightForce::_weightConst
double _weightConst
Definition: gravitation.h:167
StepCore::RigidBody::mass
double mass() const
Get mass of the body.
Definition: rigidbody.h:208
StepCore::Constants::GravitationalError
static const double GravitationalError
Error of newtonian constant of gravitation.
Definition: constants.h:53
StepCore::GravitationForce::_gravitationConst
double _gravitationConst
Definition: gravitation.h:102
StepCore::WeightForceErrors::WeightForce
friend class WeightForce
Definition: gravitation.h:128
StepCore::ParticleErrors::positionVariance
const Vector2d & positionVariance() const
Get position variance.
Definition: particle.h:52
StepCore::QT_TR_NOOP
QT_TR_NOOP("Errors class for CoulombForce")
StepCore::STEPCORE_PROPERTY_RW
STEPCORE_PROPERTY_RW(double, depth, QT_TRANSLATE_NOOP("PropertyName","depth"), QT_TRANSLATE_NOOP("Units","J"), QT_TR_NOOP("Potential depth"), depth, setDepth) STEPCORE_PROPERTY_RW(double
StepCore::GravitationForce::gravitationForceErrors
GravitationForceErrors * gravitationForceErrors()
Get (and possibly create) GravitationForceErrors object.
Definition: gravitation.h:96
StepCore::WeightForceErrors::setWeightConstVariance
void setWeightConstVariance(double weightConstVariance)
Set weightConst variance.
Definition: gravitation.h:123
StepCore::Particle::applyForce
void applyForce(const Vector2d &force)
Apply force to the body.
Definition: particle.h:135
StepCore::RigidBodyErrors
Errors object for RigidBody.
Definition: rigidbody.h:37
StepCore::Particle
Particle with mass.
Definition: particle.h:103
StepCore::WeightForce::weightForceErrors
WeightForceErrors * weightForceErrors()
Get (and possibly create) WeightForceErrors object.
Definition: gravitation.h:161
StepCore::WeightForce::calcForce
void calcForce(bool calcVariances)
Calculate force.
Definition: gravitation.cc:107
StepCore::Constants::WeightAccelError
static const double WeightAccelError
Error of standard acceleration of gravity (free fall on Earth)
Definition: constants.h:68
particle.h
Particle and ChargedParticle classes.
StepCore::Particle::position
const Vector2d & position() const
Get position of the particle.
Definition: particle.h:117
StepCore::STEPCORE_META_OBJECT
STEPCORE_META_OBJECT(CollisionSolver, QT_TRANSLATE_NOOP("ObjectClass","CollisionSolver"),"CollisionSolver", MetaObject::ABSTRACT, STEPCORE_SUPER_CLASS(Object), STEPCORE_PROPERTY_RW(double, toleranceAbs, QT_TRANSLATE_NOOP("PropertyName","toleranceAbs"), STEPCORE_UNITS_1, QT_TR_NOOP("Allowed absolute tolerance"), toleranceAbs, setToleranceAbs) STEPCORE_PROPERTY_R_D(double, localError, QT_TRANSLATE_NOOP("PropertyName","localError"), STEPCORE_UNITS_1, QT_TR_NOOP("Maximal local error during last step"), localError)) STEPCORE_META_OBJECT(GJKCollisionSolver
StepCore::GravitationForce::calcForce
void calcForce(bool calcVariances)
Calculate force.
Definition: gravitation.cc:65
StepCore::ObjectErrors::owner
Item * owner() const
Get the owner of ObjectErrors.
Definition: world.h:58
StepCore::WeightForceErrors::weightConstVariance
double weightConstVariance() const
Get weightConst variance.
Definition: gravitation.h:121
gravitation.h
GravitationForce and WeightForce classes.
StepCore::RigidBodyErrors::positionVariance
const Vector2d & positionVariance() const
Get position variance.
Definition: rigidbody.h:52
StepCore::square
T square(T v)
Definition: util.h:30
StepCore::ParticleErrors
Errors object for Particle.
Definition: particle.h:38
StepCore::RigidBody::rigidBodyErrors
RigidBodyErrors * rigidBodyErrors()
Get (and possibly create) RigidBodyErrors object.
Definition: rigidbody.h:261
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:43:06 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

step/stepcore

Skip menu "step/stepcore"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Modules
  • Related Pages

kdeedu API Reference

Skip menu "kdeedu API Reference"
  • Analitza
  •     lib
  • kalgebra
  • kalzium
  •   libscience
  • kanagram
  • kig
  •   lib
  • klettres
  • kstars
  • libkdeedu
  •   keduvocdocument
  • marble
  • parley
  • rocs
  •   App
  •   RocsCore
  •   VisualEditor
  •   stepcore

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal