Table of Contents

Parallelogram Rule for Addition of Forces


\begin{tikzpicture}

  % grid
  \draw[help lines] (-4,-4) grid (4,4);
  
  % mass
  \node [square,minimum size=20mm] at (0, 0) [draw] (O) [lightgray,fill,text=black] node [anchor=south east] {$O$};
  
  % coordinates
  \coordinate (O) at (0,0);
  \drawpoint{O}{.5mm}{black}
  \coordinate (F1) at (3,2.5);
  \coordinate (F2) at (-0.5,-3);
  \coordinate (YM1) at (0, -4);
  \coordinate (YM2) at (2.5,-4);
  \coordinate (YM3) at (3,-4);
  
  % forces
  \draw [>=latex,draw=blue,fill=blue,->] (0,0) -- (F1) node[anchor=south east] {$A$};
  \draw [>=latex,draw=blue,fill=blue,->] (0,0) -- (F2) node[anchor=south east] {$B$};
  
  % guides
  \draw [dotted,black] (O) -- (0,-4);
  \draw [dotted,black] (F1) -- (3,-4);
  \draw [dotted,black] (F2) -- (4,-3);
  
  % angles
  \markangle{O}{F2}{YM1}{7mm}{9mm}{$\alpha$}{red}{west}
  \markangle{F1}{YM2}{YM3}{7mm}{9mm}{$\alpha$}{red}{west}
  
  % paralleles
  \draw [densely dashed,black,name path=f1 parallel] (F1) -- (2.5,-4);
  \draw [densely dashed,black,name path=f2 parallel] (F2) -- (4,0);
  \draw [densely dashed,black,name path=vector line] (F1) -- (F2);
  
  % intersection resultant
  \path [name intersections={of = f1 parallel and f2 parallel}];
  \coordinate (R) at (intersection-1);
  \drawpoint{R}{.5mm}{black}
  
  % resultant
  \draw [>=latex,draw=green,fill=blue,->,name path=resultant line] (0,0) -- (R) node[anchor=south east] {$F$};
  
  % intersection vectors
  \path [name intersections={of = vector line and resultant line}];
  \coordinate[label={[black]above:$M$}] (M) at (intersection-1);
  \drawpoint{M}{.5mm}{black}

\end{tikzpicture}

Suppose we have a coordinate system with two points $A=(A_{x}, A_{y}, A_{z})$ and $B=(B_{x}, B_{y}, B_{z})$ and the origin $O=(O_{x}, O_{y}, O_{z})$, then the length of the vector $\overrightarrow{OA}$ defines the magnitude of the force $F_{1}$ given by the scalar value of $F_{1}$:

\begin{eqnarray*}
|F_{1}|&=&\sqrt{(A_{x}-O_{x})^{2}+(A_{y}-O_{y})^2+(A_{z}-O_{z})^2}
\end{eqnarray*}

symmetrically the length of the vector $\overrightarrow{OA}$ defines the magnitude of the force $F_{2}$ given by the scalar value of $F_{2}$:

\begin{eqnarray*}
|F_{2}|&=&\sqrt{(B_{x}-O_{x})^{2}+(B_{y}-O_{y})^2+(B_{z}-O_{z})^2}
\end{eqnarray*}

The sum of the two forces $F_{1}$ and $F_{2}$ applied in the point-mass $O$ can be computed from the sum of the segments that define them.

Let $F_{1}=A-O$ and $F_{2}=B-O$, then the sum of the two vectors is:

\begin{eqnarray*}
F_{resultant}&=&F_{1} + F_{2} \\
&=& A - O + B - O \\
&=& 2 * (\frac{A+B}{2}-O) \\
&=& 2 * (M-O)
\end{eqnarray*}

where $M$ is the midpoint of the segment $\overline{AB}$. Thus the resulting force $F$ is:

\begin{eqnarray*}
\overrightarrow{F}&=&\overrightarrow{FO}
\end{eqnarray*}

The scalar value of $F$ is given by:

\begin{eqnarray*}
|F|&=&\sqrt{(F_{x}-O_{x})^{2}+(F_{y}-O_{y})^2+(F_{z}-O_{z})^2}
\end{eqnarray*}

