Presentation is loading. Please wait.

Presentation is loading. Please wait.

L10 – Map labeling algorithms NGEN06(TEK230) – Algorithms in Geographical Information Systems L10- Map labeling algorithms by: Sadegh Jamali (source: Lecture.

Similar presentations


Presentation on theme: "L10 – Map labeling algorithms NGEN06(TEK230) – Algorithms in Geographical Information Systems L10- Map labeling algorithms by: Sadegh Jamali (source: Lecture."— Presentation transcript:

1 L10 – Map labeling algorithms NGEN06(TEK230) – Algorithms in Geographical Information Systems L10- Map labeling algorithms by: Sadegh Jamali (source: Lecture notes in GIS, Lars Harrie) 1

2 Labels are an essential aspect of maps. For example, on maps for mobile applications, it is necessary to label roads, landmarks, and …. to help users understand their location and the environment. The labels should be easy to read and should follow basic cartographic rules. The cartographic rules are analytically defined and implemented in computer programs. L10- Map labeling algorithms Background 2

3  to provide some basics of algorithms for automated map labelling. L10- Map labeling algorithms Aim 3 Content 1. Basic cartography theory 2. Label placement by combinatorial optimization 3. Label placement by slider model

4 L10- Map labeling algorithms 4 Generally, there are two things that are important for labels: proper font type and size good position. 1. Basic cartography theory

5 L10- Map labeling algorithms 5 Font type and size Figure. The two main font families (From Jenny et al. 2008). Example of Sans Serif family: Verdena and Frutiger Font size: at least 12 points. Note: to distinguish between different label types, you could use wide letter spacing, varying font size and bold/italic style.

6 L10- Map labeling algorithms 6 Label position To be good positioned, the labels should: 1) not overlap 2) not obscure other map objects 3) placed in a good position relative to the referent.

7 Preferred positions for point labels Slocum et al. (2005) L10- Map labeling algorithms 7

8 Slocum et al. (2005) L10- Map labeling algorithms 8 Preferred positions for line labels

9 Slocum et al. (2005) L10- Map labeling algorithms 9 Preferred positions for area labels

10 L10- Map labeling algorithms 10 2. Label placement by combinatorial optimization Label placement can be defined as a combinatorial optimization problem. To find the optimal combination of placement a cost function (f) is created.

11 L10- Map labeling algorithms 11 Cost function The best solution: the solution with the smallest cost.

12 L10- Map labeling algorithms 12 So how to find the best possible solution? we can adopt an iterative improvement algorithm. Challenge!

13 13 simulated annealing allows moving towards both lower (better) and upper (worse) neighboring positions, where a worse position is accepted with a probability decreasing over time the probability is controlled by a parameter denoted as temperature, which decreases over time and thus forms a number of temperature stages by accepting worse positions with a decreasing probability, simulated annealing may escape from a local optimal position and reach the global optimal position (Russell and Norvig 1995). L10- Map labeling algorithms Iterative improvement algorithm can be illustrated as a search process on the surface of a landscape each position = a specific configuration, i.e., a solution, with an elevation representing the “cost” of the solution moves around to find the lowest position on the landscape can be realized by a slope descending algorithm slope descending may be terminated at local lowest positions

14 14 L10- Map labeling algorithms Combinatorial optimization schema 1) Labels are initially placed at the position with best placement properties. 2) Create a cost function to reflect cartographic requirements and aesthetic principles. 3) Start an optimization using the simulated annealing schema. For each iteration a label is randomly selected. 4) Run the process until a minimum of the cost function is found.

15 L10- Map labeling algorithms 15 3. Label placement by slider model In the combinatorial optimization: a fixed number of positions are allowed. Slider model: much more positions are allowed (leads to enhanced cartographic quality of the labels). Constraints: 1)labels should be legible 2)each label should be properly associated to the feature that it describes (i.e. feature and its label are not separated).

16 L10- Map labeling algorithms 16 Slider Model ( Zhang and Harrie(2006a,b) ) Phases: 1)all possible positions for the label are computed. 2)the candidate positions are reduced according to conflict detection. 3)finally a position is selected from the reduced candidate set to label the feature.

17 L10- Map labeling algorithms 17 Slider Model: point labeling algorithm Input data: a point set (to be labeled) and other feature classes (acting as obstacles) Algorithm workflow: 1.Select a point sequentially from the point set, and create four rectangular boxes around the point (“range boxes”). Figure: (a) The top range box of a point feature.

18 L10- Map labeling algorithms 18 The workflow: 2. Select the range boxes of a point feature sequentially, and search for the obstacles in conflict with this box. 3. For each conflicting obstacle, compute the intersection between the obstacle and the range box. If any intersection exists, reduce the range box using the intersection. Figure: (b) The reduced range boxes (left and bottom) of a point feature in conflict with a line feature.

19 L10- Map labeling algorithms 19 Reduction of a range box: depends on the location and size of the intersection between the range box and the obstacle. If there is an object O (label or cartographic feature) that overlaps the range box RB, then the intersection I has the properties: where MBR is the minimum bounding box function.

20 L10- Map labeling algorithms 20 Then the range box RB will be reduced to a new range box RBnew as follows (if it is a top or bottom range boxes; left and right range boxes are treated similarly): Figure: Reduce a range box in conflict with an obstacle

21 L10- Map labeling algorithms 21 The workflow: 4. select a position to place the label inside the reduced range box according to position preference. 5. Go back to step 1) to deal with the next point’s labelling. The computational complexity: O (nk+nm) Step 2): O (nk) n: the number of point features to be labeled k: the number of obstacles Step 3): O (nm) m: the average number of conflicting obstacles for each point to be labeled

22 L10- Map labeling algorithms 22 Slider Model: line labeling algorithm Steps: 1)search for all the long line segments along a line as candidate positions. 2)Candidate positions along each segment are reduced to a part of the original positions, without conflict to any obstacles.

23 L10- Map labeling algorithms 23 Input data: a line set (to be labeled) and several feature classes (acting as obstacles) Algorithm workflow: 1.Select a line sequentially, and create its generalized version using the Douglas-Peucker algorithm. 2.Search for segments long enough for label placement. 3.Search for the longest segment. 4.Create a range box with orientation along the longest segment. 5.Search for obstacles in conflict with the range box, and shrink the range box according to conflict detection. 6.If the reduced range box is long enough, then reduce its size to the size of corresponding label text, shrinking its two sides towards the centroid. Otherwise, search for the second longest segment, then go back to step 4) to find a labelling position for the line. 7.Go back to step 1) to deal with the next line’s labelling.

24 L10- Map labeling algorithms 24 The computational complexity: O (nk+nm) n: the number of line features to be labeled k: the number of obstacles m: the average number of conflicting obstacles for each line to be labeled.

25 L10- Map labeling algorithms 25 A case study Note: only one label is created for each road feature. So the routine for merging the road segments was successful in this case study. Figure: Labels placed automatically by the slider method (source: National Land Survey of Finland)


Download ppt "L10 – Map labeling algorithms NGEN06(TEK230) – Algorithms in Geographical Information Systems L10- Map labeling algorithms by: Sadegh Jamali (source: Lecture."

Similar presentations


Ads by Google