# Repetition Structures - Tessellations ![main1.gif](images/main1.gif) ![main2.png](images/main2.png) ![main3.png](images/main3.png) One of the advantages of using computer programs is that we can easily implement repetitive tasks. Structures such as the `for`, `while`, and `do-while` allow us to repeat a block of instructions as many times as needed. In this lab experience you will use `for` loops produce patterns and mosaics. ##Objectives: 1. Practice the use of repetition structures to make patterns and tessellations. 2. Strengthen the use of functions and objects. This laboratory experience is an adaptation of https://sites.google.com/a/wellesley.edu/wellesley-cs118-spring13/lectures-labs/lab-2. ##Pre-Lab: Before coming to the laboratory session you should have: 1. Reviewed the basic concepts related to repetition structures. 2. Studied the concepts and instructions for the laboratory session, especially the use of the methods for: a. adjusting the size of the windows, b. adjusting the position of the tessellations, c. rotate tessellations. 3. Taken the Pre-Lab quiz available through the course’s Moodle portal. --- --- ##Tessellations A tessellation is a mosaic that is created by repeating a figure to cover the surface without leaving empty spaces or overlapping the figures. A *regular tessellation* is a figure that is made by repeating the same *regular polygon*, like triangles, squares or hexagons. (A regular polygon is a polygon where all sides are congruent and the angles that form the sides are congruent.) --- ![figure1.gif](images/figure1.gif) **Figure 1** - The only regular tessellations possible obtained using triangles, squares and hexagons. --- ##Library The `Tessellations.pro` project available in `http://bitbucket.org/eip-uprrp/repetitions1-tessellations` contains the `Tessellation` class, which is an abstraction of a tessellation with squares, and the `DrawingWindow` class. The code shown in Figure 2 creates a `DrawingWindow` called `w`, a `Tesselation` called `t` and places the tessellation in position (50,100). Notice that the `addTessellation` method of the `DrawingWindow` class should be invoked to draw the tessellation. --- ```cpp int main(int argc, char *argv[]) { QApplication a(argc, argv); DrawingWindow w; // Creates the w object of the DrawingWindow class w.resize(300, 300); w.show(); Tessellation t; // Creates the t object of the Tessellation class t.move(50,100); // Sets the tessellation's position w.addTessellation(t); // Adds the tessellation to the window return a.exec(); } ``` **Figure 2.** Code in the `main` function to create a window and tessellation. --- The window that is obtained with the code in Figure 2 is similar to the window in Figure 3. The arrows and the numbers 50 and 100 illustrate the spaces between the tessellation's upper left corner and the window's borders. The tessellation's upper left corner is in the position (50,100). --- ![figure3.png](images/figure3.png) **Figure 3.** Window with the tessellation in the position (50,100). --- **Example 1.** The code in Figure 4 contains a `foo` function to draw four tessellations in the positions (0,0), (50,50), (100,100), and (150,150), with the original figure's rotation of $$0^\circ, 90^\circ, 180^\circ y 270^\circ$$ (clockwise). --- ```cpp int foo(DrawingWindow &w) { int rot = 0; for (int i = 0; i < 4; i++) { Tessellation t; t.setRotation(rot); t.move(i * 50, i * 50); w.addTessellation(t); rot += 90; } } int main(int argc, char *argv[]) { QApplication a(argc, argv); DrawingWindow w; w.resize(300, 300); w.show(); foo(w); return a.exec(); } ``` **Figure 4.** Code for the `foo` function that draws four tessellations. --- Observe how the `foo` function needs to receive a reference to the `w` object of the `DrawingWindow` class since its invoking the `addTessellation` method of the class in each iteration of the loop. The figure that is obtained is similar to the one in Figure 5. --- ![figure5.png](images/figure5.png) **Figure 5.** Tessellations drawn by the `foo` function in the code in Figure 4. --- **Example 2.** The code in Figure 6 shows an example of how to use nested loops to create tessellations. --- ```cpp int fah(DrawingWindow &w) { int rot = 0; for (int i = 0; i < 4; i++) { for (int j = 0; j < 4; j++) { Tessellation t; t.move(i * 50, j * 50); t.setRotation(rot); w.addTessellation(t); } rot += 90; } } ``` **Figure 6.** Code for the `fah` function that uses nested loops to draw four tessellations. The figure that is obtained is similar to the one in Figure 7. --- ![figure7.png](images/figure7.png) **Figure 7.** Tessellations drawn by the `fah` function in the code in Figure 6. --- --- --- !INCLUDE "../../eip-diagnostic/tesselations/en/diag-tesselations-01.html" !INCLUDE "../../eip-diagnostic/tesselations/en/diag-tesselations-02.html" --- --- ##Laboratory Session In today's laboratory experience you will practice the use of nested loops to create different tessellations. ###Exercise 1: Study the loop that produces tessellations ####Instructions 1. Load the Qt project called `Tessellations` by double-clicking on the `Tessellations.pro` file in the `Documents/eip/Repetitions-Tessellations` folder of your computer. Alternatively, you may clone the git repository `http://bitbucket.org/eip-uprrp/repetitions-tessellations` to download the `Repetitions-Tessellations` folder to your computer. 2. The `Tessellations.pro` project contains the `Tessellations` and `DrawingWindow` classes and the `foo` function. Configure the project and run the program. You should see a window similar to the one in Figure 5. This figure is created with the `foo` function shown in Figure 4 and explained in Example 1. The `foo` function is invoked from `main()`. In this laboratory experience you will only be making changes to the `main()` function. Study the `foo` function once again and notice the creation of the objects from the `Tessellations` class, the use of the `setRotation` method, and the `move` method to set the tessellation in the desired position. Notice how the instructions in the `for` loop in the function use the loop's counter to determine the square's position and how the rotation's value is incremented. Also notice that you will need to use the `addTessellation` method to add the tessellation to the `w` window. ###Exercise 2: Create the `herringbone` function and tessellation ####Instructions 1. Create a `herringbone` function that produces the tessellation in Figure 8. The size of the window is 400x400. The size of each square in the tessellation is its size by default: 50x50. --- ![figure8.png](images/figure8.png) **Figure 8.** Tessellation that the `herringbone` function should draw. --- 2. Comment the **invocation** of the `foo` function. 3. Invoke the `herringbone` function from `main()` and run the program so you can see the tessellation you created. ###Exercise 3: Create the `zigzag` function and tessellation ####Instructions 1. Create a `zigzag` function that produces the tessellation in Figure 9. --- ![figure9.png](images/figure9.png) **Figure 9.** Tessellation that the `zigzag` function should draw. --- 2. Comment the invocation of the `herringbone` function. 3. Invoke the `zigzag` function from `main()` and run the program so you can see the tessellation you created. ###Exercise 4: Create the `diamond` function and tessellation ####Instructions 1. Create a `diamond` function that produces the tessellation in Figure 10. --- ![figure10.png](images/figure10.png) **Figure 10.** Tessellation that the `diamond` function should draw. --- 2. Comment the invocation of the `zigzag` function. 3. Invoke the `diamond` function from `main()` and run the program so you can see the tessellation you created. --- --- ##Deliverables Use "Deliverables" in Moodle to upload the `main.cpp` file that contains the `herringbone`, `zigzag` and `diamond` functions that you created in Exercises 2, 3, and 4. Remember to use good programming techniques, include the names of the programmers involved, and to document your program. --- --- ##References [1] https://sites.google.com/a/wellesley.edu/wellesley-cs118-spring13/lectures-labs/lab-2.