Note that in the illustration shows an ideal case where the $z$ component is zero and forces are applied from the origin (point-mass force).

Analytical

In Euclidian space $\mathbb{R}^3$ the resultant force $\overrightarrow{F}$ can be calculated as $\overrightarrow{F_{1}}+\overrightarrow{F_{2}}$ such that:

\begin{eqnarray*}
\overrightarrow{F}&=&(A_{x}+B_{x})e_{1}+(A_{y}+B_{y})e_{2}+(A_{z}+B_{z})e_{3}
\end{eqnarray*}

where $e$ represents the basis vectors:

\begin{eqnarray*}
e_{1}&=&(1,0,0) \\
e_{2}&=&(0,1,0) \\
e_{3}&=&(0,0,1)
\end{eqnarray*}

this can be generalised to n-dimensional Euclidian space by extending the components of the vectors.

The magnitude of the vector $\overrightarrow{F}$ is given by the scalar $|F|$:

\begin{eqnarray*}
|F|&=&\sqrt{(A_{x}+B_{x})^2+(A_{y}+B_{y})^2+(A_{z}+B_{z})^2}
\end{eqnarray*}

Vector Angle to Axis


\begin{tikzpicture}

  % grid
  \draw[help lines] (-4,-4) grid (4,4);
  
  % coordinates
  \coordinate[label={[black]below left:$O$}] (O) at (0,0);
  \drawpoint{O}{.5mm}{black}
  \coordinate (F1) at (1.3,1.88);
  \coordinate[label={[black]below:$P_{x}$}] (F1X) at (1.3,0);
  \drawpoint{F1X}{.5mm}{black}  
  \coordinate (F1Y) at (0,1.88);
  \drawpoint{F1Y}{.5mm}{black};
  
  % forces
  \draw [>=latex,draw=blue,fill=blue,->] (0,0) -- (F1) node[anchor=south east] {$A$};
  
  % guides
  \draw [dashed,black] (O) -- (0,-3);
  \draw [solid,black,->] (O) -- (0,3) node[anchor=south] {$y$};
  \draw [solid,black,->] (O) -- (3,0) node[anchor=south] {$x$};
  \draw [dashed,black] (O) -- (-3,0);
  
  % projections
  \draw [dashed,black] (F1) -- (1.3,0);
  \draw [dashed,black] (F1) -- (0,1.88);
  
  % angles
  \markangle{O}{F1}{F1X}{7mm}{9mm}{$\alpha$}{red}{west}
  
  % braces
  \drawbrace{O}{F1X}{2mm}{black}{$a_{x}$}{0}{-4mm}{mirror}

\end{tikzpicture}

For a vector in 2D defined as:

\begin{eqnarray*}
\overrightarrow{OA}&=&a_{x}e_{1} + a_{y}e_{2} + a_{z}e_{3}
\end{eqnarray*}

with the basis vectors:

\begin{eqnarray*}
e_{1}&=&(1,0,0) \\
e_{2}&=&(0,1,0) \\
e_{3}&=&(0,0,0)
\end{eqnarray*}

in the triangle $\widehat{OP_{x}A}$ we can write that:

\begin{eqnarray*}
\cos{\alpha}&=&\frac{a_{x}}{\overline{OA}}
\end{eqnarray*}

due to the right angle formed by $\widehat{OP_{x}A}$. Thus, we can deduce that the angle $\alpha$ (in radians) is:

\begin{eqnarray*}
\alpha&=&\arccos{\frac{a_{x}}{\overline{OA}}}
\end{eqnarray*}

Note that the length of the segment $\overline{OA}$ is given by the magnitude of the vector $\overrightarrow{OA}$ and that $a_{x}$ represents the component of the vector $\overrightarrow{OA}$ on the $x$ axis.

Example

Let us take a real-world scenario. We want to calculate the direction of the wind in terms of bearing (North, South, East, West) and we know that the measured wind vector is:

\begin{eqnarray*}
\overrightarrow{OA}&=&
\begin{pmatrix} 
5 \\
0 \\
0 
\end{pmatrix}e_{1} + 
\begin{pmatrix}
0 \\
8 \\
0
\end{pmatrix}e_{2} +
\begin{pmatrix}
0 \\
0 \\
0 \\
\end{pmatrix}e_{3}
\end{eqnarray*}

