Proof of Descartes Theorem on Polyhedron


On polyhedron, there’s Descartes Theorem besides Euler’s Formula.

Thinking of Polyhedron

Polyhedron is rounded by faces, whatever faces’ figure is. It means there’s a theorem. Now, let’s investigate regular polyhedrons.

About regular polyhedron, the summation of internal angle that gathers one vertex must be less than 360 degrees. If it equals to 360 degrees, vertex doesn’t exist.

Example

Calculate about regular tetrahedron.

A face of it is regular triangle and one of its angles is 60 degrees. At 1 vertex of tetrahedron, 3 faces gather, so summation of angle degrees gathering at one vertex is

\[ 60 times 3 = 180 . \]

Difference from space, 360 degree, is

\[ 360 – 180 = 180 . \]

The number of tetrahedron vertexes is 4, so sum of angle deficit for all faces are

\[ 180 times 4 = 720 . \]

I calculated such angle deficit for all regular polyhedron. The result is below.

table of regular polyhedron angle deficit
Sum of internal angle on one vertex Difference from 360 degrees (angle deficit) Sum of angle deficit for all faces
regular tetrahedron 180 degrees 180 degrees 720 degrees
regular hexahedron 270 degrees 90 degrees 720 degrees
regular octahedron 240 degrees 120 degrees 720 degrees
regular dodecahedron 324 degrees 36 degrees 720 degrees
regular icosahedron 300 degrees 60 degrees 720 degrees

See, the summation of angle deficit over the polyhedron is 720 degree.

Actually, it is true to every polyhedron. This theorem called Descartes theorem.

Now, let’s prove it.

Proof

Write vertex number, edge number and face number of a polyhedron as \( V \) , \( E \) , \( F \) . As I wrote on Think about Euler’s Formula, the following equation is true (Euler’s Formula).

\[ V – E + F = 2 \]

Now, calculate summation of angle deficit. It is explained as ( 360 degree ) × ( vertex count ) – ( sum of internal angle for all faces ).

\[ (360 \textrm{degree} ) \times ( \textrm{vertex count} ) = 360 \times V \]

is clear from definition of \( V \) .

Calculate summation of internal angle for each face.

The summation of internal angle for a face

Write edge number of a face as \( e \) . The summation of internal angle on this face is

\[ (e – 2) \times 180 . \]

Calculate summation of the above value for all faces.

The summation of internal angle for all faces

With \( e \), it is written as the following.

\begin{eqnarray} & & \sum \left\{ (e – 2) times 180 \right\} & = & 180 ( \sum e – \sum 2 ) \end{eqnarray}

\( \sum \) means summation.

\( \sum e \) is the summation of edge count for all faces. It means count twice for each edge, so \( \sum e = 2 E \) . Calculate summation for each face, then \( \sum 2 = 2 F \) .

Now, the value we want to know is

\begin{eqnarray} & & 180 ( sum e – sum 2 ) & = & 180 ( 2 E – 2 times F ) \\ & = & 360 ( E – F ) . \end{eqnarray}

Then, the sum of angle deficit over polyhedron is

\begin{eqnarray} & & 360 V – \left\{ 360 ( E – F ) \right\} & = & 360 ( V – E + F) \\ & = & 360 \times 2 \\ & = & 720 . \end{eqnarray}

Think about Euler’s Formula on polyhedron


Let’s think about Euler’s formula in polyhedron.

Euler’s Formula

On polyhedron, the following equation is valid.

(vertex count) – (edge count) + (face count) = 2

This formula is also true to plane figure.

Now, let’s think about this formula on plane figure. Polyhedron can be projected to plane figure, so it is true to polyhedron when it’s true to plane figure.

men

Project Polyhedron to Plane Figure

Polyhedron can be projected to plane figure.

Left is a tetrahedron, and it can be projected to plane figure on the right side. 4 faces of tetrahedron becomes 3 triangle and other, rounding area. Plane is divided into 4 area by vertex and edge.

Proof

Now, think about plain figure composed vertex, edge and face. Vertex is edge’s start and end point. All edge is connected only at vertex, don’t cross.

Think in mathematical induction. Define \( V \) as vertex count , \( E \) as edge count , \( F \) as face count. The goal is \( V – E + F = 2 \) .

Case \( E = 1 \)

Edge \( E \) is 1, face \( F \) is 1, Veftex \( V \) is 2, then

\[ V – E + F = 2 – 1 + 1 = 2 . \]

The formula is true.

Case when \( E = k \in \mathbb{N} \)

Suppose \( E_k \) , \( V_k \) , \( F_k \) as \( E \) , \( V \) , \( F \) when \( E = k \) and the formula is true.

\[ V_k – E_k + F_k = 2 \]

\( V_k \) and \( F_k \) is not unique for \( k \), they are values which meet the formula.

Think of adding a new edge. Edges are connected on vertexes, so new edge should be connected to already existing edges on start or end point

When the new edge connect on one point

Vertex count increases by one then \( V = V_k + 1 \). Edge count increases by one then \( E = E_k + 1 \) . Face count doesn’t change so \( F = F_k \) .

\begin{array}{cl} & V – E + F \\ = & ( V_k + 1 ) – ( E_k + 1 ) + F_k \\ = & V_k – E_k + F_k \\ = & 2 \end{array}

When the new edge connect on two point

Without the new edge, edges are connected so one side or the other is rounded by edges. Then, draw the new edge, and the face count increases by one.

Now, vertex count doesn’t change, \( V = V_k \), edge count increases by one, \( E = E_k + 1 \) , face count increases by one, \( F = F_k + 1 \) . Of course, in the case that start and end point is the same.

\begin{array}{cl} & V – E + F \\ = & V_k – ( E_k + 1 ) + ( F_k + 1 ) \\ = & V_k – E_k + F_k \\ = & 2 \end{array}

From the above, when the formula is true to \( E = k \in \mathbb {N} \), it is also true to \( E = k + 1 \) .

Above all, the formula is always true.

With this Euler’s Formula, we can prove Descartes theorem. I wrote the detail on Prove Descartes Theorem on Polyhedron.


haskell split string by comma, into list


I’ll introduce to you, how to split string into list by comma, make "a,b,c" to ["a", "b", "c"].

Background

You know that there are some function like splitOn in Data.List.Split module, but import Data.List.Split didn’t work on Ideone. So, I, a haskell beginner, thought how to do it without other modules.

Split by comma

The following code do it. It split string, [Char] only by comma.

split "a,b,c" outputs ["a", "b", "c"].

Split by any delimiter

You can specify any delimiter with the following. The delimiter should be a Char.

split ' ' "a b c" outputs ["a", "b", "c"].


A Life Summary of an Gypsy