Jump to content

User:Smcgruer: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Smcgruer (talk | contribs)
Blanked the page
Smcgruer (talk | contribs)
Undid revision 556109507 by Smcgruer (talk)
 
Line 1: Line 1:
''(Note to the marker: My topic, Hexagonal Coordinate Systems, is technically a mathematical issue with a practical application in Computer Vision. Since the course is about vision, I have chosen to keep this page primarily focused around that. In a real article it would be preferable to keep the main page solely for mathematical definitions, and have it's use in vision processing as another page.)''


<big>'''Hexagonal Coordinate Systems'''</big>

A hexagonal coordinate system is formed by placing a [[hexagonal lattice]] over a 2D plane, forming a [[coordinate system]] where each hexagon (or 'tile') can be uniquely specified in some manner. Although the coordinate system can be continuous, the discrete case is more common in [[computer vision|vision processing]] and [[computer games]], where a hexagon usually represents a pixel or map space respectively. The main advantages of hexagonal coordinates over the traditional [[Cartesian coordinate system|Cartesian]] approach are the consistent distance between a hexagon and all of it’s neighbours, and the ability of hexagons to neatly represent natural shapes such as curves.

== History ==

The use of hexagonal coordinate systems in vision processing first occurred in 1963{{citation needed}}, in the [[ILLIAC#ILLIAC_III|Illinois Pattern Recognition Computer]]<ref>McCormick, Bruce H. ''The Illinois Pattern Recognition Computer - ILLIAC III''. IEEE Transactions on Electronic Computers, 1963.</ref>, where they were referred to as rhombic arrays. However it was not until 1969 that the first work directly relating to hexagonal coordinate systems was published, on the potential benefits of a hexagonal representation of data for pattern matching<ref>Golay, Marcel J. E. ''Hexagonal Parallel Pattern Transformations''. IEEE Transactions on Computers, 1969.</ref>. Since then, hexagonal coordinate systems have surfaced multiple times in academic work, but have never obtained widespread popularity.

== Definitions and Conventions ==

=== Conventions ===

By convention, tiles in a hexagonal coordinate system are laid out edge-to-edge horizontally, along the x-axis. Aligning vertically along the y-axis is sometimes used; most of the definitions and formulae laid out on this page can be adapted to a vertically-aligned system by simply swapping axis parameters. Other alignments are rare, as they complicate most of the mathematics involved in hexagonal coordinate systems.

=== Indexing a Hexagonal Coordinate System ===

[[File:Hexagonal_Coordinates_ZigZag_Columns.svg|thumb|250px|alt=TODO|The effect of transforming the 'zig-zag' axis to a straight axis. Note how the transformation partitions the coordinate system in two.]]

Due to the popular nature of traditional rectangular coordinate systems, a natural approach when defining a hexagonal coordinate system is to attempt to use an [[orthogonal]] set of axes. As having truly orthogonal axes is obviously impossible, a zig-zag column approach is often suggested, where the y-axis alternates direction on each vertical row of tiles. This approach is inherently problematic, as can be seen by transforming the y-axis to a straight line. Examining the effect of this transformation on the super-hexagon triangles, we find that using an approximated y-axis splits the coordinate system into two partitions, based on alternating rows. This complicates geometric calculations, as they must take into account the two partitions. For example, distance calculations become iterative as the two ‘shortest’ paths between the start and end point (in terms of the number of tiles passed through) are not the same length in the coordinate system - the calculation must check which row it is in at each iteration and 'move' accordingly.

[[File:Hexagonal_Coordinates_Skewed_Columns.svg|thumb|250px|alt=TODO|The effect of transforming the skewed-axis to a straight axis.]]

A better approach for indexing hexagonal coordinate systems can be found by altering the traditional view of the y-axis to suit hexagonal tiles. We define the y-axis to be ‘skewed’, rotated 60° from the x-axis. This viewpoint is 'straight' in terms of hexagonal coordinates, as each axis runs through the centre of an edge of the hexagon. Transforming the y-axis back to the traditional viewpoint, as we did before, shows that the super-hexagon triangles are now uniformly represented in the skewed-axis system.

Another approach for indexing hexagonal coordinate systems uses the hexagon’s axes of symmetry, giving three trigonal axes. By convention these are referred to as the x-, y- and z-axes, although it is important to realise that they are distinct from the normal three-dimensional use of these names - the coordinate system still only indexes into a two-dimensional plane. As only two of the three coordinates are required to uniquely specify any hexagon in the coordinate system, one coordinate is redundant; however the use of all three coordinates allows the easy calculation of distances and other geometric functions. Converting between the skewed-axis approach and the three-coordinate approach is straightforward - we simply identify the redundant coordinate and remove it, renaming and shifting the other axes as appropriate.

A final and rather unusual representation for a hexagonal coordinate system is to represent it as a layered system. The layered system is defined recursively, as each layer is composed of a number of tiles from the layer below it. A layer 0 tile is a single hexagon. A layer {{math|''L''}} tile is composed of a layer {{math|''L-1''}} tile and it’s 6 neighbouring tiles. That is, a layer 1 tile is a collection of seven hexagons, a layer 2 tile is a collection of seven layer 1 tiles, and so on. This approach is common in vision processing due to its efficient use of space. There are {{math|7<sup>L</sup>}} tiles in an {{math|''L''}} layer system, and each hexagon in the system can be indexed using an {{math|''L''}}-digit, base 7 number. Starting from the global tile, each digit in an index represents which sub-tile the hexagon belongs to, starting at 0 in the centre and then proceeding from 1 to 6 around the centre tile. For example, consider the hexagon indexed by {{math|24<sub>7</sub>}}. The first digit, 2, indicates that the hexagon is in the second location of the layer 1 tile, and the last digit, 4, indicates that the hexagon is in the fourth location of the layer 0 tile.

As each hexagon is just a number, an image can be stored as a one-dimensional vector. A hexagonal image of L layers with 24-bit colour requires {{math|3 x 7<sup>L</sup>}} bytes. If the hexagonal image was created from an {{math|''M'' x ''N''}} square image with {{math|''M'' {{=}} ''N'' {{=}} 2<sup>m</sup>}}, we can calculate the required number of layers as

:<math>L = m\frac{2 log 2}{log 7} \approx 0.71m.</math>

Aside from its efficient use of space, the hierarchical layering approach also makes the execution of some visual processing algorithms in hexagonal space easier.

=== Extension to N Dimensions ===

As a planar shape, hexagons cannot be represented in three or more dimensions. Therefore, unlike Cartesian or [[polar coordinate]] systems, there is no straightforward extension of hexagonal coordinate systems to higher dimensions.

== Advantages and Issues ==

=== Advantages of Hexagonal Coordinate Systems ===

As stated above, the main reasons for using a hexagonal coordinate system for image processing are hexagons' consistent connection with their neighbours and the ease of representing natural shapes using hexagons. In a normal square-pixel system, a pixel’s neighbours have two different levels of connectivity - they are either 1 pixel away, or <math>\scriptstyle \sqrt{2}</math> pixels. This means that algorithms based on neighbourhood searches either have to ignore this distinction (and lose information) or cope with it somehow (causing increased complexity). Using a hexagonal coordinate system means that each neighbour is exactly 1 pixel away, and so algorithms can treat them all the same. The natural representation of curves in hexagonal coordinate systems allows many visual operations to be performed more easily; examples of edge detection and shape extraction are given below.

In addition to the above, hexagonal lattices also more closely resemble the pattern of photo-receptors in the human eye than square lattices. This means that they may be used when attempting to simulate the visual information provided by the eye to the brain and some of the visual processing performed by the brain on image data, such as simulating saccading<ref>Middleton, Lee., Coghill, George., and Sivaswamy, Jayanthi. ''Saccadic Exploration using a Hexagonal Retina''. Proceedings of the International ICSC Congress on Intelligent Systems and Applications, 2000.</ref>.

=== Potential Issues ===

Despite their advantages, hexagonal coordinate systems are not commonly used in vision processing outside of academic work. A number of reasons have been suggested for the lack of uptake. Firstly, people often find thinking in hexagonal space difficult compared to traditional Cartesian systems, and so are less inclined to use hexagonal coordinate systems. Whether or not this is a real difficulty, or simply something one has to 'get used to' is debated, but in either case it reduces the likelihood of people choosing to use a hexagonal representation of data.

The lack of hardware devices (both input and output) that directly support hexagonal coordinate systems is also an issue. Input images must be converted from a square lattice to a hexagonal one. This may either be done by [[extrapolation]], in which case the resolution of the image is artificially lowered, or by capturing the image at a higher resolution than it will be processed at, which is wasteful. Once the processing has been completed the output image must then be represented on or converted back to a square lattice somehow, which collapses pixels and thus results in a lower output resolution.

== Image Conversion ==

=== Square to Hexagonal Lattices ===

As hardware devices that can directly capture images onto a hexagonal lattice are rare, images usually have to be converted from a square lattice to a hexagonal one. This process is known as ''image re-sampling''. The conversion method depends on how the hexagonal coordinate system is indexed; as we can easily convert between the skewed-axis and 3-coordinate representations, only the skewed-axis method will be shown.

[[File:Hexagonal_tile_distance_to_edge_and_corner.svg|thumb|180px|alt=A hexagon with the distance from the centre to the middle of one edge, and from the centre to a corner shown.|An example hexagon showing the distances from the centre to it's edges and corners.]]

To convert points from a Cartesian coordinate system to a hexagonal system, we must transform the points into hexagonal space, map them to a square lattice, and then convert the square lattice to a hexagonal one. For convenience we define two constants: {{math|''r''}} is the shortest distance from the centre of a hexagon to an edge, and {{math|''s''}} is the distance from the centre of a hexagon to a corner.

Two matrices are used to transform the Cartesian coordinates to hexagonal space, one for each hexagonal axis. For each axis we must describe an [[affine transformation]] from the hexagonal lattice to the square lattice. Starting with the x-axis, we can examine one possible transformation such that every point in a square corresponds to the same x-coordinate in hexagonal space:


:[[File:Cartesian_to_hexagonal_x_affine_transformation.svg|350px|alt=TODO]]


We now need to define the transformation matrix

: <math>M = \begin{bmatrix}A & B \\ C & D\end{bmatrix},</math>

such that {{math|''Mp''<sub>h</sub> {{=}} ''p''<sub>s</sub>}}, where {{math|''p''<sub>h</sub>}} is a point in the hexagonal lattice and {{math|''p''<sub>s</sub>}} is a point in the square lattice. Consider two points in the square lattice: {{math|''(1,0)''}} and {{math|''(0,1)''}}. These correspond to the points {{math|''(0, -s)''}} and {{math|''(r,s/2)''}} in the hexagonal lattice. Therefore, we can form four [[linear equation|linear equations]]:

:<math>\begin{alignat}{9}
A &&\; * &&\; 0 &&\; + &&\; B &&\; * \;&& -s &&\; = \;&& 1 & \\
C &&\; * &&\; 0 &&\; + &&\; D &&\; * \;&& -s &&\; = \;&& 0 & \\
A &&\; * &&\; r &&\; + &&\; B &&\; * &&\; \tfrac{s}{2} &&\; = \;&& 0 & \\
C &&\; * &&\; r &&\; + &&\; D &&\; * &&\; \tfrac{s}{2} &&\; = \;&& 1 &
\end{alignat}</math>

Solving this [[system of linear equations|linear system]] gives us <math>\textstyle A = \frac{1}{2r}</math>, <math>\textstyle B = -\frac{1}{s}</math>, <math>\textstyle C = \frac{1}{r}</math>, and <math>\textstyle D = 0 </math>. Now we compute the hexagonal x-coordinate. This is calculated as

:<math>x_{hex} = \frac{x_s + y_s + n}{w},</math>

where {{math|''(x''<sub>s</sub>, ''y''<sub>s</sub>'')''}} is the transformed point, {{math|''n''}} is the offset needed to map the correct points to {{math|''x'' {{=}} 0}} (in the above example we want {{math|''(-2,0)''}}, {{math|''(-1,0)''}} and {{math|''(0,0)''}} to all map to hex coordinate {{math|''x'' {{=}} 0}}, so {{math|''n'' {{=}} 2}}), and {{math|''w''}} is the 'width' or number of squares wide that a transformed hexagon is.

We now use a similar method for the y-axis. Another affine transformation is examined, such that every point in a square corresponds to the same y-coordinate in hexagonal space.


:[[File:Cartesian_to_hexagonal_y_affine_transformation.svg|350px|alt=TODO]]


Under this transformation the points {{math|''(1,0)''}} and {{math|''(0,1)''}} in the square lattice correspond to the hexagonal coordinates {{math|''(r, s/2)''}} and {{math|''(-r, s/2)''}} respectively. Again we form four linear equations:

:<math>\begin{alignat}{9}
A &&\; * &&\; r &&\; + &&\; B &&\; * \;&& \tfrac{s}{2} &&\; = \;&& 1 & \\
C &&\; * &&\; r &&\; + &&\; D &&\; * \;&& \tfrac{s}{2} &&\; = \;&& 0 & \\
A &&\; * &&\; -r &&\; + &&\; B &&\; * &&\; \tfrac{s}{2} &&\; = \;&& 0 & \\
C &&\; * &&\; -r &&\; + &&\; D &&\; * &&\; \tfrac{s}{2} &&\; = \;&& 1 &
\end{alignat}</math>

Solving this system gives us <math>\textstyle A = \frac{1}{2r}</math>, <math>\textstyle B = -\frac{1}{s}</math>, <math>\textstyle C = -\frac{1}{r}</math>, and <math>\textstyle D = \frac{1}{s}</math>. Finally we compute the hexagonal y-coordinate. This is identical to before:

<math>y_{hex} = \frac{x_s + y_s + n}{w}.</math>


The values of {{math|''r''}} and {{math|''s''}} depend on the chosen mapping scale between the square and hexagonal lattice. Common values are <math>\textstyle r = \frac{1}{2}</math> and <math>\textstyle s = \sqrt{3}</math>. These give the basis functions

:<math>\displaystyle b_1 = (1,0),</math>
:<math>b_2 = (\frac{1}{2}, \frac{\sqrt{3}}{2}).</math>


Note that these basis vectors mean that the horizontal scale is fixed between the square and hexagonal lattice, but that the 'vertical' scale is not independent of the horizontal and so results in the hexagonal system having a tighter packing than the original square lattice.

Once the image has been converted, the hexagonal lattice is often represented using the layered approach in order to make visual processing easier. The conversion to a layered indexing system is a simple bottom-up sweep: we define the origin tile {{math|0<sub>7</sub>}} and then walk our way up the system, recursively backtracking down to define new tiles.

=== Hexagonal to Square Lattices ===

As most output devices are based on a square lattice rather than a hexagonal one, displaying a hexagonal-based image requires us to simulate a hexagonal coordinate system using the square lattice. This is a two-step procedure: first we must convert the hexagonal coordinates to Cartesian ones, and then we must simulate each hexagonal pixel using a suitable set of square pixels.

Assuming that the image is stored using the layered approach described above, each hexagon is represented as an n-digit number in base 7:

:<math>\displaystyle d_{n}d_{n-1}...d_{0}.</math>

Each digit, starting from {{math|''d''<sub>0</sub>}}, indicates an increase in distance from the origin, which can be seen by examining the sequence {{{math|1<sub>7</sub>}}, {{math|10<sub>7</sub>}}, {{math|100<sub>7</sub>}}, ...}. As the hexagonal x-axis maps exactly to the Cartesian one, we can convert each of these points directly to Cartesian coordinates, getting

:<math>1_{7} \rightarrow R\begin{bmatrix}1 \\ 0\end{bmatrix},\; 10_{7} \rightarrow R\begin{bmatrix}2 \\ \sqrt{3}\end{bmatrix},\;100_{7} \rightarrow R\begin{bmatrix}1 \\ 4\sqrt{3}\end{bmatrix}, ...,</math>

where {{math|''R''}} is determined by the inter-pixel spacing. Using these vectors we can convert any hexagonal location to a Cartesian one, by rotating each vector (using a standard Cartesian rotation matrix) depending on the location of the referenced tile relative to the centre tile. The rotation values are:

{| class="wikitable" style="text-align: center;"
|-
! scope="col" width="50" | d<sub>i</sub>
! scope="col" width="50" | Rotation
|-
| 1 || 0
|-
| 2 || <math>\frac{5\pi}{3}</math>
|-
| 3 || <math>\frac{4\pi}{3}</math>
|-
| 4 || <math>\pi</math>
|-
| 5 || <math>\frac{2\pi}{3}</math>
|-
| 6 || <math>\frac{\pi}{3}</math>
|}

As an example, the hexagon {{math|32<sub>7</sub>}} can be converted to Cartesian coordinates by first converting {{math|2<sub>7</sub>}}:

:<math>2_{7} \rightarrow \begin{bmatrix}cos(\frac{5\pi}{3}) & sin(\frac{5\pi}{3}) \\ -sin(\frac{5\pi}{3}) & cos(\frac{5\pi}{3})\end{bmatrix}\begin{bmatrix}1 \\ 0\end{bmatrix} = \begin{bmatrix}\frac{1}{2} & -\frac{\sqrt{3}}{2} \\ \frac{\sqrt{3}}{2} & \frac{1}{2}\end{bmatrix}\begin{bmatrix}1 \\ 0\end{bmatrix} = \begin{bmatrix}\frac{1}{2} \\ \frac{\sqrt{3}}{2}\end{bmatrix},</math>

and then converting {{math|30<sub>7</sub>}}:

:<math>30_{7} \rightarrow \begin{bmatrix}cos(\frac{4\pi}{3}) & sin(\frac{4\pi}{3}) \\ -sin(\frac{4\pi}{3}) & cos(\frac{4\pi}{3})\end{bmatrix}\begin{bmatrix}2 \\ \sqrt{3}\end{bmatrix} = \begin{bmatrix}-\frac{1}{2} & -\frac{\sqrt{3}}{2} \\ \frac{\sqrt{3}}{2} & -\frac{1}{2}\end{bmatrix}\begin{bmatrix}2 \\ \sqrt{3}\end{bmatrix} = \begin{bmatrix}-\frac{5}{2} \\ \frac{\sqrt{3}}{2}\end{bmatrix}.</math>

Combining the two values gives a final result of

:<math>32_{7} \rightarrow \begin{bmatrix}\frac{1}{2} \\ \frac{\sqrt{3}}{2}\end{bmatrix} + \begin{bmatrix}-\frac{5}{2} \\ \frac{\sqrt{3}}{2}\end{bmatrix} = \begin{bmatrix}-2 \\ \sqrt{3}\end{bmatrix}.</math>

Once the image has been converted to Cartesian coordinates, each point must now be displayed as a hexagon on the screen. There are two constraints to consider - we must attempt to simulate a hexagon as exactly as possible, and we must tile the plane exactly. As each hexagonal pixel spans multiple real pixels, they are referred to as ''hyper-pixels''. There are many possible representations for a hexagonal hyper-pixel, but one possible choice is:


[[File:Hexagonal_hyper_pixel.svg|180px]]


Note that a natural consequence of this approach is that the hexagonal resolution is far less than the display's true resolution, meaning we need a denser screen resolution than we wish to display at.

== Geometric Transformations ==

As with any coordinate system, common [[Transformation_(function)|geometric transformations]] can be implemented on hexagonal coordinate systems. These are most easily shown when using a 3-coordinate representation, as their form is then similar to 3D Cartesian transformations. In the following section, we will use the convention that the x-axis points 30° clockwise from 'right' (meaning that the y-axis points directly 'up', and the z-axis is rotated 150° clockwise from right.) As is common when dealing with transformation matrices, [[homogeneous coordinates]] can be used to allow transformation chaining. This means that the general form of a transformation is

:<math>(x', y', z', 1) = (x, y, z, 1)\begin{bmatrix}a_{11} & a_{12} & a_{13} & 0 \\ a_{21} & a_{22} & a_{23} & 0 \\ a_{31} & a_{32} & a_{33} & 0 \\ a_{41} & a_{42} & a_{43} & 1\end{bmatrix}.</math>

Some important properties to note are that:

* <math>\displaystyle A(0) = I</math>
* <math>\displaystyle A(\alpha)A^{-1}(\alpha) = A^{-1}(\alpha)A(\alpha) = I</math>
* Transformation matrices are not necessarily unique - some transformations have multiple representations. For example, a rotation of 60° in hexagonal space has three representations:

::<math>\begin{bmatrix}\frac{2}{3} & \frac{2}{3} & -\frac{1}{3} & 0 \\ -\frac{1}{3} & \frac{2}{3} & \frac{2}{3} & 0 \\ \frac{2}{3} & -\frac{1}{3} & \frac{2}{3} & 0 \\ 0 & 0 & 0 & 1\end{bmatrix} \equiv \begin{bmatrix}1 & 1 & 0 & 0 \\ 0 & 1 & 1 & 0 \\ 1 & 0 & 1 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix} \equiv \begin{bmatrix}0 & 0 & -1 & 0 \\ -1 & 0 & 0 & 0 \\ 0 & -1 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}.</math>

=== Translation ===

[[Translation_(geometry)|Translation]] in a hexagonal coordinate system is similar to the 3D Cartesian case. The translation matrix is given by

:<math>T(\triangle x, \triangle y, \triangle z) = \begin{bmatrix}1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ \triangle x & \triangle y & \triangle z & 1\end{bmatrix}</math>

Unlike the Cartesian case, however, hexagonal translation has the constraint that the coordinate deltas must sum to 0:

:<math>\triangle x + \triangle y + \triangle z = 0</math>


As an example, the translation matrix to move one hexagon 'right' is

:<math>T(1, 0, -1) = \begin{bmatrix}1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 1 & 0 & -1 & 1\end{bmatrix}.</math>

We can see that 1 + 0 + -1 = 0, and if we apply this to the point {{math|(5,1,2)}} we get

:<math>(5, 1, 2, 1)T(1, 0, -1) = (5, 1, 2, 1)\begin{bmatrix}1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 1 & 0 & -1 & 1\end{bmatrix} = (6, 1, 1, 1),</math>

which gives us the (correct) output point {{math|(6, 1, 1)}}.

=== Reflection ===

[[File:Hexagonal_reflection_axes.svg|thumb|A point P illustrating the set of reflection axes for a hexagonal coordinate system and the respective reflection matrices.]]

As a hexagonal lattice has 12-fold symmetry<ref>Her, Innchyn. ''Geometric Transformations on the Hexagonal Grid''. IEEE Transactions On Image Processing, 1995.</ref>, we can examine any point placed on a circle centred at the origin and find that it has 12 reflection points on that circle. These 12 points give the basic [[Reflection_(mathematics)|reflection]] matrices for hexagonal coordinate systems (with the point itself being given by the identity matrix, {{math|''I''}}.) The matrices are:


:<math>\begin{alignat}{6}
F_{x} = &&\; \begin{bmatrix}-1 & 0 & 0 & 0 \\ 0 & 0 & -1 & 0 \\ 0 & -1 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, &&\;
F_{y} = &&\; \begin{bmatrix}0 & 0 & -1 & 0 \\ 0 & -1 & 0 & 0 \\ -1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, &&\;
F_{z} = &&\; \begin{bmatrix}0 & -1 & 0 & 0 \\ -1 & 0 & 0 & 0 \\ 0 & 0 & -1 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, & \\
F_{xy} = &&\; \begin{bmatrix}0 & 1 & 0 & 0 \\ 1 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, &&\;
F_{yz} = &&\; \begin{bmatrix}1 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, &&\;
F_{zx} = &&\; \begin{bmatrix}0 & 0 & 1 & 0 \\ 0 & 1 & 0 & 0 \\ 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, & \\
F_{x}F_{xy} = &&\; \begin{bmatrix}0 & -1 & 0 & 0 \\ 0 & 0 & -1 & 0 \\ -1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, &&\;
F_{x}F_{y} = &&\; \begin{bmatrix}0 & 0 & 1 & 0 \\ 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, &&\;
F_{x}F_{yz} = &&\; \begin{bmatrix}-1 & 0 & 0 & 0 \\ 0 & -1 & 0 & 0 \\ 0 & 0 & -1 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, & \\
F_{x}F_{z} = &&\; \begin{bmatrix}0 & 1 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, &&\;
F_{x}F_{zx} = &&\; \begin{bmatrix}0 & 0 & -1 & 0 \\ -1 & 0 & 0 & 0 \\ 0 & -1 & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, &&\; &
\end{alignat}</math>


More complex reflections about an arbitrary line can be achieved by combining a basic reflection with other transformation matrices<ref>Foley, J. D., van Dam, A., Feiner, A. K., and Hughes, J. F. ''Computer Graphics: Principles and Practice''. Addison-Wesley, 1990.</ref>.

=== Scaling ===

As with reflection, [[Scaling_(geometry)|scaling]] is usually more complicated in hexagonal space, as the coordinates are not independent. Uniform scaling is simple as it scales each coordinate together, and is given by

:<math>S(\alpha) = \begin{bmatrix}\alpha & 0 & 0 & 0 \\ 0 & \alpha & 0 & 0 \\ 0 & 0 & \alpha & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}.</math>

Otherwise, we can consider two different types of scaling - either scaling along one of the three axes, or along the lines formed when two axis values are equal. In each case there are three possible directions for scaling. For each of the six cases we need to derive scaling matrices such that

:<math>\displaystyle (x', y', z', 1) = (x, y, z, 1)S(\alpha).</math>


First consider scaling along the x-axis by a factor {{math|&alpha;}}. In this case, the x-value will not change, so we have <math>\textstyle x' = x</math>. Since the scaled coordinates must still sum to 0, we have

:<math>\displaystyle y' + z' = y + z.</math>

Additionally, since {{math|''y'' - ''z''}} changes with respect to the scaling factor, we also have

:<math>\displaystyle y' - z' = \alpha(y - z).</math>

Solving these equations gives the matrix for the {{math|''S''<sub>x</sub>}} case, and the {{math|''S''<sub>y</sub>}} and {{math|''S''<sub>z</sub>}} matrices are found similarly:

:<math>S_{x}(\alpha) = \begin{bmatrix}1 & 0 & 0 & 0 \\ 0 & \frac{1 + \alpha}{2} & \frac{1 - \alpha}{2} & 0 \\ 0 & \frac{1 - \alpha}{2} & \frac{1 + \alpha}{2} & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, S_{y}(\alpha) = \begin{bmatrix}\frac{1 + \alpha}{2} & 0 & \frac{1 - \alpha}{2} & 0 \\ 0 & 1 & 0 & 0 \\ \frac{1 - \alpha}{2} & 0 & \frac{1 + \alpha}{2} & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, S_{z}(\alpha) = \begin{bmatrix}\frac{1 + \alpha}{2} & \frac{1 - \alpha}{2} & 0 & 0 \\ \frac{1 - \alpha}{2} & \frac{1 + \alpha}{2} & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}.</math>


Now consider scaling along a line formed by {{math|''x'' {{=}} ''y''}}. In this case the value {{math|''x'' - ''y''}} doesnt change, so we have

:<math>\displaystyle x' - y' = x - y</math>.

Therefore, only the value of {{math|''z''}} changes with respect to {{math|&alpha;}}, i.e.

:<math>\displaystyle z' = \alpha z.</math>

Solving these equations gives us the matrix for the {{math|''S''<sub>xy</sub>}} case, and the {{math|''S''<sub>yz</sub>}} and {{math|''S''<sub>zx</sub>}} matrices are found similarly:

:<math>S_{xy}(\alpha) = \begin{bmatrix}\frac{\alpha + 1}{2} & \frac{\alpha - 1}{2} & 0 & 0 \\ \frac{\alpha - 1}{2} & \frac{\alpha + 1}{2} & 0 & 0 \\ 0 & 0 & \alpha & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, S_{yz}(\alpha) = \begin{bmatrix} \alpha & 0 & 0 & 0 \\ 0 & \frac{\alpha + 1}{2} & \frac{\alpha - 1}{2} & 0 \\ 0 & \frac{\alpha - 1}{2} & \frac{\alpha + 1}{2} & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}, S_{zx}(\alpha) = \begin{bmatrix} \frac{\alpha + 1}{2} & 0 & \frac{\alpha - 1}{2} & 0 \\ 0 & \alpha & 0 & 0 \\ \frac{\alpha - 1}{2} & 0 & \frac{\alpha + 1}{2} & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}.</math>

=== Rotation ===

Since we have {{math|''x'' + ''y'' + ''z'' {{=}} 0}}, a [[Rotation_(mathematics)|rotation]] in a hexagonal coordinate system is equivalent to a rotation in Cartesian 3D space around the unit normal vector of the plane

<math>(\frac{1}{\sqrt{3}}, \frac{1}{\sqrt{3}}, \frac{1}{\sqrt{3}}).</math>

By substituting this into the general rotation matrix for 3D Cartesian space around an arbitrary vector, we get:

:<math>R(\theta) = \begin{bmatrix}P & Q & R & 0 \\ R & P & Q & 0 \\ Q & R & P & 0 \\ 0 & 0 & 0 & 1\end{bmatrix} = \begin{bmatrix}
\frac{1 + 2cos(\theta)}{3} & \frac{1 - cos(\theta) + \sqrt{3}sin(\theta)}{3} & \frac{1 - cos(\theta) - \sqrt{3}sin(\theta)}{3} & 0 \\ \frac{1 - cos(\theta) - \sqrt{3}sin(\theta)}{3} & \frac{1 + 2cos(\theta)}{3} & \frac{1 - cos(\theta) + \sqrt{3}sin(\theta)}{3} & 0 \\ \frac{1 - cos(\theta) + \sqrt{3}sin(\theta)}{3} & \frac{1 - cos(\theta) - \sqrt{3}sin(\theta)}{3} & \frac{1 + 2cos(\theta)}{3} & 0 \\ 0 & 0 & 0 & 1
\end{bmatrix}</math>


From this we create three new matrices by subtracting off P, Q, and R, giving us (respectively):


:<math>\begin{alignat}{2}
R'(\theta) = && \begin{bmatrix}P - P & Q - P & R - P & 0 \\ R - P & P - P & Q - P & 0 \\ Q - P & R - P & P - P & 0 \\ 0 & 0 & 0 & 1\end{bmatrix} =
\begin{bmatrix}0 & Q - P & R - P & 0 \\ R - P & 0 & Q - P & 0 \\ Q - P & R - P & 0 & 0 \\ 0 & 0 & 0 & 1\end{bmatrix} & \\
R''(\theta) = && \begin{bmatrix}P - Q & Q - Q & R - Q & 0 \\ R - Q & P - Q & Q - Q & 0 \\ Q - Q & R - Q & P - Q & 0 \\ 0 & 0 & 0 & 1\end{bmatrix} =
\begin{bmatrix}P - Q & 0 & R - Q & 0 \\ R - Q & P - Q & 0 & 0 \\ 0 & R - Q & P - Q & 0 \\ 0 & 0 & 0 & 1\end{bmatrix} & \\
R'''(\theta) = && \begin{bmatrix}P - R & Q - R & R - R & 0 \\ R - R & P - R & Q - R & 0 \\ Q - R & R - R & P - R & 0 \\ 0 & 0 & 0 & 1\end{bmatrix} =
\begin{bmatrix}P - R & Q - R & 0 & 0 \\ 0 & P - R & Q - R & 0 \\ Q - R & 0 & P - R & 0 \\ 0 & 0 & 0 & 1\end{bmatrix}\end{alignat}</math>


The differences between {{math|''P''}}, {{math|''Q''}}, and {{math|''R''}} define the ratios of the sides of an equilateral triangle. These are similar to standard [[trigonometric functions]], which define similar ratios for a right-angled triangle. Therefore, we can define three hexagonal trigonometric functions, based on the triangle:


[[File:Hexagonal_trigonometric_triangle.svg|thumb|center|The equilateral triangle used to define hexagonal trigonometric functions.]]


* The ''hexagonal sine'', denoted {{math| ''sinx &theta;''}}, is the ratio of a side of the equilateral triangle to the line AB:
::<math>sinx \theta = \frac{BC}{AB}.</math>
* The ''forward hexagonal cosine'', denoted {{math| ''cosx<sub>+</sub> &theta;''}}, is the negation of the ratio of line AC to AB:
::<math>cosx_{+} \theta = -\frac{AC}{AB}.</math>
* The ''backward hexagonal cosine'', denoted {{math| ''cosx<sub>-</sub> &theta;''}}, is the negation of the ratio of line AE to AB:
::<math>cosx_{-} \theta = -\frac{AE}{AB}.</math>

We can use these hexagonal trigonometric functions to re-write our rotation matrices in a simpler form:


:<math>\begin{alignat}{2}
R'(\theta) = && \begin{bmatrix}0 & -cosx_{-} \theta & cosx_{+} \theta \\ cosx_{+} \theta & 0 & -cosx_{-} \theta \\ -cosx_{-} \theta & cosx_{+} \theta & 0\end{bmatrix} & \\
R''(\theta) = && \begin{bmatrix}cosx_{-} \theta & 0 & -sinx \theta \\ -sinx \theta & cosx_{-} \theta & 0 \\ 0 & -sinx \theta & cosx_{-} \theta\end{bmatrix} & \\
R'''(\theta) = && \begin{bmatrix}-cosx_{+} \theta & sinx \theta & 0 \\ 0 & -cosx_{+} \theta & sinx \theta \\ sinx \theta & 0 & -cosx_{+} \theta\end{bmatrix}
\end{alignat}</math>


Note that these now closely resemble Cartesian 2D rotation matrices.

== Applications ==

=== Edge Detection ===
{{seealso|Edge detection}}

Edge detection is a commonly used technique in visual processing, which aims to find edges in an image by searching for locations at which the [[Luminous intensity|image intensity]] noticeably changes. Middleton and Sivaswamy<ref>Middleton, Lee., and Sivaswamy, Jayanthi. ''Edge Detection in a Hexagonal-Image Processing Framework''. Image and Vision Computing, Volume 19, Number 14, 2001.</ref> examined the use of hexagonal coordinate systems for edge detection, adapting three approaches (the Prewitt, Laplacian of Gaussian, and Canny edge detectors) to use hexagonal coordinate systems and comparing their performance to a square lattice.

====Prewitt Edge Detection====
{{seealso|Prewitt}}

The Prewitt edge detector is based on the [[Image gradient|gradient]] of the intensity, and looks for local maxima to detect edges. In general it is considered to be a poor detector due to it's bad approximation of the change in intensity. It also uses two 3&times;3 ''edge masks'', one for the horizontal direction and one for the vertical, which treat all of a pixel's neighbours equivalently. In a square-pixel system this is a false assumption, and means that the Prewitt edge detector ignores information. However, this assumption means that Prewitt edge detection is well suited for conversion to a hexagonal coordinate system, as a hexagonal pixel's neighbours are all equivalent.

Converting the Prewitt operator to a hexagonal lattice requires the definition of new edge masks. As the hexagonal horizontal axis is the same as the Cartesian one, no change is needed for the horizontal edge mask, other than to convert it to a hexagonal matrix:

:<math>h_1 = \begin{bmatrix}& 1 & & 1 & \\ 0 & & 0 & & 0 \\ & -1 & & -1 & \end{bmatrix}.</math>

The vertical mask is approximated by combining two masks that are orientated at 60° and 120° from the horizontal axis:

:<math>h_2 = \begin{bmatrix}& 0 & & 1 & \\ -1 & & 0 & & 1 \\ & -1 & & 0 &\end{bmatrix}, h_3 = \begin{bmatrix}& -1 & & 0 & \\ -1 & & 0 & & 1 \\ & 0 & & 1 &\end{bmatrix}.</math>

Note that as {{math|''h''<sub>1</sub> {{=}} ''h''<sub>2</sub> - ''h''<sub>3</sub>}}, we do not need to store all three edge masks, and can compute the gradient images using only two of them.

====Laplacian of Gaussian Edge Detection====
{{seealso|Laplacian of Gaussian}}

The Laplacian of Gaussian edge detector is based on the second derivation of the intensity, looking for zero-crossings to indicate edges in the image. Due to the use of a Gaussian smoothing function, to reduce the noise sensitivity of the second derivative, the Laplacian of Gaussian approach is [[isotropic]]. As such, adapting it to a hexagonal coordinate system is straightforward; the Gaussian masks must simply be adapted to be hexagonal instead of square.

====Canny Edge Detection====
{{seealso|Canny edge detector}}

The Canny edge detector combines elements of the Prewitt and Laplacian of Gaussian approaches. It uses two Gaussians; one for the horizontal axis and one for the vertical axis. As such, it is also isotropic and needs little adjustment apart from the use of hexagonal Gaussian masks.

==== Results ====

In general, Middleton and Sivaswamy found that hexagonal-based edge detection located approximately the same number of edge pixels as the square lattice approach for each of their tests cases, but choose qualitatively better pixels which more accurately represented the edge locations. As would be expected, the hexagonal-based edge detection performed better on natural curves than it did on sharp edges. The hexagonal methods also seemed to require less computation: the hexagonal Prewitt edge detection method required 13% less space for it's mask than the square method while achieving similar performance, the hexagonal Laplacian of Gaussian mask was far smaller than the square mask, and the hexagonal Canny edge detector required fewer computations than the square method.

=== Shape Extraction ===

Finding shapes in an image is a common visual processing task, often with the aim of reducing the data dimensionality from a whole image to a set of features. This is called [[feature extraction|shape extraction]], and can be viewed as attempting to find the dominant edges for any possible shapes in an image. Middleton, Sivaswamy, and Coghill<ref>Middleton, Lee., Sivaswamy, Jayanthi., and Coghill, George. ''Shape Extraction in a Hexagonal-Image Processing Framework''. Proceedings of the 6th International Conference on Control, Automation, Robotics and Vision, 2000.</ref> examined the use of hexagonal coordinate systems for shape extraction, comparing them to a square lattice.

By using a hexagonal lattice, Middleton et al. were able to mimic the human visual system, specifically the way that human eyes saccade to isolate points of interest in an image. They began by preprocessing the image to find 'critical points', where the weight of a hexagonal attention window placed over the point was above some threshold. The hexagonal attention window was then returned to the first critical point, features were extracted in terms of the weight and orientation of the point, and the attention window was moved according to the current features. Once a whole shape was found the algorithm restarted with the next critical point that had not already been assigned to a shape, and continued until there were no more critical points.

Middleton et al. found that their hexagonal-lattice based shape extraction method worked well on their test cases. As expected it worked better on natural curves due to the ability of the 'round' hexagonal attention window to match curves, while it struggled somewhat on sharp edges where a hexagon cannot nicely sit.

== See Also ==
*[[Hexagonal lattice]]
*[[Hexagonal tiling]]
*[[Hex map]], for the use of hexagonal coordinate systems in games.

== References ==
{{reflist}}

== External Links ==
* http://homepages.inf.ed.ac.uk/rbf/CVonline/LOCAL_COPIES/AV0405/MARTIN/Hex.pdf
* http://playtechs.blogspot.com/2007/04/hex-grids.html
* http://www-cs-students.stanford.edu/~amitp/game-programming/grids/

<!--- Categories --->
[[:Category:Image processing]]

Latest revision as of 14:38, 21 May 2013

(Note to the marker: My topic, Hexagonal Coordinate Systems, is technically a mathematical issue with a practical application in Computer Vision. Since the course is about vision, I have chosen to keep this page primarily focused around that. In a real article it would be preferable to keep the main page solely for mathematical definitions, and have it's use in vision processing as another page.)


Hexagonal Coordinate Systems

A hexagonal coordinate system is formed by placing a hexagonal lattice over a 2D plane, forming a coordinate system where each hexagon (or 'tile') can be uniquely specified in some manner. Although the coordinate system can be continuous, the discrete case is more common in vision processing and computer games, where a hexagon usually represents a pixel or map space respectively. The main advantages of hexagonal coordinates over the traditional Cartesian approach are the consistent distance between a hexagon and all of it’s neighbours, and the ability of hexagons to neatly represent natural shapes such as curves.

History

[edit]

The use of hexagonal coordinate systems in vision processing first occurred in 1963[citation needed], in the Illinois Pattern Recognition Computer[1], where they were referred to as rhombic arrays. However it was not until 1969 that the first work directly relating to hexagonal coordinate systems was published, on the potential benefits of a hexagonal representation of data for pattern matching[2]. Since then, hexagonal coordinate systems have surfaced multiple times in academic work, but have never obtained widespread popularity.

Definitions and Conventions

[edit]

Conventions

[edit]

By convention, tiles in a hexagonal coordinate system are laid out edge-to-edge horizontally, along the x-axis. Aligning vertically along the y-axis is sometimes used; most of the definitions and formulae laid out on this page can be adapted to a vertically-aligned system by simply swapping axis parameters. Other alignments are rare, as they complicate most of the mathematics involved in hexagonal coordinate systems.

Indexing a Hexagonal Coordinate System

[edit]
TODO
The effect of transforming the 'zig-zag' axis to a straight axis. Note how the transformation partitions the coordinate system in two.

Due to the popular nature of traditional rectangular coordinate systems, a natural approach when defining a hexagonal coordinate system is to attempt to use an orthogonal set of axes. As having truly orthogonal axes is obviously impossible, a zig-zag column approach is often suggested, where the y-axis alternates direction on each vertical row of tiles. This approach is inherently problematic, as can be seen by transforming the y-axis to a straight line. Examining the effect of this transformation on the super-hexagon triangles, we find that using an approximated y-axis splits the coordinate system into two partitions, based on alternating rows. This complicates geometric calculations, as they must take into account the two partitions. For example, distance calculations become iterative as the two ‘shortest’ paths between the start and end point (in terms of the number of tiles passed through) are not the same length in the coordinate system - the calculation must check which row it is in at each iteration and 'move' accordingly.

TODO
The effect of transforming the skewed-axis to a straight axis.

A better approach for indexing hexagonal coordinate systems can be found by altering the traditional view of the y-axis to suit hexagonal tiles. We define the y-axis to be ‘skewed’, rotated 60° from the x-axis. This viewpoint is 'straight' in terms of hexagonal coordinates, as each axis runs through the centre of an edge of the hexagon. Transforming the y-axis back to the traditional viewpoint, as we did before, shows that the super-hexagon triangles are now uniformly represented in the skewed-axis system.

Another approach for indexing hexagonal coordinate systems uses the hexagon’s axes of symmetry, giving three trigonal axes. By convention these are referred to as the x-, y- and z-axes, although it is important to realise that they are distinct from the normal three-dimensional use of these names - the coordinate system still only indexes into a two-dimensional plane. As only two of the three coordinates are required to uniquely specify any hexagon in the coordinate system, one coordinate is redundant; however the use of all three coordinates allows the easy calculation of distances and other geometric functions. Converting between the skewed-axis approach and the three-coordinate approach is straightforward - we simply identify the redundant coordinate and remove it, renaming and shifting the other axes as appropriate.

A final and rather unusual representation for a hexagonal coordinate system is to represent it as a layered system. The layered system is defined recursively, as each layer is composed of a number of tiles from the layer below it. A layer 0 tile is a single hexagon. A layer L tile is composed of a layer L-1 tile and it’s 6 neighbouring tiles. That is, a layer 1 tile is a collection of seven hexagons, a layer 2 tile is a collection of seven layer 1 tiles, and so on. This approach is common in vision processing due to its efficient use of space. There are 7L tiles in an L layer system, and each hexagon in the system can be indexed using an L-digit, base 7 number. Starting from the global tile, each digit in an index represents which sub-tile the hexagon belongs to, starting at 0 in the centre and then proceeding from 1 to 6 around the centre tile. For example, consider the hexagon indexed by 247. The first digit, 2, indicates that the hexagon is in the second location of the layer 1 tile, and the last digit, 4, indicates that the hexagon is in the fourth location of the layer 0 tile.

As each hexagon is just a number, an image can be stored as a one-dimensional vector. A hexagonal image of L layers with 24-bit colour requires 3 x 7L bytes. If the hexagonal image was created from an M x N square image with M = N = 2m, we can calculate the required number of layers as

Aside from its efficient use of space, the hierarchical layering approach also makes the execution of some visual processing algorithms in hexagonal space easier.

Extension to N Dimensions

[edit]

As a planar shape, hexagons cannot be represented in three or more dimensions. Therefore, unlike Cartesian or polar coordinate systems, there is no straightforward extension of hexagonal coordinate systems to higher dimensions.

Advantages and Issues

[edit]

Advantages of Hexagonal Coordinate Systems

[edit]

As stated above, the main reasons for using a hexagonal coordinate system for image processing are hexagons' consistent connection with their neighbours and the ease of representing natural shapes using hexagons. In a normal square-pixel system, a pixel’s neighbours have two different levels of connectivity - they are either 1 pixel away, or pixels. This means that algorithms based on neighbourhood searches either have to ignore this distinction (and lose information) or cope with it somehow (causing increased complexity). Using a hexagonal coordinate system means that each neighbour is exactly 1 pixel away, and so algorithms can treat them all the same. The natural representation of curves in hexagonal coordinate systems allows many visual operations to be performed more easily; examples of edge detection and shape extraction are given below.

In addition to the above, hexagonal lattices also more closely resemble the pattern of photo-receptors in the human eye than square lattices. This means that they may be used when attempting to simulate the visual information provided by the eye to the brain and some of the visual processing performed by the brain on image data, such as simulating saccading[3].

Potential Issues

[edit]

Despite their advantages, hexagonal coordinate systems are not commonly used in vision processing outside of academic work. A number of reasons have been suggested for the lack of uptake. Firstly, people often find thinking in hexagonal space difficult compared to traditional Cartesian systems, and so are less inclined to use hexagonal coordinate systems. Whether or not this is a real difficulty, or simply something one has to 'get used to' is debated, but in either case it reduces the likelihood of people choosing to use a hexagonal representation of data.

The lack of hardware devices (both input and output) that directly support hexagonal coordinate systems is also an issue. Input images must be converted from a square lattice to a hexagonal one. This may either be done by extrapolation, in which case the resolution of the image is artificially lowered, or by capturing the image at a higher resolution than it will be processed at, which is wasteful. Once the processing has been completed the output image must then be represented on or converted back to a square lattice somehow, which collapses pixels and thus results in a lower output resolution.

Image Conversion

[edit]

Square to Hexagonal Lattices

[edit]

As hardware devices that can directly capture images onto a hexagonal lattice are rare, images usually have to be converted from a square lattice to a hexagonal one. This process is known as image re-sampling. The conversion method depends on how the hexagonal coordinate system is indexed; as we can easily convert between the skewed-axis and 3-coordinate representations, only the skewed-axis method will be shown.

A hexagon with the distance from the centre to the middle of one edge, and from the centre to a corner shown.
An example hexagon showing the distances from the centre to it's edges and corners.

To convert points from a Cartesian coordinate system to a hexagonal system, we must transform the points into hexagonal space, map them to a square lattice, and then convert the square lattice to a hexagonal one. For convenience we define two constants: r is the shortest distance from the centre of a hexagon to an edge, and s is the distance from the centre of a hexagon to a corner.

Two matrices are used to transform the Cartesian coordinates to hexagonal space, one for each hexagonal axis. For each axis we must describe an affine transformation from the hexagonal lattice to the square lattice. Starting with the x-axis, we can examine one possible transformation such that every point in a square corresponds to the same x-coordinate in hexagonal space:


TODO


We now need to define the transformation matrix

such that Mph = ps, where ph is a point in the hexagonal lattice and ps is a point in the square lattice. Consider two points in the square lattice: (1,0) and (0,1). These correspond to the points (0, -s) and (r,s/2) in the hexagonal lattice. Therefore, we can form four linear equations:

Solving this linear system gives us , , , and . Now we compute the hexagonal x-coordinate. This is calculated as

where (xs, ys) is the transformed point, n is the offset needed to map the correct points to x = 0 (in the above example we want (-2,0), (-1,0) and (0,0) to all map to hex coordinate x = 0, so n = 2), and w is the 'width' or number of squares wide that a transformed hexagon is.

We now use a similar method for the y-axis. Another affine transformation is examined, such that every point in a square corresponds to the same y-coordinate in hexagonal space.


TODO


Under this transformation the points (1,0) and (0,1) in the square lattice correspond to the hexagonal coordinates (r, s/2) and (-r, s/2) respectively. Again we form four linear equations:

Solving this system gives us , , , and . Finally we compute the hexagonal y-coordinate. This is identical to before:


The values of r and s depend on the chosen mapping scale between the square and hexagonal lattice. Common values are and . These give the basis functions


Note that these basis vectors mean that the horizontal scale is fixed between the square and hexagonal lattice, but that the 'vertical' scale is not independent of the horizontal and so results in the hexagonal system having a tighter packing than the original square lattice.

Once the image has been converted, the hexagonal lattice is often represented using the layered approach in order to make visual processing easier. The conversion to a layered indexing system is a simple bottom-up sweep: we define the origin tile 07 and then walk our way up the system, recursively backtracking down to define new tiles.

Hexagonal to Square Lattices

[edit]

As most output devices are based on a square lattice rather than a hexagonal one, displaying a hexagonal-based image requires us to simulate a hexagonal coordinate system using the square lattice. This is a two-step procedure: first we must convert the hexagonal coordinates to Cartesian ones, and then we must simulate each hexagonal pixel using a suitable set of square pixels.

Assuming that the image is stored using the layered approach described above, each hexagon is represented as an n-digit number in base 7:

Each digit, starting from d0, indicates an increase in distance from the origin, which can be seen by examining the sequence {17, 107, 1007, ...}. As the hexagonal x-axis maps exactly to the Cartesian one, we can convert each of these points directly to Cartesian coordinates, getting

where R is determined by the inter-pixel spacing. Using these vectors we can convert any hexagonal location to a Cartesian one, by rotating each vector (using a standard Cartesian rotation matrix) depending on the location of the referenced tile relative to the centre tile. The rotation values are:

di Rotation
1 0
2
3
4
5
6

As an example, the hexagon 327 can be converted to Cartesian coordinates by first converting 27:

and then converting 307:

Combining the two values gives a final result of

Once the image has been converted to Cartesian coordinates, each point must now be displayed as a hexagon on the screen. There are two constraints to consider - we must attempt to simulate a hexagon as exactly as possible, and we must tile the plane exactly. As each hexagonal pixel spans multiple real pixels, they are referred to as hyper-pixels. There are many possible representations for a hexagonal hyper-pixel, but one possible choice is:



Note that a natural consequence of this approach is that the hexagonal resolution is far less than the display's true resolution, meaning we need a denser screen resolution than we wish to display at.

Geometric Transformations

[edit]

As with any coordinate system, common geometric transformations can be implemented on hexagonal coordinate systems. These are most easily shown when using a 3-coordinate representation, as their form is then similar to 3D Cartesian transformations. In the following section, we will use the convention that the x-axis points 30° clockwise from 'right' (meaning that the y-axis points directly 'up', and the z-axis is rotated 150° clockwise from right.) As is common when dealing with transformation matrices, homogeneous coordinates can be used to allow transformation chaining. This means that the general form of a transformation is

Some important properties to note are that:

  • Transformation matrices are not necessarily unique - some transformations have multiple representations. For example, a rotation of 60° in hexagonal space has three representations:

Translation

[edit]

Translation in a hexagonal coordinate system is similar to the 3D Cartesian case. The translation matrix is given by

Unlike the Cartesian case, however, hexagonal translation has the constraint that the coordinate deltas must sum to 0:


As an example, the translation matrix to move one hexagon 'right' is

We can see that 1 + 0 + -1 = 0, and if we apply this to the point (5,1,2) we get

which gives us the (correct) output point (6, 1, 1).

Reflection

[edit]
A point P illustrating the set of reflection axes for a hexagonal coordinate system and the respective reflection matrices.

As a hexagonal lattice has 12-fold symmetry[4], we can examine any point placed on a circle centred at the origin and find that it has 12 reflection points on that circle. These 12 points give the basic reflection matrices for hexagonal coordinate systems (with the point itself being given by the identity matrix, I.) The matrices are:



More complex reflections about an arbitrary line can be achieved by combining a basic reflection with other transformation matrices[5].

Scaling

[edit]

As with reflection, scaling is usually more complicated in hexagonal space, as the coordinates are not independent. Uniform scaling is simple as it scales each coordinate together, and is given by

Otherwise, we can consider two different types of scaling - either scaling along one of the three axes, or along the lines formed when two axis values are equal. In each case there are three possible directions for scaling. For each of the six cases we need to derive scaling matrices such that


First consider scaling along the x-axis by a factor α. In this case, the x-value will not change, so we have . Since the scaled coordinates must still sum to 0, we have

Additionally, since y - z changes with respect to the scaling factor, we also have

Solving these equations gives the matrix for the Sx case, and the Sy and Sz matrices are found similarly:


Now consider scaling along a line formed by x = y. In this case the value x - y doesnt change, so we have

.

Therefore, only the value of z changes with respect to α, i.e.

Solving these equations gives us the matrix for the Sxy case, and the Syz and Szx matrices are found similarly:

Rotation

[edit]

Since we have x + y + z = 0, a rotation in a hexagonal coordinate system is equivalent to a rotation in Cartesian 3D space around the unit normal vector of the plane

By substituting this into the general rotation matrix for 3D Cartesian space around an arbitrary vector, we get:


From this we create three new matrices by subtracting off P, Q, and R, giving us (respectively):



The differences between P, Q, and R define the ratios of the sides of an equilateral triangle. These are similar to standard trigonometric functions, which define similar ratios for a right-angled triangle. Therefore, we can define three hexagonal trigonometric functions, based on the triangle:


The equilateral triangle used to define hexagonal trigonometric functions.


  • The hexagonal sine, denoted sinx θ, is the ratio of a side of the equilateral triangle to the line AB:
  • The forward hexagonal cosine, denoted cosx+ θ, is the negation of the ratio of line AC to AB:
  • The backward hexagonal cosine, denoted cosx- θ, is the negation of the ratio of line AE to AB:

We can use these hexagonal trigonometric functions to re-write our rotation matrices in a simpler form:



Note that these now closely resemble Cartesian 2D rotation matrices.

Applications

[edit]

Edge Detection

[edit]

Edge detection is a commonly used technique in visual processing, which aims to find edges in an image by searching for locations at which the image intensity noticeably changes. Middleton and Sivaswamy[6] examined the use of hexagonal coordinate systems for edge detection, adapting three approaches (the Prewitt, Laplacian of Gaussian, and Canny edge detectors) to use hexagonal coordinate systems and comparing their performance to a square lattice.

Prewitt Edge Detection

[edit]

The Prewitt edge detector is based on the gradient of the intensity, and looks for local maxima to detect edges. In general it is considered to be a poor detector due to it's bad approximation of the change in intensity. It also uses two 3×3 edge masks, one for the horizontal direction and one for the vertical, which treat all of a pixel's neighbours equivalently. In a square-pixel system this is a false assumption, and means that the Prewitt edge detector ignores information. However, this assumption means that Prewitt edge detection is well suited for conversion to a hexagonal coordinate system, as a hexagonal pixel's neighbours are all equivalent.

Converting the Prewitt operator to a hexagonal lattice requires the definition of new edge masks. As the hexagonal horizontal axis is the same as the Cartesian one, no change is needed for the horizontal edge mask, other than to convert it to a hexagonal matrix:

The vertical mask is approximated by combining two masks that are orientated at 60° and 120° from the horizontal axis:

Note that as h1 = h2 - h3, we do not need to store all three edge masks, and can compute the gradient images using only two of them.

Laplacian of Gaussian Edge Detection

[edit]

The Laplacian of Gaussian edge detector is based on the second derivation of the intensity, looking for zero-crossings to indicate edges in the image. Due to the use of a Gaussian smoothing function, to reduce the noise sensitivity of the second derivative, the Laplacian of Gaussian approach is isotropic. As such, adapting it to a hexagonal coordinate system is straightforward; the Gaussian masks must simply be adapted to be hexagonal instead of square.

Canny Edge Detection

[edit]

The Canny edge detector combines elements of the Prewitt and Laplacian of Gaussian approaches. It uses two Gaussians; one for the horizontal axis and one for the vertical axis. As such, it is also isotropic and needs little adjustment apart from the use of hexagonal Gaussian masks.

Results

[edit]

In general, Middleton and Sivaswamy found that hexagonal-based edge detection located approximately the same number of edge pixels as the square lattice approach for each of their tests cases, but choose qualitatively better pixels which more accurately represented the edge locations. As would be expected, the hexagonal-based edge detection performed better on natural curves than it did on sharp edges. The hexagonal methods also seemed to require less computation: the hexagonal Prewitt edge detection method required 13% less space for it's mask than the square method while achieving similar performance, the hexagonal Laplacian of Gaussian mask was far smaller than the square mask, and the hexagonal Canny edge detector required fewer computations than the square method.

Shape Extraction

[edit]

Finding shapes in an image is a common visual processing task, often with the aim of reducing the data dimensionality from a whole image to a set of features. This is called shape extraction, and can be viewed as attempting to find the dominant edges for any possible shapes in an image. Middleton, Sivaswamy, and Coghill[7] examined the use of hexagonal coordinate systems for shape extraction, comparing them to a square lattice.

By using a hexagonal lattice, Middleton et al. were able to mimic the human visual system, specifically the way that human eyes saccade to isolate points of interest in an image. They began by preprocessing the image to find 'critical points', where the weight of a hexagonal attention window placed over the point was above some threshold. The hexagonal attention window was then returned to the first critical point, features were extracted in terms of the weight and orientation of the point, and the attention window was moved according to the current features. Once a whole shape was found the algorithm restarted with the next critical point that had not already been assigned to a shape, and continued until there were no more critical points.

Middleton et al. found that their hexagonal-lattice based shape extraction method worked well on their test cases. As expected it worked better on natural curves due to the ability of the 'round' hexagonal attention window to match curves, while it struggled somewhat on sharp edges where a hexagon cannot nicely sit.

See Also

[edit]

References

[edit]
  1. ^ McCormick, Bruce H. The Illinois Pattern Recognition Computer - ILLIAC III. IEEE Transactions on Electronic Computers, 1963.
  2. ^ Golay, Marcel J. E. Hexagonal Parallel Pattern Transformations. IEEE Transactions on Computers, 1969.
  3. ^ Middleton, Lee., Coghill, George., and Sivaswamy, Jayanthi. Saccadic Exploration using a Hexagonal Retina. Proceedings of the International ICSC Congress on Intelligent Systems and Applications, 2000.
  4. ^ Her, Innchyn. Geometric Transformations on the Hexagonal Grid. IEEE Transactions On Image Processing, 1995.
  5. ^ Foley, J. D., van Dam, A., Feiner, A. K., and Hughes, J. F. Computer Graphics: Principles and Practice. Addison-Wesley, 1990.
  6. ^ Middleton, Lee., and Sivaswamy, Jayanthi. Edge Detection in a Hexagonal-Image Processing Framework. Image and Vision Computing, Volume 19, Number 14, 2001.
  7. ^ Middleton, Lee., Sivaswamy, Jayanthi., and Coghill, George. Shape Extraction in a Hexagonal-Image Processing Framework. Proceedings of the 6th International Conference on Control, Automation, Robotics and Vision, 2000.
[edit]

Category:Image processing