For aesthetics, let us presume that the axis $\overline{Oy}$ represents North and that the axis $\overline{Ox}$ represents East (with West and South in the respective inverse sense of the axis). Now we take the vector $\overrightarrow{OA}$ and want to point in the direction of the wind. In order to do that, we perform the calculations above an obtain the angle $\alpha$:

\begin{eqnarray*}
\alpha&=&\arccos{\frac{a_{x}}{\overline{OA}}} \\
&=&\arccos{\frac{5}{ \sqrt{(5-0)^{2}+(8-0)^2+(0-0)^2} }} \\
&\approx&\arccos{\frac{5}{9.433}} \\
&\approx&1.56549631\mbox{ }\text{radians}
\end{eqnarray*}

and converting to degrees, we obtain:

\begin{eqnarray*}
\alpha&\approx&89.69^{\circ}
\end{eqnarray*}

This means that we have to rotate an arrow, or a pointer, starting from the $\overline{Ox}$ axis, approximately $89.69^{\circ}$ towards the axis that we have decided represents North. The result makes sense if you think about it, because the vector $\overrightarrow{OA}$ is in the first trigonometric quadrant (more than zero and less than 90 degrees). So, interpreting the result, the wind direction is approximately towards the North-North East.

Unit Vector Between Two Points

Given two points in cartesian space $A(x,y,z)$ and $B(x,y,z)$, we want to find the unit vector between those points. First, we establish from which point to which point the direction should be.

For example's sake, let us assume that we want to find the vector that points from $A$ to $B$. In that case, the vector is:

\begin{eqnarray*}
$\overrightarrow{AB}$ &=& B - A
\end{eqnarray*}

In order to find the unit vector, we dive the vector $\overrightarrow{AB}$ with its magnitude. In other words:

\begin{eqnarray*}
$\overrightarrow{U_{AB}}$ &=& \frac{\overrightarrow{AB}}{|\overrightarrow{AB}|}
\end{eqnarray*}

In order to compute $\overrightarrow{AB}$ we can use the cartesian notation of vectors using matrices, such that:

\begin{eqnarray*}
$\overrightarrow{AB}$ &=& \begin{pmatrix} 
x_{A} \\
y_{A} \\
z_{A} 
\end{pmatrix} -
\begin{pmatrix} 
x_{B} \\
y_{B} \\
z_{B} 
\end{pmatrix}
\end{eqnarray*}

and the magnitude of the vector $\overrightarrow{AB}$ is given by the scalar $|\overrightarrow{AB}|$:

\begin{eqnarray*}
|AB|&=&\sqrt{(A_{x}+B_{x})^2+(A_{y}+B_{y})^2+(A_{z}+B_{z})^2}
\end{eqnarray*}

Example

Using Second Life, Suppose we have two arbitrarily disposed masses in space, the red ball and the cyan ball:

and that we want to apply an impulse to the red ball, such that it travels towards the cyan ball.

In order to propel the red ball towards the the cyan ball, we apply the formulas above as a script inside the red ball. We perform the following calculations in succession:

// velocity in m/s
float velocity = 1;
 
default {
    state_entry() {
        // scan for an object named cyan
        llSensor("cyan", "", ACTIVE|PASSIVE, 96, TWO_PI);
    }
 
    // when the cyan ball is found
    sensor(integer num) {
        // calculate the vector between the cyan ball and the red ball
        vector f = llDetectedPos(0) - llGetPos();
        // calculate the unit vector
        vector u = (f)*1/llVecMag(f);
        // apply an impulse to the red ball
        llSetVelocity(velocity * u, FALSE);
    }
}

The unit vector u gives us the direction and the scalar velocity gives us the speed. The reason for having an unit vector is that we leave it up to the scalar multiplier u to give us the velocity.

Universal Attraction of Masses

The law for universal attraction of masses is given by the formula:

\begin{eqnarray*}
F &=& k * \frac{m * M}{d^{2}}  
\end{eqnarray*}

where:

Simulating in Second Life

As a small application of our cyan and red balls, let us rename both balls to mass and size them so that their sizes are equal. Under these constraints, we can use the following script, placed in both balls to illustrate the universal attraction of masses:

default {
    state_entry() {
        // scan for an object named mass
        llSensorRepeat("mass", "", ACTIVE|PASSIVE, 96, TWO_PI, 1.175494351E-38);
    }
 
    // when the cyan ball is found
    sensor(integer num) {
        // calculate the vector between the cyan ball and the red ball
        vector f = llDetectedPos(0) - llGetPos();
        // calculate the unit vector
        vector u = (f)*1/llVecMag(f);
        // get the distance between the cyan ball and the red ball
        float d = llVecDist(llDetectedPos(0), llGetPos());
        // the force is equal to the directional vector times the 
        // mass squared and divided by the distance between the masses
        llSetForce(u * llPow(llGetMass(), 2)/d, FALSE);
    }
}

Since we now know how to use the directional vector u from the previous section, we can now set the force as the unit vector u times the force. Since we have said that we will consider the masses to be equal, we can just square the masses instead of doing $m * M$ and then divide with the distance between them.

The masses do not necessarily have to be the same, however, in Second Life, it is impossible to detect the mass of an object. A different restriction is the force is applied every $\approx 0.05s$ which is roughly the resolution that events in Second Life are capable of.

Orbits

One consequence of the universal law of attraction is the creation of orbits.

Given two masses, the following observations can be made initially:

In the real world, given the lack of constant acceleration, the orbit decays. This can be explained by looking at the forces exerted upon the orbiting object.


\begin{tikzpicture}

  % grid
  \draw[help lines] (-3,-3) grid (3,3);
  
  % origin
  \draw[red, line width=.1mm] (-0.1,-0.1) -- (0.1,0.1)
    (0.1,-0.1) -- (-0.1,0.1);
  \coordinate[label={[red]above left:$O$}] (O) at (0,0);
  \coordinate[label={[red]above right:$A$}] (A) at ({0.05+cos(30)},{0.05+2*cos(30)});
  \coordinate (C) at (2,1);
  \coordinate (D) at ({cos(30)-0.5},{2*cos(30)-1});
  \coordinate (R) at (1.4, 0.1);
  
  \drawpoint{A}{.5mm}{red};
  
  % alpha 
  \markangle{A}{O}{R}{3mm}{3mm}{$\alpha$}{cyan}{north}
  
  % circle 
  \draw [black, dotted] (0,0) circle [radius=2];
  \draw [black, dotted] (A) -- (O);
  \draw [blue,->] (A) -- (C) node [label={[blue]above right:$\overrightarrow{F_{c}}$}];
  \draw [blue,->] (A) -- (D) node [label={[blue]above left:$\overrightarrow{F_{a}}$}];
  \draw [blue,->] (A) -- (R) node [label={[blue]right:$\overrightarrow{R}$}];
  \draw [black, dotted] (R) -- (C);
  \draw [black, dotted] (R) -- (D);
  
  %\drawbrace{O}{A}{2mm}{blue}{$r$}{-4mm}{0}{};
  
\end{tikzpicture}

Suppose that the object is in $A$ and that the initial force $\overrightarrow{F_{c}}$ acts upon the object, that the force due to the universal attraction of masses is $\overrightarrow{F_{a}}$ and that the resultant is $\overrightarrow{R}$. In the triangle formed by $\widehat{\overrightarrow{F_{a}}A\overrightarrow{R}}$ we can write:

\begin{eqnarray*}
\tan{\alpha} &=& \frac{|F_{c}|}{|F_{a}|} 
\end{eqnarray*}

and thus:

\begin{eqnarray*}
\alpha &=& \arctan{\frac{|F_{c}|}{|F_{a}|}} 
\end{eqnarray*}

and if the initial force $\overrightarrow{F_{c}}$ is gradually diminished we observe that the angle $\alpha$ becomes smaller such that eventually:

\begin{eqnarray*}
\lim_{F_{c} \mapsto 0}\alpha &=& \lim_{F_{c} \mapsto 0}{\arctan{\frac{|F_{c}|}{|F_{a}|}}} \\
&=& 0
\end{eqnarray*}

the angle will be $0$, thus pulling the object towards the object $O$. Object $A$'s orbit will decay and eventually collide with object $O$

Centripetal Force


\begin{tikzpicture}

  % grid
  \draw[help lines] (-3,-3) grid (3,3);
  
  % origin
  \draw[red, line width=.1mm] (-0.1,-0.1) -- (0.1,0.1)
    (0.1,-0.1) -- (-0.1,0.1);
  \coordinate[label={[red]above left:$O$}] (O) at (0,0);
  \coordinate[label={[red]above right:$A$}] (A) at ({0.05+cos(30)},{0.05+2*cos(30)});
  \coordinate (C) at (2,1);
  \coordinate (D) at ({cos(30)-0.5},{2*cos(30)-1});
  \coordinate (R) at (1.4, 0.1);
  
  \drawpoint{A}{.5mm}{red};
  
  % alpha 
  %\markangle{A}{O}{R}{3mm}{3mm}{$\alpha$}{cyan}{north}
  
  % circle 
  \draw [black, dotted] (0,0) circle [radius=2];
  \draw [black, dotted] (A) -- (O);
  \draw [blue,->] (A) -- (C) node [label={[blue]above right:$\overrightarrow{v}$}];
  \draw [blue,->] (A) -- (D) node [label={[blue]above left:$\overrightarrow{F_{c}}$}];
  %\draw [blue,->] (A) -- (R) node [label={[blue]right:$\overrightarrow{R}$}];
  %\draw [black, dotted] (R) -- (C);
  %\draw [black, dotted] (R) -- (D);
  
  %\drawbrace{O}{A}{2mm}{blue}{$r$}{-4mm}{0}{};
  
\end{tikzpicture}

The magnitude of the centripetal force of an object of mass $m$ moving at a tangential speed $\overrightarrow{v}$ along a path with radius of $r$ is:

\begin{eqnarray*}
F_{c}&=&ma_{c} \\
&=&\frac{mv^{2}}{r}
\end{eqnarray*}

in terms of angular velocity $\omega$, the equation can be written as:

\begin{eqnarray*}
F_{c}&=&mr\omega^{2}
\end{eqnarray*}

where, in two dimensions:

\begin{eqnarray*}
\omega = \frac{d\Phi}{dt}
\end{eqnarray*}

and $\omega$ is the change of angle in time.

Simulating in Second Life

Given a central pole, and a ball that must rotate around the pole at a given velocity (here $0.1 \frac{m}{s}$), the following script will:

float velocity = 0.1;
 
default {
    state_entry() {
        // scan for an object named mass
        llSensorRepeat("pole", "", ACTIVE|PASSIVE, 96, TWO_PI, 1.175494351E-38);
    }
 
    // when the object is found
    sensor(integer num) {
        // get the position of the object
        vector oPos = llDetectedPos(0);
        // get our position
        vector mPos = llGetPos();
        // calculate the vector between the object and us
        vector f = <oPos.x, oPos.y, 0> - <mPos.x, mPos.y, 0>;
        // calculate the unit vector towards the object
        vector u = (f)*1/llVecMag(f);
        // calcualte the unit vector rotated by 90 (tangential)
        vector r = u * llEuler2Rot(<0, 0, 90> * DEG_TO_RAD);
        // get the distance between the object and us in the plane xOy
        float d = llVecDist(<oPos.x, oPos.y, 0>, <mPos.x, mPos.y, 0>);
        // compute the vector for the centripetal force
        vector fc = u * (llGetMass() * llPow(velocity,2)/d);
        // compute the vector for the velocity
        vector v = r * velocity;
        // set the centripetal force
        llSetForce(fc, FALSE);
        // set the tangential velocity
        llSetVelocity(v, FALSE);
 
    }
}

The velocity is favourably selected as being small $0.01 \frac{m}{s}$ in order to counter the effect of the application of the centripetal force fc every $\approx 0.05s$. In reality, the centripetal force $F_{c}$ is applied all the time and not in $\approx 0.05s$ intervals, which, in the simulation's case, makes the ball gradually spiral away from the pole.