

Michigan Technological University

Create the Future Digital Commons @ Michigan Tech

Dissertations, Master's Theses and Master's Reports - Open

Dissertations, Master's Theses and Master's Reports

2013

# DESIGN AND IMPLEMENT DYNAMIC PROGRAMMING BASED DISCRETE POWER LEVEL SMART HOME SCHEDULING USING FPGA

Xin Yang michigan technological

Follow this and additional works at: https://digitalcommons.mtu.edu/etds

Part of the Electrical and Computer Engineering Commons Copyright 2013 Xin Yang

#### **Recommended Citation**

Yang, Xin, "DESIGN AND IMPLEMENT DYNAMIC PROGRAMMING BASED DISCRETE POWER LEVEL SMART HOME SCHEDULING USING FPGA", Master's report, Michigan Technological University, 2013. https://digitalcommons.mtu.edu/etds/601

Follow this and additional works at: https://digitalcommons.mtu.edu/etds Part of the <u>Electrical and Computer Engineering Commons</u>

# DESIGN AND IMPLEMENT DYNAMIC PROGRAMMING BASED DISCRETE POWER LEVEL SMART HOME SCHEDULING USING FPGA

Ву

Xin Yang

A REPORT

Submitted in partial fulfillment of the requirements for the degree of

MASTER OF SCIENCE

In Electrical Engineering

MICHIGAN TECHNOLOGICAL UNIVERSITY

2013

© 2013 Xin Yang

This report has been approved in partial fulfillment of the requirements for the Degree of MASTER OF SCIENCE in Electrical Engineering

Department of Electrical and Computer Engineering

Report Advisor: Shiyan Hu

Committee Member: Sumit Paudyal

Committee Member: Chaoli Wang

Department Chair: Daniel R. Fuhrmann

# Contents

| Section I. Abs    | tract                        | 3  |
|-------------------|------------------------------|----|
| Section II. Intro | oduction                     | 4  |
| 1.                | History                      | 4  |
| 2.                | Today's power grid           | 4  |
| 3.                | Daily life power consumption | 4  |
| 4.                | Solutions                    | 5  |
| Section III. Algo | prithm                       | 8  |
| 1.                | Dynamic programming method   | 8  |
| 2.                | Proposed algorithm           | 8  |
| 3.                | Example                      | 13 |
| 4.                | Nash equilibrium             | 16 |
| Section IV. Flow  | v charts                     | 19 |
| 1.                | Procedure                    | 19 |
| 2.                | Individual user scheduling   | 20 |
| 3.                | Multiple users scheduling    | 21 |
| Section V. FPG    | GA Structure                 | 22 |
| 1.                | Choosing FPGA board          | 22 |
| 2.                | NIOS II processor            | 23 |

| Section VI. Instruction of implementation in Quartus II | 25 |
|---------------------------------------------------------|----|
| 1. Schematic                                            | 25 |
| 2. SOPC builder                                         | 31 |
| 3. Clock source and Phase Lock Loop(PLL)                | 36 |
| Section VII. Hardware Testing                           | 37 |
| 1. Example 1                                            | 37 |
| 2. Example 2                                            | 38 |
| 3. Example 3                                            | 44 |
| Section VIII. Problems Solution                         | 54 |
| Section IX. Conclusion                                  | 56 |
| Section X. Code in NIOS II                              | 57 |
| Section XI. Appendix                                    | 65 |
| Section XII. References                                 | 80 |

# I. Abstract:

With the development and capabilities of the Smart Home system, people today are entering an era in which household appliances are no longer just controlled by people, but also operated by a Smart System. This results in a more efficient, convenient, comfortable, and environmentally friendly living environment. A critical part of the Smart Home system is Home Automation, which means that there is a Micro-Controller Unit (MCU) to control all the household appliances and schedule their operating times. This reduces electricity bills by shifting amounts of power consumption from the on-peak hour consumption to the offpeak hour consumption, in terms of different "hour price". In this paper, we propose an algorithm for scheduling multi-user power consumption and implement it on an FPGA board, using it as the MCU. This algorithm for discrete power level tasks scheduling is based on dynamic programming, which could find a scheduling solution close to the optimal one. We chose FPGA as our system's controller because FPGA has low complexity, parallel processing capability, a large amount of I/O interface for further development and is programmable on both software and hardware. In conclusion, it costs little time running on FPGA board and the solution obtained is good enough for the consumers.

# II. Introduction

### 1. History

Over a century ago, Nikola Tesla proposed the architecture of the power grid and people followed the design and developed it. During that time, electricity was a luxury resource that was used for lighting. Today, the power grid is used in almost all fields and people may not survive without it. Following the rapid technology development and no longer satisfying the present situation of the power grid, people are now concerned about issues such as greenness, efficiency, sustainability and reliability. The power grid could have the capability to become "smarter", a smarter grid [1] [2].

### 2. Today's power grid

There are many ways to make the power grid become smarter, such as improving the efficiency and reliability, developing environmentally friendly generators, managing the power consumption for consumers and so on so forth [3]. A basic and important part of the smart grid is the smart home. Specifically, if household tasks or daily power consumption could be arranged and scheduled, a more efficient system could be developed.

### 3. Daily life power consumption

The following figure demonstrates the inefficiency power consumption that would occur during daily life. This is a plot of the power consumption for the province Ontario, Canada, on a normal weekday in April 27, 2009 [4].



Figure 1. Power consumption in Ontario on a normal day

We could easily find out that the peak power consumption occurred during the afternoon and low power consumption during the late night when most people were asleep [5]. The inefficiency occurs when the power companies must build the power plant which could support this high demand. These power plants with more capacity need more maintenance and repair cost. Hence, utility companies have to purchase power at higher rate. Furthermore, consumers typically purchase power with same price during different time periods. As the result, consumers would not consider adjusting their power consumption.

#### 4. Solutions

In order to improve this inefficient situation, utility companies would like to choose a "time of use" policy, which means that the power rate could be variable due to the total amount of power consumption. For example, higher power rate occurs during the afternoon and lower power rate occurs during the late night. Hence, for our individual consumers, we would like to have a smart system to help us schedule our household tasks in a reasonable way to reduce our electricity bill. The result could be that the controller for the system assists us to shift parts of

soft loads from the peak demand hours to the low demand hours. Soft loads are the loads can be scheduled, like washing clothes. During the day, the consumer may not need a precise washing time for clothes but ask for an end time to do this job. So, he/she can put the clothes there and let the smart washing machine decide when the clothes should be washed. These kinds of jobs are called soft loads, and hard loads are exactly the opposite. As previously stated, due to the smart scheduling, in terms of the individual the electricity bill is surely reduced when the hourly power rate offered by the utility company remains the same. These kinds of smart shifting behaviors can not only affect our electricity bill, but can also help the environment. For instance, in a typical week in October, one needs to do laundry. Thursday night during the high power demand hours, and Friday morning during the low power demand hours could be chosen as the time to start the laundry. The difference is, the power plants will need to add immediate and long-term generation capacity to support the electricity grid on Friday, which results in an increasing fuel levels in the plants by burning more coal for that kind of capacity buildup. Hence, due to the help of the smart scheduling, the emissions could be reduced [6].

However, if all the consumers in this community considered this reasonable scheduling by using the same smart system, they would all like to shift their loads from the peak demand hours to the low demand hours simultaneously. This would result in a bad situation that the original low demand hours become the high demand hours. Hence, if we need to solve this problem, communication with the other users is one of the prerequisites. Good news is that the smart system has a good capacity of communication. Thus, the controller could schedule the tasks based on the other's arrangement in an optimal way. This solution has two major advantages. On one hand, it has less complexity and results in a time saving strategy. On the other hand, it would allow the users to change the schedule optionally, since whenever the consumer inputs the newest schedule information to the controller in real time, the controller would immediately calculate the best scheduling option based on the other users' schedule.

- 6 -

This method is basically a dynamic programming strategy, which solves complex problems by dividing them into some simpler "sub-problems" and each time solves the sub-problem only once; the current solution depended on the previous computed optimal solution [7]. In this report, our proposed method is dynamic programming-based and focuses on the scheduling for the multi-user-community.

Since we need a Micro-Controller Unit (MCU) for the carrier of this proposed algorithm, FPGA is chosen due to its low complexity, convenient reprogrammability both on software and hardware and the technology trend. This is preliminary work for the controller of the Smart Home system, because in our work, the controller can only schedule the tasks but not perform other smart behaviors like real life wireless remote controls, controlling the power level of the household appliances based on the temperature and so on so forth. Fortunately, it is not hard to do further developments on the FPGA controller and that is exactly its critical advantage.

## III. Algorithm

#### 1. Dynamic programming method

Since our proposed algorithm is dynamic programming method based, I would like to introduce the dynamic programming strategy first. Dynamic programming is more like a divide and conquer algorithm, which divides the problems into pieces of sub-problems and then conquers them step by step. But, the difference is that these sub-problems are usually not mutually independent. If we solve this problem using the divide and conquer algorithm, some of the sub-problems may be calculated many times. Thus, if we could store the solutions of previous subproblems and use them to solve the next one, an abundance of repeated work would be avoided. For example, we could use a table to record all the solutions of the sub-problems we have already solved, no matter whether these subproblems would or would not be used for the future. This is the basic thinking of the dynamic programming algorithm. Keeping in mind, dynamic programming is not a typical algorithm that has a standard mathematical expression or clear structure. It is a way, a ladder, of solving the optimization problem. For different decision processes, there is different dynamic programming method-based algorithm [7].

#### 2. Proposed algorithm

Now, I would like to present our proposed algorithm in the following paragraph. First of all, individual scheduling is presented. Assume that there are *n* hours in the time period, and there are *m* tasks that need to be scheduled during the time period. In our case, each task has 5 factors, which are the start time *Task [i] [0]*, the end time *Task [i] [1]*, power level 1 *Task [i] [2]*, power level 2 *Task [i] [3]* and the total power consumption *Task [i] [4]*. For an easy simulation, we only divide time into hourly periods and only have two options of the power levels for each task. Furthermore, each task can only be operated continuously and can also change its power level during the operating time period. Hence, the total power consumption *Task [i] [4]* for one task would be,

$$Task [i][4] = \sum_{t=Task [i] [0]}^{Task [i] [1]} Energy_{task [i],t}$$
(1)

Since we are on the premise that the utility company is using the "time of use" strategy, different power consumption at different times has different power rates. These prices for the different hours are offered to the customers before the day starts and the prices would not change during that day. For example, Table 1, which is shown below, indicates the price related with certain hours in Ontario from May, 2012 to Apr, 2013. [8] In our case, we assume each hour has 3 factors, *hours [j] [0]*, *hours [j] [1]* and *hours [j] [2]*. *hours [j] [0]* represents the threshold value. If the total power consumption of the community in this hour is larger than the threshold value, the power rate would be *hours [j] [1]*. Otherwise, if the community total power consumption is less than the threshold value, the power rate would become *hours [j] [2]*. Then, we could start our scheduling algorithm in this condition for seeking the best or one of the best solutions to schedule all of the *n* tasks.

| From     | То       | Summer Rate<br>(May - Oct) | Winter Rate<br>(Nov - Apr) | Comparison of Time-of-Use Rates                                                               |  |  |
|----------|----------|----------------------------|----------------------------|-----------------------------------------------------------------------------------------------|--|--|
| 7:00 AM  | 8:00 AM  |                            |                            | 12                                                                                            |  |  |
| 8:00 AM  | 9:00 AM  | mid-peak rate              | on-peak rate               | 11 - 10 -                                                                                     |  |  |
| 9:00 AM  | 10:00 AM | 9.9 cents/kWh              | 11.8 cents/kWh             | 9                                                                                             |  |  |
| 10:00 AM | 11:00 AM |                            |                            | 48 -<br>47 -<br>5 -<br>5 -<br>5 -<br>5 -<br>5 -<br>5 -<br>5 -<br>5                            |  |  |
| 11:00 AM | 12:00 PM |                            |                            | ž 6 -                                                                                         |  |  |
| 12:00 PM | 1:00 PM  |                            |                            | \$ 5 -                                                                                        |  |  |
| 1:00 PM  | 2:00 PM  | on-peak rate               | mid-peak rate              | 3                                                                                             |  |  |
| 2:00 PM  | 3:00 PM  | 11.8 cents/kWh             | 9.9 cents/kWh              | 2 -                                                                                           |  |  |
| 3:00 PM  | 4:00 PM  |                            |                            |                                                                                               |  |  |
| 4:00 PM  | 5:00 PM  |                            |                            | Off Peak Mid Peak On Peak                                                                     |  |  |
| 5:00 PM  | 6:00 PM  | mid-peak rate              | on-peak rate               |                                                                                               |  |  |
| 6:00 PM  | 7:00 PM  | 9.9 cents/kWh              | 11.8 cents/kWh             | Note<br>Off peak rates are charged                                                            |  |  |
| 7:00 PM  | 8:00 PM  |                            |                            | on weekends and holidays.                                                                     |  |  |
| 8:00 PM  | 9:00 PM  |                            |                            | The rates shown to the left<br>apply Monday to Friday.                                        |  |  |
| 9:00 PM  | 10:00 PM |                            |                            |                                                                                               |  |  |
| 10:00 PM | 11:00 PM |                            |                            | Based on a small sample of 152 households,                                                    |  |  |
| 11:00 PM | Midnight |                            |                            | we calculate that, on average, time-of-use<br>consumption typically breaks down as follows:   |  |  |
| Midnight | 1:00 AM  | off-peak rate              | off-peak rate              | consumption typically breaks down as follows.                                                 |  |  |
| 1:00 AM  | 2:00 AM  | 6.3 cents/kWh              | 6.3 cents/kWh              | Off-peak: 63.4%                                                                               |  |  |
| 2:00 AM  | 3:00 AM  |                            |                            | Mid-peak: 16.0%<br>On-peak: 20.5%                                                             |  |  |
| 3:00 AM  | 4:00 AM  |                            |                            |                                                                                               |  |  |
| 4:00 AM  | 5:00 AM  |                            |                            | This results in a blended rate of<br>8.0 cents/kWh.                                           |  |  |
| 5:00 AM  | 6:00 AM  |                            |                            | ·                                                                                             |  |  |
| 6:00 AM  | 7:00 AM  |                            |                            | Help us improve our sample by participating<br>in our <u>Ontario Electricity Usage</u> study. |  |  |

First 600 Kilowatt Hours per month:7.4 cents/kWhAbove 600 kWh:8.7 cents/kWh

Table 1. 2012-2013 Ontario Time of Use Electricity Rates

The easiest way for scheduling these tasks that comes to mind would usually be the enumeration algorithm. However, since we have hundreds of tasks for multiusers and need to schedule them on at least 24 hours, the enumeration algorithm would cost a large amount of time to accomplish the job. This is due to the number of repeating sub problems that would grow exponentially while the size of the input is increasing. Fortunately, our proposed dynamic programming based algorithm is especially useful to deal with this kind of problems. Hence, it is very easy for us to abandon the way using the enumeration algorithm, even though using the enumeration algorithm can get the global optimal solution.

Back to the point, let **Sched (E, C)** be the main function of our scheduling. **E** denotes the current total energy consumption, while **C** denotes the current total cost. Thus, we obtained Table 2 for the optimization process for each task, assuming the start time is 12:00am.

| Hour | 12:00am | 1:00am      | 2:00am         | 3:00am |  |
|------|---------|-------------|----------------|--------|--|
| Ways |         |             |                |        |  |
| 1    | (0,C1)  | (0,C4)      | ► (0,C11)      |        |  |
| 2    | (E1,C2) | (E1,C5)     | (E1,C12)       |        |  |
| 3    | (E2,C3) | (E2,C6)     | (E2,C13)       |        |  |
| 4    |         | (E1+E1,C    | (E1+E1,C14)    |        |  |
| 5    |         | (E1+E2,C8)  | (E1+E2,C15)    |        |  |
| 6    |         | (E2+E1,C9)  | (E2+E1,C16)    |        |  |
| 7    |         | (E2+E2,C10) | (E2+E2,C17)    |        |  |
| 8    |         |             | (E1+E1+E1,C18) |        |  |
| 9    |         |             | (E1+E1+E2,C19) |        |  |
| 10   |         |             | (E1+E2+E1,C20) |        |  |
| 11   |         |             | (E1+E2+E2,C21) |        |  |
| 12   |         |             | (E2+E1+E1,C22) |        |  |
| 13   |         |             | (E2+E1+E2,C23) |        |  |
|      |         |             |                |        |  |

Table 2. Scheduling the tasks without pruning

**E1** and **E2** denote the power level choices of the task respectively. For the first hour, we could schedule the task in 3 ways: no schedule, schedule it in power level 1, or schedule it in power level 2. And each of these schedules would cause a cost named  $C_i$ . Since each schedule is based on the previous solution, we have a cost when this task does not schedule on this hour, or  $(0, C_x)$ . We could easily find out that the solution numbers for *j*th hour is  $3^{2*i}+1$ , and this number we obtained without simplification. With simplification, some of the solution could be abandoned due to its lower energy consumption and higher cost in the same row. For example, looking at the second row, at this hour, there are 2 outputs of cost for total power consumption **E1+E2**. So, if  $C_8$  is bigger than  $C_7$ , which means the

5<sup>th</sup> way costs more, compared to the 6<sup>th</sup> way, while consuming the same power at this time. Thus, the 5<sup>th</sup> way at 1:00am should be abandoned. For the result, the solution following this abandoned solution at the next hour should all be deleted, since for those child solutions, their parent solution is no longer an optimal one. Then, we do the same comparison for all the solutions in the same column mutually as long as no higher cost with lower energy consumption solutions remain. That is a huge simplification for this table, and the new one, as an example, is shown below in Table 3.

| Hour | 12:00am | 1:00am      | 2:00am         | 3:00am |  |
|------|---------|-------------|----------------|--------|--|
| Ways |         |             |                |        |  |
| 1    | (0,C1)  | →(0,C4)     | → (0,C11)      |        |  |
| 2    | (E1,C2) | ₩E1,C5      | (E1,C12)       |        |  |
| 3    | (E2,C3) | (E2,C6)     | (E2,C13)       |        |  |
| 4    |         | (E1+E1,C7)  | (E1+E1,C14)    |        |  |
| 5    |         | (E2+E1,C9)  | (E1+E2,C15)    |        |  |
| 6    |         | (E2+E2,C10) | (E2+E2,C17)    |        |  |
| 7    |         |             | (E1+E1+E1,C18) |        |  |
| 8    |         |             | (E1+E1+E2,C19) |        |  |
| 9    |         | J           | (E2+E1+E2,C20) |        |  |
| 10   |         |             | (E2+E2+E1,C21) |        |  |
| 11   |         |             |                |        |  |
|      |         |             |                |        |  |

Table 3. Scheduling the tasks with pruning

For *j*th hour,  $j \in [1,24]$ , the combination of energy is (*a*\*E1+*b*\*E2), and *a* <= *j*, *b*<= *j*. Hence, we could find out that the solution numbers for *j*th hour become no more than(j + 1)<sup>2</sup>. Assume that in the real life, the power level would usually be an integer number. Let C equals to the maximum value in the E set, then the solution number for **j**th hour becomes no more than C\*j.

After one task scheduling, the next task scheduling which is based on the previous one, would be easy and we would like to schedule it in the same way as the previous one was done. After finishing all the tasks for individual customers, we would like to re-schedule the tasks from the beginning for better scheduling. The advantage of doing so is that more precise optimization would occur. What we need to do is just removing one task from the scheduler, recalculating the total energy consuming for each of hours the task used to schedule on, and reschedule the tasks into the scheduler just like a new task based on the rest tasks. Multi-user tasks scheduling is almost the same as the individual user task scheduling. In multi-user tasks scheduler and repeat the work, which is shown through the example below.

#### 3. Example

Let us assume that we have 9 tasks, and each of them has 5 factors (start time=0, end time=6, power level 1=1, power level 2=2, total energy=4). The hourly price for all hours is \$1 if the total energy consumption for each hour is below or equal to 1 and the hourly price would be \$2 if the total energy consumption for each hour is above 1. Then, the scheduling for the first task is shown below.

| <i>j</i> th<br>hour<br>ways | 1 <sup>st</sup> (0) | 2 <sup>nd</sup> (1) | 3 <sup>rd</sup> (2) | 4 <sup>th</sup> (3) | 5 <sup>th</sup> (4) | 6 <sup>th</sup> (5) | 7 <sup>th</sup> (6) |
|-----------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| 1                           | (0,0)               | ▶(0,0) ▼            | (0,0)               | (0,0)               | →(0,0)              | →(0,0) 🦷            | (0,0)               |
| 2                           | (1,1)               | (1,1)               | (1,1)               | (1,1)               | (1,1)               | (1,1)               | (1,1)               |
| 3                           | (2,4)               | *(2,4)              | *(2,4)              | *(2,4)              | *(2,4)              | *(2,4)              | *(2,4)              |
| 4                           |                     | (2,2)               | (2,2)               | (2,2)               | (2,2)               | (2,2)               | (2,2)               |
| 5                           |                     | *(3,5)              | *(3,5)              | *(3,5)              | *(3,5)              | *(3,5)              | *(3,5)              |
| 6                           |                     | (3,5)               | (3,3)               | (3,3)               | (3,3)               | (3,3)               | (3,3)               |
| 7                           |                     | (4,8)               | *(4,6)              | *(4,6)              | *(4,6)              | *(4,6)              | *(4,6)              |
| 8                           |                     |                     | (4,6)               | (4,4)               | (4,4)               | (4,4)               | (4,4)               |
| 9                           |                     |                     |                     |                     |                     |                     |                     |

\* need to be pruned

Table 4. Example of pruning for task 1

The red ones are the final schedule for task 1 which is the optimum solution as there is no other task scheduled. Now, we need to schedule the next task depending on the task 1's scheduling.

| <i>j</i> th                                                | 1 <sup>st</sup> (0) | 2 <sup>nd</sup> (1) | 3 <sup>rd</sup> (2) | 4 <sup>th</sup> (3) | 5 <sup>th</sup> (4) | 6 <sup>th</sup> (5) | 7 <sup>th</sup> (6) |
|------------------------------------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| hour<br>ways                                               | Prev 1              | Prev 1              | Prev 1              | Prev 1              | Prev 0              | Prev 0              | Prev 0              |
| 1                                                          | (0,1) 🤊             | (0,2)               | (0,3)               | •(0,4)              | (0,4)               | ₹0,4)               | ▶(0,4)              |
| 2                                                          | (1,4)               | (1,5)               | (1,6)               | (1,7)               | (1,5)               | (1,5)               | (1,5)               |
| 3                                                          | (2,6)               | (2,7)               | (2,8)               | (2,9)               | *(2,8)              | *(2,8)              | *(2,8)              |
| 4                                                          | //                  | *(2,8)              | *(2,9)              | *(2,10)             | (2,8)               | <b>(</b> 2,6)       | 2,6)                |
| 5                                                          |                     | *(3,10)             | *(3,11)             | *(3,12)             | <b>*(3,11)</b>      | *(3,9)              | *(3,9)              |
| 6                                                          |                     | (3,10)              | (3,11)              | (3,12)              | (3,10)              | (3,9)               | (3,9)               |
| 7                                                          |                     | (4,12)              | (4,13)              | (4,14)              | *(4,13)             | *(4,12)             | *(4,12)             |
| 8                                                          |                     |                     | *(4,14)             | *(4,15)             | (4,13)              | (4,11)              | (4,10)              |
| 9                                                          |                     |                     |                     |                     |                     |                     |                     |
| * need to be pruned Table 5. Example of pruning for task 2 |                     |                     |                     |                     |                     |                     |                     |

*Prev n* means in this hour period, *n* units' power has already been scheduled due to previous scheduling. After scheduling, we figure out that the total cost is lowest when we arranged the task 2 uniformly in power level 1 on the last four time periods. Repeat the scheduling using our proposed algorithm for the rest tasks. After one time full-tasks scheduling, we arrange all the tasks in the way shown in the following table.

| <i>j</i> th<br>hour<br>tasks | 1 <sup>st</sup> (0) | 2 <sup>nd</sup> (0) | 3 <sup>rd</sup> (2) | 4 <sup>th</sup> (3) | 5 <sup>th</sup> (4) | 6 <sup>th</sup> (5) | 7 <sup>th</sup> (6) |
|------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| 1                            | 1                   | 1                   | 1                   | 1                   |                     |                     |                     |
| 2                            |                     |                     |                     | 1                   | 1                   | 1                   | 1                   |
| 3                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 4                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 5                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 6                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 7                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 8                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 9                            | 2                   | 2                   |                     |                     |                     |                     |                     |

Table 6. All tasks scheduling

In order to optimize the arrangement, we prefer to run it again. First, we should "delete" task 1 from the table. Then, depending on the existing arrangement, reschedule task 1 and reschedule the rest after it. Finally, we would obtain the following arrangement.

| <b>j</b> th<br>hour<br>tasks | 1 <sup>st</sup> (0) | 2 <sup>nd</sup> (0) | 3 <sup>rd</sup> (2) | 4 <sup>th</sup> (3) | 5 <sup>th</sup> (4) | 6 <sup>th</sup> (5) | 7 <sup>th</sup> (6) |
|------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| 1                            | 2                   | 1                   | 1                   |                     |                     |                     |                     |
| 2                            |                     |                     |                     | 1                   | 1                   | 1                   | 1                   |
| 3                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 4                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 5                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 6                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 7                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 8                            | 2                   | 2                   |                     |                     |                     |                     |                     |
| 9                            | 2                   | 2                   |                     |                     |                     |                     |                     |

Table 7. All tasks rescheduling

Then, we met equilibrium, no matter how many further rescheduling we run. For this simple example, this arrangement is one of the optimum solutions. Most of the time, we may not obtain the optimum solution using this algorithm, but we could get a solution very close to the optimum one after rescheduling  $\lambda$  times. In order to determine this  $\lambda$ , we could compare the lowest cost in  $\lambda$ th time and in ( $\lambda$ -1)th time. If the difference is below a certain value, like 1%, which the consumers may accept, the controller shall stop rescheduling the tasks. Then we could do this progress for all the users in the community, just treating multi-users as multi-tasks. Finally, equilibrium would be met and all the users in the community would satisfy the result [9].

#### 4. Nash equilibrium

Our proposed algorithm is to find Nash equilibrium. "In game theory, the Nash equilibrium is a solution concept of a non-cooperative game involving two or more players, in which each player is assumed to know the equilibrium strategies of the other players, and no player has anything to gain by changing only his own strategy unilaterally" [10]. In the system, like our "smart community", where

multiple independent consumers are trying to optimize their own utility unilaterally, Pareto Optimality is very hard to achieve. Pareto optimality or Pareto efficiency means that in the system, "no one can be made better off without making at least one individual worse off [11]." Hence, Nash equilibrium is fair and reasonable among consumers since everyone in the system is choosing the individual optimal strategy depending on others' choices. Following is the normal math definition of Nash equilibrium. In a game set G={S1,...,Sn: u1,...un}, there is a Strategy Profile (s1\*,...,sn\*), where si\* $\in$ Si(Si is the strategy set of player i). If any si\* is the best strategy to the combination of others' strategies (s1\*,...,s\*i-1,s\*i+1,...,sn\*), or ui(s1\*,...,s\*i-1,s\*i,s\*i+1,...,sn\*) ≥ui((s1\*,...,s\*i-1,sij\*,s\*i+1,...,sn\*) where sij $\in$ Si, then the strategies(s1\*,...,sn\*) is a Nash equilibrium of the game set G [12].

Apparently, our algorithm keeps finding the Nash equilibrium until the improvement of the two scheduling solutions for the whole community is less than a certain value. For instance, our solution is implemented in a community with 100 customers. The controller would do the scheduling for the first customer, and repeat the procedure until the last one. The strategy for each scheduling depends on what we have scheduled for the previous ones. After one complete scheduling for these 100 customers, we could obtain a game set G1=  $\{S1_1, S2_1, ..., S100_1: c1_1, c2_1, ..., c100_1\}$ , where  $Si_1$  denotes the strategy of customer *i* and  $c_{j_1}$  denotes the cost of customer *j* using its strategy in the 1<sup>st</sup> scheduling. Then in the 2<sup>nd</sup> scheduling for the whole community, we would change everyone's scheduling strategy one by one, depending on the Strategy Profile of the whole community  $(S1_2, S2_2, ..., Si - 1_2, Si_1, Si + 1_1, ..., S100_1)$ , to obtain a new Strategy Profile  $\{S1_2, S2_2, ..., Si - 1_2 Si_2, Si + 1_1, ..., S100_1\}$ . After a Strategy Profile  $\{S1_2, S2_2, \dots, Si - 1_2 Si_2, Si + 1_2, \dots, S100_2\}$  is obtained, the controller shall start the 3<sup>rd</sup> scheduling for the community. Since each individual scheduling strategy is set depending on all the other strategies in the community, the controller must be able to find a game set  $G_k$ , in which any  $Si_k$  is the best strategy to the combination of others' strategies (s1,...si-1,si+1,...,sn).

- 18 -

Additionally, the best strategy means the strategy with the lowest cost. It is important to remember that finding the Nash equilibrium does not mean that we should find out Minimum(c1+c2+...+c100). However, this **k** value is hard to find since the tasks' number in a community may be very large. In fact, we only need to go through  $\lambda$  times, like mentioned in the earlier paragraph. After  $\lambda$  times scheduling, the difference of the total cost between two complete scheduling for the community is less than a very small value. Then, we would obtain a solution that is very close to the Nash equilibrium and the customers would be satisfied.

The algorithm part is completed and therefore I would like to present the hardware and software setup in the next sections. Due to the complexity of the algorithm, I decided to use the CPU core embedded on the FPGA board to do the calculation, or scheduling. The following are flow charts of the whole procedure of scheduling.

# IV. Flow Charts

#### 1. Procedure





### 2. Individual user scheduling



Figure 2b. Flow chart of the algorithm for individual user scheduling

3. Multiple users scheduling





# V. FPGA Structure

### 1. Choosing FPGA board

At the beginning of the project, I chose Altera's DE0 Nano board, which is shown below, as my controller due to its small size of body, good portability, and enough logic elements and comparatively large memory storage. Cyclone IV EP4C22 FPGA, which has 150,000 logic elements, is embedded in the DE0-Nano board. This FPGA education board also has 32MB SDRAM [13]. However, since it has no Flash Memory embedded on the board, it is kind of difficult to load the task information and hourly electricity price, which needs to be input by the operators from the keyboard or from a file. Hence, I finally abandoned this board and used Altera's DE2 board as the MCU. Even though this board is about 10 times larger than DE0-Nano board and only has Cyclone II FPGA core with 68,416 logic elements and 8MB SDRAM, it still fits this project [14].



Figure 3a. DE0-Nano board

A photograph of the DE2 board is shown below in Figure 3. It demonstrates the location of the key component. The components with a yellow square frame are used in our project.



Figure 3b.DE2 board

### 2. NIOS II processor

In order to implement the comparatively complex algorithm, the NIOS II Processor embedded in Cyclone II FPGA is used in this project. Figure 4, obtained from Altera, shows an example of the architecture of a NIOS II Processor System [15].



Figure 4.Example of a NIOS II Processor System

This architecture is very important for us to build a System on Programmable Chip (SOPC). I will review this figure later when I use the SOPC builder in Quatus II.

# **<u>VI.</u>** Instruction of Implementing in Quartus II

### 1. Schematic

First of all, we need to create the hardware configuration in Quartus II. A new project should be built and after we will create a schematic file as our project's top entity. The overview of the hardware schematic is shown below as the Figure 5a and Figure 5b.







Figure 5. Overview of the schematic2

A system clock is needed, so we will create an input connecting to *CLOCK\_50*, which has 50Mhz power level, followed by the wire named clk. This wire could connect to any modules, which need clock sources.

|        | .cik     |  |
|--------|----------|--|
|        | CLOCK_50 |  |
| PIN_N2 |          |  |

Figure 6.System Clock Source

Use KEY[1] as the *reset* input and KEY[0] to choose the particular hours to demonstrate the tasks scheduled on them.



Figure 7.KEY modules

In this case, if KEY[0] is not pushed, the tasks scheduled on *hour[0]* would be displayed on the board by turning on the LEDs. If KEY[0] is pushed one time, the tasks scheduled on *hour[1]* would be displayed and so on so forth. In this simulation, I set the number of hours up to 24 and the output has 5 bits. The Verilog code of this KEY controlling module is shown below.

KEY,

hours

);

input [0:0]KEY;

output reg [4:0]hours;

always @(negedge KEY[0])

if (hours>5'd22) hours<=0;

else hours<=hours+1;</pre>

#### endmodule

Following is the demonstrated used LEDs output module and its brightness control used counter module. Each LED represents a task. If the power level of the running task is high, the LED would become brighter, otherwise it would become fainter. In our project, I assume that the power level range of all the tasks is between 1 and 15. *Counter* is used to count the clock. Since it only has 4 bits, *counter* will keep increasing between 0 and 15 in 50 Mhz frequency as the same as the system clock. Hence, the brightness of the LED would be set proportionally depending on the power level of the corresponding task, since during each 16 units time period the LED would be turned on in *factor* number unit time period and be turned off in (16 - *factor*) number unit time period.



Figure 8.LEDs output module



Figure 9.Brightness control used counter module

The Verilog codes for these two module are shown below.

```
module simple_counter (
```

CLOCK\_50,

counter\_out

);

*input* CLOCK\_50;

output reg [3:0] counter\_out;

always @ (posedge CLOCK\_50)

begin

counter\_out <= #1 counter\_out + 1;</pre>

end

endmodule

module brightness (

# clk, factor,

counter,

out

);

input clk;

*input* [3:0]factor;

*input* [3:0]counter;

output reg out;

always @ (posedge clk)

if (factor==0) out<=0;</pre>

else if (counter<=factor) out <=1; else out <=0;</pre>

endmodule

### 2. SOPC builder

The most important part is the CPU core of this system. We will use *SOPC builder* to create an on chip system, which is shown below.

| Devia    | e Family: Cyc                        | Name               | 8                                               |        |              | Sour       | ce   |         |
|----------|--------------------------------------|--------------------|-------------------------------------------------|--------|--------------|------------|------|---------|
| Devic    | cyc                                  | clk_5              |                                                 |        |              | Exter      |      |         |
|          |                                      |                    |                                                 |        |              |            |      |         |
| Jse      | Connecti                             | Module Name        | Description                                     | Clock  | Base         | End        | Tags | IRC     |
| V        |                                      | 😑 сри              | Nios II Processor                               |        |              |            |      |         |
|          |                                      | instruction_master | Avalon Memory Mapped Master                     | clk_50 |              |            |      |         |
|          |                                      | data_master        | Avalon Memory Mapped Master                     |        | IRQ          | 0 IRQ 31   | 1    | ←       |
|          | $ \downarrow \downarrow \rightarrow$ | jtag_debug_module  | Avalon Memory Mapped Slave                      |        | 0x01802800   | 0x01802fff |      |         |
| 1        |                                      | onchip_memory2     | On-Chip Memory (RAM or ROM)                     |        |              |            |      |         |
|          | $ \uparrow \rightarrow$              | s1                 | Avalon Memory Mapped Slave                      | clk_50 |              | 0x01801fff |      |         |
| <b>V</b> |                                      | ⊟ jtag_uart        | JTAG UART                                       |        |              |            |      |         |
|          | $   \rightarrow$                     | avalon_jtag_slave  | Avalon Memory Mapped Slave                      | clk_50 | 0x01803130   | 0x01803137 |      | $\succ$ |
| 1        |                                      | ⊟ sdram            | SDRAM Controller                                |        |              |            |      |         |
|          | $ \uparrow \rightarrow$              | s1                 | Avalon Memory Mapped Slave                      | clk_50 |              | 0x00ffffff |      |         |
| 1        |                                      | ☐ cfi_flash        | Flash Memory Interface (CFI)                    |        |              |            |      |         |
|          | $   \rightarrow$                     | • s1               | Avalon Memory Mapped Tristate Slave             | clk_50 |              | 0x017fffff |      |         |
| 1        |                                      | tri_state_bridge_0 | Avalon-MM Tristate Bridge                       |        |              |            |      |         |
|          | $  \rightarrow   \rightarrow$        | avalon_slave       | Avalon Memory Mapped Slave                      | clk_50 |              |            |      |         |
|          | $    \subseteq$                      | tristate_master    | Avalon Memory Mapped Tristate Master            |        |              |            |      |         |
| <b>V</b> |                                      | pio_LED0           | PIO (Parallel I/O)                              |        |              |            |      |         |
|          | $  \longrightarrow$                  | • s1               | Avalon Memory Mapped Slave                      | clk_50 | 0x01803000   | 0x0180300f |      |         |
| 1        |                                      | pio_LED1           | PIO (Parallel VO)                               |        |              |            |      |         |
|          | $  \rightarrow$                      | • s1               | Avalon Memory Mapped Slave                      | clk_50 |              | 0x0180301f |      |         |
| V        |                                      | pio_LED2           | PIO (Parallel I/O)                              |        |              |            |      |         |
|          | $  \rightarrow$                      | • s1               | Avalon Memory Mapped Slave                      | clk_50 |              | 0x0180302f |      |         |
| V        |                                      | pio_LED3           | PIO (Parallel VO)                               |        |              |            |      |         |
|          | $  \rightarrow$                      | • s1               | Avalon Memory Mapped Slave                      | clk_50 |              | 0x0180303f |      |         |
| V        |                                      | pio_LED4           | PIO (Parallel I/O)                              |        |              |            |      |         |
|          | $  \rightarrow$                      | • s1               | Avalon Memory Mapped Slave                      | clk_50 | © 0x01803040 | 0x0180304f |      |         |
| V        |                                      | pio_LED5           | PIO (Parallel I/O)                              |        |              |            |      |         |
|          | $  \rightarrow$                      | • s1               | Avalon Memory Mapped Slave                      | clk_50 |              | 0x0180305f |      |         |
| <b>V</b> |                                      | pio_LED6           | PIO (Parallel I/O)                              |        |              |            |      |         |
|          | $  \rightarrow$                      | • s1               | Avalon Memory Mapped Slave                      | clk_50 | 0x01803060   | 0x0180306f |      |         |
| 1        |                                      | pio_LED7           | PIO (Parallel VO)                               |        |              |            |      |         |
|          | $  \longrightarrow$                  | • s1               | Avalon Memory Mapped Slave                      | clk_50 |              | 0x0180307f |      |         |
| V        |                                      | ☐ pio_LED8         | PIO (Parallel I/O)                              |        |              |            |      |         |
|          | $  \longrightarrow$                  | s1                 | Avalon Memory Mapped Slave                      | clk_50 |              | 0x0180308f |      |         |
| 1        |                                      | □ pio_LED9         | PIO (Parallel VO)                               |        |              |            |      |         |
| _        | $  \rightarrow$                      | s1                 | Avalon Memory Mapped Slave                      | clk_50 |              | 0x0180309f |      |         |
| V        |                                      | □ pio_LED10        | PIO (Parallel I/O)                              |        |              |            |      |         |
| _        | $  \longrightarrow$                  | • s1               | Avalon Memory Mapped Slave                      | clk_50 | 0x018030a0   | 0x018030af |      |         |
| 1        |                                      | ☐ pio_LED11        | PIO (Parallel VO)                               |        |              |            |      |         |
|          | $  \rightarrow$                      | • s1               | Avalon Memory Mapped Slave                      | clk_50 | 🖹 0x018030b0 | 0x018030bf |      |         |
| V        |                                      | □ pio_LED12        | PIO (Parallel I/O)                              |        |              |            |      |         |
| _        | $  \longrightarrow$                  | • s1               | Avalon Memory Mapped Slave                      | clk_50 | 0x018030c0   | 0x018030cf |      |         |
| V        |                                      | ☐ pio_LED13        | PIO (Parallel VO)                               |        |              |            |      |         |
| _        | $  \longrightarrow$                  | s1                 | Avalon Memory Mapped Slave                      | clk_50 |              | 0x018030df |      |         |
| V        |                                      | □ pio_LED14        | PIO (Parallel I/O)                              |        |              |            |      |         |
|          | $\rightarrow$                        | s1                 | Avalon Memory Mapped Slave                      | clk_50 | 0x018030e0   | 0x018030ef |      |         |
| 1        |                                      | □ pio_LED15        | PIO (Parallel I/O)                              |        | 1.           |            |      |         |
| _        | $  \longrightarrow$                  | s1                 | Avalon Memory Mapped Slave                      | clk_50 |              | 0x018030ff |      |         |
| 1        |                                      | □ pio_LED16        | PIO (Parallel I/O)                              |        |              |            |      |         |
|          | $ \longrightarrow $                  | s1                 | Avalon Memory Mapped Slave                      | clk_50 | 0x01803100   | 0x0180310f |      |         |
| 1        |                                      | □ pio_LED17        | PIO (Parallel I/O)                              |        |              |            |      |         |
| _        | $  \rightarrow$                      | s1                 | Avalon Memory Mapped Slave                      | clk_50 | ■ 0x01803110 | 0x0180311f |      |         |
| <b>V</b> |                                      | pio_KEY            | PIO (Parallel VO)<br>Avalon Memory Mapped Slave | clk 50 | ■ 0x01803120 |            |      |         |

Figure 10.SOPC builder setup

CPU is the core and it connects to all of the other parts of system. Jtag uart is used for the FPGA board to communicate with the PC. For example, through the jtag\_uart interface, the input file could be stored from the PC to the Flash Memory embedded on the FPGA board. Then, we created several I/O interfaces like *pio\_key* and *pio\_ledx* to connect the CPU core to the I/O pins on the FPGA board. It's painless to quickly add a System ID component, named sysid, to keep track of whether the BSP driver package currently used is still compatible with the hardware we are trying to run it on. It is also painless to add an Onchip memory. Actually we don't need to use it since I decided to store all the instructions, library, etc. in the SDRAM. Why I would like to use SDRAM as my CPU memory is that the memory space in onchip memory is too small to support the full c library. I could only use the full c library to use file operation in NIOS II. In Figure 4, it shows that we need an *SDRAM* controller to connect the real SDRAM memory and to control its behavior. For each particular FPGA chip, we should consider the configuration of the SDRAM controller. Datasheet of the target board is needed here.

| SDRAM Controller          |
|---------------------------|
| Parameter<br>Settings     |
| Memory Profile > Timing > |
| Presets: Custom           |
| Data width                |
| Bits: 16 💌                |
| _ Architecture            |
| Chip select: 1            |
| Address widths            |
| Row: 12 Column: 8         |

Figure 11.SDRAM Controller Memory Profile configuration



Figure 12.SDRAM Controller Timing Configuration

Flash Memory Interface, named cfi\_flash, is also added in the SOPC. In order to correctly use Flash Memory, indicating in Figure 4, tri\_state\_bridge is also required, and the slave side should connect to the CPU and the master side should connect to the Flash Memory. Flash Memory Interface's setup is shown below.

|                       | MegaCore                                      | Flash Memor                                     | y Ir        |
|-----------------------|-----------------------------------------------|-------------------------------------------------|-------------|
|                       | Parameter<br>Settings                         | Traing                                          |             |
|                       | Attributes Presets: Cust                      | Timing X                                        |             |
|                       | Size                                          |                                                 |             |
|                       | Address Wi                                    | idth (bits): 22                                 |             |
| MegaCore'             |                                               |                                                 | About       |
| Parameter<br>Settings |                                               |                                                 |             |
| Attributes            | Timing                                        |                                                 |             |
| Setup: 40             | Wait: 1                                       | 60 Hold: 40                                     | Units: ns 👻 |
|                       | eriod is 20.0 ns.<br>rity is in units of Ava  | alon clock period.                              |             |
|                       |                                               | te transfers: 40.0 ns                           |             |
|                       | ate time for read and<br>e for read and write | I write transfers: 160 ns<br>transfers: 40.0 ns |             |
|                       |                                               |                                                 |             |

Figure 13.Flash Memory Interface Configuration

The NIOS II CPU core is setup as shown below, notice that SDRAM is chosen.

| Select a Nios II core:                                                                       |                  |                                                                                                  |                                                                                                                                                               |
|----------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                              | ○Nios II/e       | ○Nios II/s                                                                                       | ●Nios II/f                                                                                                                                                    |
| Nios II<br>Selector Guide<br>Family: Cyclone II<br>f <sub>system:</sub> 50.0 MHz<br>cpuid: 0 | RISC<br>32-bit   | RISC<br>32-bit<br>Instruction Cache<br>Branch Prediction<br>Hardware Multiply<br>Hardware Divide | RISC<br>32-bit<br>Instruction Cache<br>Branch Prediction<br>Hardware Multiply<br>Hardware Divide<br>Barrel Shifter<br>Data Cache<br>Dynamic Branch Prediction |
| Performance at 50.0 MHz                                                                      | Up to 5 DMIPS    | Up to 25 DMIPS                                                                                   | Up to 51 DMIPS                                                                                                                                                |
| Logic Usage                                                                                  | 600-700 LEs      | 1200-1400 LEs                                                                                    | 1400-1800 LEs                                                                                                                                                 |
| Hardware Multiply: Embe                                                                      | dded Multipliers | <ul> <li>Hardware Divide</li> </ul>                                                              |                                                                                                                                                               |
| Reset Vector: Mem                                                                            | ory: sdram       | ▼ Offset: 0x0                                                                                    | 0×00800                                                                                                                                                       |
| Exception Vector: Memo                                                                       | ry: sdram        | ↓ Offset: 0x20                                                                                   | 0x008000                                                                                                                                                      |

Figure 14.NIOS II core overview

After we created all of the components of the system and added a system 50Mhz clock, we need to refresh the system and Auto-Assign Base Addresses for all of the components and then generate it.

| -11. 50                          |                           |              |
|----------------------------------|---------------------------|--------------|
| clk_50                           |                           |              |
| reset_n                          |                           |              |
|                                  |                           |              |
| in_port_to_the_pio_KEY[40]       |                           |              |
|                                  | Lo[3.]o]                  | • • •        |
| out_port_from_the_pio_LED0[30]   | <b>—</b> X                |              |
|                                  | L1[3.0]                   |              |
| out_port_from_the_pio_LED1[30]   | <b>—</b> X                |              |
|                                  | .L10[30]                  |              |
| out_port_from_the_pio_LED10[30]  |                           | . : :        |
|                                  | .L11[30]                  | . : :        |
| out_port_from_the_pio_LED11[30]  |                           | . : :        |
|                                  | L12[30]                   | . : :        |
| out_port_from_the_pio_LED12[30]  |                           | . : :        |
|                                  | L13[30]                   | . : :        |
| out_port_from_the_pio_LED13[30]  | X                         | . : :        |
|                                  | L14[3.0]                  | . : :        |
| out_port_from_the_pio_LED14[30]  |                           | . : :        |
|                                  | L16(30)                   | . : :        |
| out_port_from_the_pio_LED15[30]  |                           | . : :        |
|                                  | L16[30]                   | . : :        |
| out_port_from_the_pio_LED16[30]  |                           | . : :        |
|                                  | 14779 01                  | . : :        |
| out_port_from_the_pio_LED17[30]  | L17[30]                   | . : :        |
|                                  | L2[3.0]                   |              |
| out_port_from_the_pio_LED2[30]   |                           |              |
|                                  | L3[3.0]                   | . : :        |
| out_port_from_the_pio_LED3[30]   |                           | . : :        |
|                                  | .L4[30]                   | . : :        |
| out_port_from_the_pio_LED4[30]   |                           | . : :        |
|                                  | L5[3.0]                   | . : :        |
| out_port_from_the_pio_LED5[30]   |                           | . : :        |
|                                  | L6[3.0]                   | . : :        |
| out_port_from_the_pio_LED6[30]   | <b>— X</b>                |              |
|                                  | .L7[30]                   |              |
| out_port_from_the_pio_LED7[30]   | <b>—</b> X                |              |
|                                  | L8[3.0]                   |              |
| out_port_from_the_pio_LED8[30]   | <b>— — ×</b>              |              |
|                                  | L9[3.0]                   |              |
| out_port_from_the_pio_LED9[30]   | <b>— X</b>                |              |
|                                  |                           |              |
| zs_addr_from_the_sdram[110]      | DRAM_ADDR[110]            |              |
| zs_ba_from_the_sdram[10]         |                           | PIN_         |
| zs_cas_n_from_the_sdram -        |                           | PIN_         |
| zs_cke_from_the_sdram -          |                           | PIN_         |
| zs_cs_n_from_the_sdram -         |                           | PIN_         |
| zs_dq_to_and_from_the_sdram[150] |                           | PIN_         |
| zs_dqm_from_the_sdram[10]        | sdram_dpm[10]             | PIN_         |
| zs_ras_n_from_the_sdram -        |                           | PIN_         |
| zs_we_n_from_the_sdram -         |                           | PIN_         |
|                                  |                           | PIN_         |
| select_n_to_the_cfi_flash -      | PUTPUT FL_CE_N            | PIN          |
| tri_state_bridge_0_address[210]  | PUTPUT FL_ADDR[210]       | PIN_         |
| tri_state_bridge_0_data[70]      | = <u>RVIB</u> FL_DQ[70] [ | PIN_         |
| tri_state_bridge_0_readn -       |                           | PIN_         |
| tri_state_bridge_0_writen        |                           | PIN_<br>PIN_ |

Figure 15.SOPC module

The figure above is the quick look of the SOPC module. Since we only create a SDRAM controller in the SOPC, we have to connect the controller pins to the

input pins of the SDRAM embedded on the FPGA board. Followed by the controller pins of *SDRAM* is the flash controller pins. Just a reminder, the Flash Memory reset pin must connect to the reset pin or simply a constant 0.

## 3. Clock source and Phase Lock Loop(PLL)

In order to make sure all the signals are stable on the clock edge, a Phase Lock Loop (PLL) module is needed to create a second clock signal into SDRAM. We should also consider the setup of the PLL module, since that may cause an error when building the project if some values are incorrect for each particular FPGA board. The setup for DE2 board, or Cyclone II EP2C35F672C6 FPGA chip, is shown below.



Figure 16.PLL module

# VII. Hardware Testing

## 1. Example 1

I would like to have two tests to demonstrate my work. First one is the example I analyzed in the part **Algorithm.** Assume there are 10 tasks and we are supposed to assign them in 7 hours. First, since we need to input our information into the FPGA board using txt format file, a Zip file named files.zip should be created under scheduling\_0\_syslib folder, including 2 txt format files named file1.txt and file2.txt storing the tasks information and hourly price information respectively. Due to the software work, the names of these files cannot be modified and the txt files cannot be compressed. See the following figure.

| file1.txt - 记事本     ロ     区       文件(F) 编辑(E) 编载(G) 查看(V) | ☐ file2.txt - 记事本     □     □     ☑       文件① 编辑(E) 裕式(Q) 查看(V) 帮助(H) |                | ng 🕨 scheduling_0_syslib 🕨              |                             | cheduling_0_syslib | <u>م</u> |
|-----------------------------------------------------------|-----------------------------------------------------------------------|----------------|-----------------------------------------|-----------------------------|--------------------|----------|
| 帮助(H)<br>10 个                                             | 1 1 2<br>1 1 2                                                        | 组织 ▼ □ 打开 計    | 打印 刻录 新建文件夹                             |                             | ≡ -                |          |
| 0 6 1 2 4<br>0 6 1 2 4                                    | 1 1 2<br>1 1 2                                                        | ★ 收藏夹          | 名称                                      | 修改日期                        | 类型                 | 大小       |
| 06124<br>06124                                            | 1 1 2 1 1 2                                                           | 🚺 下载           | 퉬 .settings                             | 2012/10/14 18:54            | 文件夹                |          |
| 0 6 1 2 4                                                 | 1 1 2                                                                 | 📃 桌面           | 퉬 Debug                                 | 2012/10/20 16:08            | 文件夹                |          |
| 0 6 1 2 4                                                 | 1 1 2<br>1 1 2                                                        | 📃 最近访问的位置      | 퉬 task_samples                          | 2012/10/17 23:17            | 文件夹                |          |
| 0 6 1 2 4<br>0 6 1 2 4                                    | 1 1 2                                                                 |                | cdtbuild                                | 2012/10/14 18:54            | CDTBUILD 文件        | 2 KB     |
| 0 6 1 2 4                                                 | 1 1 2                                                                 | 篇 库            | .cdtproject                             | 2012/10/20 16:17            | CDTPROJECT 文件      | 3 KB     |
| 0 6 1 2 4                                                 | 1 1 2<br>1 1 2                                                        |                | .project                                | 2012/10/14 18:54            | PROJECT 文件         | 3 KB     |
|                                                           | 1 1 2                                                                 |                | ile1.txt                                | 2012/10/22 16:27            | 文本文档               | 1 KB     |
|                                                           | 1 1 2                                                                 |                | file2.txt                               | 2012/10/22 16:27            | 文本文档               | 1 KB     |
|                                                           | 1 1 2<br>1 1 2                                                        | _              | 💞 files.zip                             | 2012/10/22 16:28            | 快压 ZIP 压缩文件        | 1 KB     |
|                                                           | 1 1 2                                                                 | 迅雷下载           | readme.txt                              | 2012/10/14 18:54            | 文本文档               | 2 KB     |
|                                                           | 1 1 2                                                                 |                | system.stf                              | 2012/10/14 19:05            | STF 文件             | 2 KB     |
|                                                           | 1 1 2<br>1 1 2<br>1 1 2<br>1 1 2<br>1 1 2<br>1 1 2                    | 🜏 家庭組          |                                         |                             |                    |          |
|                                                           | 112                                                                   | 🖳 计算机          |                                         |                             |                    |          |
|                                                           |                                                                       | 🚨 BOOTCAMP (C: |                                         |                             |                    |          |
|                                                           |                                                                       | 💿 DVD RW 驱动器   |                                         |                             |                    |          |
|                                                           |                                                                       | 🕞 学习工作 (E:)    |                                         |                             |                    |          |
|                                                           |                                                                       | Macintosh HD ( |                                         |                             |                    |          |
|                                                           |                                                                       | 游戏娱乐 (G:)      |                                         |                             |                    |          |
|                                                           |                                                                       | Apple iPhone   |                                         |                             |                    |          |
|                                                           |                                                                       |                |                                         |                             |                    |          |
|                                                           |                                                                       |                |                                         | ""<br>書日期: 2012/10/16 21:19 |                    | ,        |
|                                                           |                                                                       |                | 修成日期: 2012/10/22 16:27 回致<br>大小: 284 字节 | ≟口刑: 2012/10/16 21:19       |                    |          |

Figure 17.Input information of Example 1

Then the result run in FPGA shows below from hour 0 to hour 6. We could see that the tasks with higher power level would be brighter.





Figure 18. Hourly power consumed of Example 1

## 2. Example 2

Another example is shown below

| □ file1.txt - 记事本 □ □                                       |                                                    |                    |
|-------------------------------------------------------------|----------------------------------------------------|--------------------|
| 文件(F) 编辑(E) 格式(O) 查看(V) 帮助(H) 文件(F) 编辑(E) 格式(O) 查看(V) 帮助(H) | C→ C→ C Schedualing → Scheduling → scheduling_0_sy | /slib ► 🔻 🍫 👔      |
| 18<br>0 11 1 2 4<br>1 1 2                                   |                                                    |                    |
| 0 11 1 2 4                                                  | 组织 ▼ 創打开 ▼ 打印 刻录 新建文件夹                             |                    |
| 0 11 1 2 4<br>0 11 1 2 4<br>1 1 2                           | 📕 🍌 下载 🔹 🔺 名称                                      | 修改日期 👂             |
|                                                             | 💻 桌面                                               | 2012/10/14 18:54 5 |
| 0 11 1 2 4 1 1 2                                            | 💹 最近访问的位置                                          | 2012/10/22 16:33 3 |
| 0 11 1 2 4<br>0 11 1 2 4<br>1 1 2                           | task samples                                       | 2012/10/22 16:46 3 |
| 0 11 1 2 4 1 1 2                                            | 篇cdtbuild                                          | 2012/10/14 18:54 C |
| 12 22 2 3 6 1 1 2                                           | N版 .cdtproject                                     | 2012/10/22 16:34 C |
| 12 22 2 3 6<br>12 22 2 3 6<br>1 1 2                         | ■ 图片                                               | 2012/10/14 18:54 P |
| 12 22 2 3 6 1 1 2                                           | 🖹 文档 📄 file1.txt                                   | 2012/10/17 22:55 3 |
| 12 22 2 3 6<br>12 22 2 3 6<br>1 1 2                         | □ 迅雷下载                                             | 2012/10/16 22:47 🕇 |
| 12 22 2 3 6 1 1 2                                           | → 音乐                                               | 2012/10/17 23:04 均 |
| 16 23 1 2 4 1 1 2                                           | readme.txt                                         | 2012/10/14 18:54 3 |
| 22 23 1 1 1 1 1 2 1 1 2                                     | ■ system.stf                                       | 2012/10/14 19:05 S |
| 1 1 2                                                       |                                                    |                    |
| 1 1 2 1 1 2                                                 | ▶ 计算机                                              |                    |
|                                                             | SOUTCAMP (C:                                       |                    |
|                                                             | OVD RW 驱动器                                         |                    |
|                                                             | ○ 学习工作 (E:)                                        |                    |
|                                                             | Macintosh HD (                                     |                    |
|                                                             | □ 游戏娱乐 (G:)                                        |                    |
|                                                             | □ IffX0展示 (G:)<br>■ Apple iPhone                   |                    |
|                                                             |                                                    |                    |
|                                                             | 👝 Internal Stora                                   |                    |
|                                                             | S 00 1/2 V                                         |                    |
|                                                             |                                                    | 2012/10/16 21:19   |
| *                                                           | 文本文档 大小: 166 字节                                    | 012/10/10 21:13    |
| · · · · · · · · · · · · · · · · · · ·                       |                                                    |                    |

Figure 19. Input information of Example 2



And the hardware testing result is shown below from hour 0 to hour 23.



Figure 20. Hourly power consumed of Example 2

Since there are only 18 onboard LEDs, I could not demonstrate the tasks with more than 18 in this way. I would like to show the debug result when there are more than 18 tasks, like 99 tasks, and multiple users below.



Figure 21. Multiple users\_1



Figure 21. Multiple users\_2

| (×)= power[0]  | 102 |
|----------------|-----|
| (x)= power[1]  | 104 |
| (x)= power[2]  | 1   |
| (x)= power[3]  | 1   |
| (x)= power[4]  | 1   |
| (x)= power[5]  | 1   |
| (×)= power[6]  | 1   |
| (x)= power[7]  | 1   |
| (×)= power[8]  | 1   |
| (x)= power[9]  | 1   |
| (x): power[10] | 1   |
| (x)= power[11] | 1   |
| (x): power[12] | 105 |
| (x)= power[13] | 105 |
| (x)= power[14] | 0   |
| (x)= power[15] | 0   |
| (x)= power[16] | 1   |
| (x)= power[17] | 1   |
| (x)= power[18] | 1   |
| (x)= power[19] | 1   |
| (×)= power[20] | 1   |
| (x)= power[21] | 1   |
| (×)= power[22] | 8   |
| (x)= power[23] | 11  |

### Figure 22. Accumulated power level for each hours

886

| 🐶 cost_total |  |  |
|--------------|--|--|

### Figure 23. The total cost

It cost about 2 seconds to obtain the result if the total task number is 99.

## 3. Example 3

To demonstrate the effectiveness, I would like to present the simulation of household appliances. The power use for each smart appliance is consulted from the manuals [16][17][18][19].

| Appliance      | Start<br>time | End<br>time | Power<br>level 1<br>(Watt) | Power<br>level 2<br>(Watt) | Total power<br>Consumption<br>(KJ) |
|----------------|---------------|-------------|----------------------------|----------------------------|------------------------------------|
| Mini Oven      | 10:00         | 12:15       | 900                        | 1800                       | 1620                               |
| Rice Cooker    | 11:00         | 12:15       | 400                        | 600                        | 1080                               |
| Clothes Washer | 8:00          | 14:30       | 400                        | 600                        | 1800                               |
| Clothes Dryer  | 14:30         | 17:00       | 2650                       | 5300                       | 19080                              |
| Refrigerator   | 0:00          | 23:45       | 720                        | 720                        | 25920                              |
| Vacuum Cleaner | 0:00          | 18:45       | 1000                       | 1200                       | 3600                               |
| Dishwasher     | 13:15         | 18:45       | 1200                       | 2400                       | 2160                               |
| Water Pump     | 0:00          | 23:45       | 250                        | 1000                       | 2700                               |

Table 5. Input information of household appliances

About the price scheme for a day, we could use the Ontario Time of Use Electricity Rates for Winter I mentioned in **Algorithm** part, which is shown below. (For better calculation and demonstration, I will round the decimal price to the nearest integer)

| From     | То       | Winter Rate(Nov-Apr) |
|----------|----------|----------------------|
| 7:00 AM  | 8:00 AM  | 12 cents/kwh         |
| 8:00 AM  | 9:00 AM  | 12 cents/kwh         |
| 9:00 AM  | 10:00 AM | 12 cents/kwh         |
| 10:00 AM | 11:00 AM | 12 cents/kwh         |
| 11:00 AM | 12:00 PM | 10 cents/kwh         |
| 12:00 PM | 1:00 PM  | 10 cents/kwh         |
| 1:00 PM  | 2:00 PM  | 10 cents/kwh         |
| 2:00 PM  | 3:00 PM  | 10 cents/kwh         |
| 3:00 PM  | 4:00 PM  | 10 cents/kwh         |
| 4:00 PM  | 5:00 PM  | 10 cents/kwh         |
| 5:00 PM  | 6:00 PM  | 12 cents/kwh         |
| 6:00 PM  | 7:00 PM  | 12 cents/kwh         |
| 7:00 PM  | 8:00 PM  | 6 cents/kwh          |
| 8:00 PM  | 9:00 PM  | 6 cents/kwh          |
| 9:00 PM  | 10:00 PM | 6 cents/kwh          |
| 10:00 PM | 11:00 PM | 6 cents/kwh          |
| 11:00 PM | Midnight | 6 cents/kwh          |
| Midnight | 1:00 AM  | 6 cents/kwh          |
| 1:00 AM  | 2:00 AM  | 6 cents/kwh          |
| 2:00 AM  | 3:00 AM  | 6 cents/kwh          |
| 3:00 AM  | 4:00 AM  | 6 cents/kwh          |
| 4:00 AM  | 5:00 AM  | 6 cents/kwh          |
| 5:00 AM  | 6:00 AM  | 6 cents/kwh          |
| 6:00 AM  | 7:00 AM  | 6 cents/kwh          |
|          |          |                      |

Table 6. 2012-2013 Ontario Time of Use Electricity Rates for winter

Since we measured the day as 96 quarter hours in this simulation, we have 96 time periods. For example, time period 0 represents the period from midnight to 12:15 AM, or time period 16 represents the period from 4:00 AM to 4:15 AM. In Ontario, "in the winter months, the higher electricity price is charged for consumption above 1,000 kwh." [8] As shown in Table 1, usually the higher electricity price is about 1 cent/kwh higher than the lower price. Hence, in our simulation, I will consider that if the quarterly power use was over

 $\frac{1,000\frac{kwh}{month}}{30\frac{days}{month} \times 24\frac{hours}{day} \times 4\frac{quarters}{hour}} \approx \frac{0.35kwh}{quarter} = \frac{1260kJ}{quarter}$ 

the price would be 1 more cent plus the original price. The unit of power level shown in Table 5 is Watt, and each of the time period is a quarter. Hence, we need to convert  $J/_{S}$  to  $J/_{quarter}$ , which means each power level need to multiply

by  $60 \times 15 \ S/_{quarter}$ . Therefore, the input information for this simulation is shown below.



Figure 24. Input tasks information



Figure 25a. Input price information



- 48 -

### Figure 25b. Input price information

For clearer demonstration, it is better to add a time display module in Quartus II, which is shown below.



Figure 26. time\_display module

And the Verilog code for this module is shown below.

module time\_display (

| clk,         |
|--------------|
| time_period, |
| HEX0,        |
| HEX1,        |
| HEX2,        |
| HEX3         |
|              |

);

input clk;

input [6:0]time\_period;

output [6:0]HEX0,HEX1,HEX2,HEX3;

reg [3:0]t1,t2,t3,t4;

reg [4:0]tm,ts; //tm: min; ts: sec

always @ (posedge clk)

### begin

*tm*<=*time\_period*/4;

ts<=time\_period%4;

t1<=tm/10;

*t2<=tm%10;* 

case (ts)

### 0: begin

t3<=0;

t4<=0;

#### end

1: begin

t3<=1;

t4<=5;

#### end

2: begin

t3<=3;

t4<=0;

#### end

### 3: begin

t3<=4;

t4<=5;

#### end

#### endcase

end

HEX\_display h1(t1,HEX3);

HEX\_display h2(t2,HEX2);

HEX\_display h3(t3,HEX1);

HEX\_display h4(t4,HEX0);

#### endmodule

module HEX\_display(t,q);
input [3:0]t;
output reg [7:0]q;

#### always begin

#### case (t)

- 0: q<=7'b1000000;
- 1: q<=7'b1111001;
- 2: q<=7'b0100100;
- 3: q<=7'b0110000;
- 4: q<=7'b0011001;
- 5: q<=7'b0010010;
- 6: q<=7'b0000010;
- 7: q<=7'b1111000;
- 8: q<=7'b000000;
- 9: q<=7'b0010000;

*default* q<=7'b1111111;

#### endcase

#### end

#### endmodule

Since it is better to assign one task in more time periods to flat the power consumption curve, I will add another factor that record how many time periods this task is assigned in. If there are many solution with the same lowest cost for one task, the controller would choose the one with the most time periods. Therefore, the result for this simulation is shown below

| Time period  | Task and Power Level                          |  |  |
|--------------|-----------------------------------------------|--|--|
| 0:00->3:00   | Refrigerator(720Watt), Water Pump(250Watt)    |  |  |
| 3:00->10:00  | Water Pump(250Watt)                           |  |  |
| 11:00->11:30 | Mini Oven(900Watt), Rice Cooker(400Watt)      |  |  |
| 11:30->11:45 | Rice Cooker(400Watt), Clothes Washer(400Watt) |  |  |
| 11:45->12:45 | Clothes Washer(400Watt)                       |  |  |
| 12:45->13:45 | Vacuum Cleaner(1000Watt)                      |  |  |
| 13:45->14:15 | Dishwasher(1200Watt)                          |  |  |
| 14:30->16:30 | Clothes Dryer(2650Watt)                       |  |  |
| otherwise    | No tasks assigned                             |  |  |
|              | <b>T</b>     <b>T</b>                         |  |  |

Table 7. Scheduling







The total cost is \$1.42, which is exactly the same value with the result obtained from the enumeration method. This is the optimal solution, which means that, in this case, any other scheduling cannot get lower price than \$1.42. Customers can benefit from our scheduling.

## 4. Example 3

Above is the simulation for individual user, and I will present the simulation for multi-user below. Here is the input information.

| 🧊 file1 - 记事本                              |                                                                  | 文件(F) 编辑(E) 格式(O) 查看(V) 帮助(H)              |
|--------------------------------------------|------------------------------------------------------------------|--------------------------------------------|
| 文件(F) 编辑(E) 格式(O) 查看(V)                    | 📄 file1 - 记事本                                                    | 0 68 2385 4770 19080                       |
| 120                                        | 文件(F) 编辑(E) 格式(O) 查看(V) 帮助(H                                     |                                            |
| usera                                      | userf                                                            | 0 75 900 1080 3600                         |
| 40 49 810 1620 1620                        | 40 49 810 1620 1620                                              | 53 75 1080 2160 2160<br>0 95 225 900 2700  |
| 44 49 360 540 1080                         | 44 49 360 540 1080                                               | userk                                      |
| 32 58 360 540 1800<br>0 68 2385 4770 19080 | 32 58 360 540 1800<br>0 68 2385 4770 19080                       | 40 49 810 1620 1620                        |
| 0 95 648 648 25920                         | 0 95 648 648 25920                                               | 44 49 360 540 1080                         |
| 0 75 900 1080 3600                         | 0 75 900 1080 3600                                               | 32 58 360 540 1800                         |
| 53 75 1080 2160 2160                       | 53 75 1080 2160 2160                                             | 0 68 2385 4770 19080<br>0 95 648 648 25920 |
| 0 95 225 900 2700<br>userb                 | 0 95 225 900 2700<br>userg                                       | 0 75 900 1080 3600                         |
| 40 49 810 1620 1620                        | 40 49 810 1620 1620                                              | 53 75 1080 2160 2160                       |
| 44 49 360 540 1080                         | 44 49 360 540 1080                                               | 0 95 225 900 2700                          |
| 32 58 360 540 1800                         | 32 58 360 540 1800                                               | userl<br>40 49 810 1620 1620               |
| 0 68 2385 4770 19080                       | 0 68 2385 4770 19080                                             | 44 49 360 540 1020                         |
| 0 95 648 648 25920<br>0 75 900 1080 3600   | 0 95 648 648 25920<br>0 75 900 1080 3600                         | 32 58 360 540 1800                         |
| 53 75 1080 2160 2160                       | 53 75 1080 2160 2160                                             | 0 68 2385 4770 19080                       |
| 0 95 225 900 2700                          | 0 95 225 900 2700                                                | 0 95 648 648 25920<br>0 75 900 1080 3600   |
| userc                                      | userh                                                            | 53 75 1080 2160 2160                       |
| 40 49 810 1620 1620<br>44 49 360 540 1080  | 40 49 810 1620 1620<br>44 49 360 540 1080                        | 0 95 225 900 2700                          |
| 32 58 360 540 1800                         | 32 58 360 540 1800                                               | userm                                      |
| 0 68 2385 4770 19080                       | 0 68 2385 4770 19080                                             | 40 49 810 1620 1620<br>44 49 360 540 1080  |
| 0 95 648 648 25920<br>0 75 900 1080 3600   | 0 95 648 648 25920<br>0 75 900 1080 3600                         | 32 58 360 540 1800                         |
| 53 75 1080 2160 2160                       | 53 75 1080 2160 2160                                             | 0 68 2385 4770 19080                       |
| 0 95 225 900 2700                          | 0 95 225 900 2700                                                | 0 95 648 648 25920                         |
| userd                                      | useri                                                            | 0 75 900 1080 3600<br>53 75 1080 2160 2160 |
| 40 49 810 1620 1620<br>44 49 360 540 1080  | 40 49 810 1620 1620<br>44 49 360 540 1080                        | 0 95 225 900 2700                          |
| 32 58 360 540 1800                         | 32 58 360 540 1800                                               | usern                                      |
| 0 68 2385 4770 19080                       | 0 68 2385 4770 19080                                             | 40 49 810 1620 1620                        |
| 0 95 648 648 25920                         | 0 68 2385 4770 19080<br>0 95 648 648 25920<br>0 75 900 1080 3600 | 44 49 360 540 1080<br>32 58 360 540 1800   |
| 0 75 900 1080 3600<br>53 75 1080 2160 2160 | 0 75 900 1080 3600<br>53 75 1080 2160 2160                       | 0 68 2385 4770 19080                       |
| 0 95 225 900 2700                          | 0 95 225 900 2700                                                | 0 95 648 648 25920                         |
| usere                                      | userj                                                            | 0 75 900 1080 3600                         |
| 40 49 810 1620 1620                        | 40 49 810 1620 1620                                              | 53 75 1080 2160 2160<br>0 95 225 900 2700  |
| 44 49 360 540 1080                         | 44 49 360 540 1080                                               | usero                                      |
| 32 58 360 540 1800<br>0 68 2385 4770 19080 | 32 58 360 540 1800<br>0 68 2385 4770 19080                       | 40 49 810 1620 1620                        |
| 0 95 648 648 25920                         | 0 95 648 648 25920                                               | 44 49 360 540 1080                         |
| 0 75 900 1080 3600                         | 0 75 900 1080 3600                                               | 32 58 360 540 1800<br>0 68 2385 4770 19080 |
| 53 75 1080 2160 2160                       | 53 75 1080 2160 2160                                             | 0 68 2385 4770 19080                       |
| 0 95 225 900 2700                          | 0 95 225 900 2700                                                |                                            |
|                                            |                                                                  |                                            |
|                                            |                                                                  |                                            |

Figure 27. Multiple users' tasks

### Then, the simulation result is shown below.

| power          |       | (×)= power[26] | 20412 |
|----------------|-------|----------------|-------|
| ⇔ power[0]     | 25182 | (×)= power[27] | 19512 |
| ⇔= power[1]    | 26082 | (×)= power[28] | 9072  |
| ⇔ power[2]     | 26982 | (×)= power[29] | 9072  |
| (x)= power[3]  | 32652 | (×)= power[30] | 9072  |
| ⇔= power[4]    | 17442 | (≫= power[31]  | 9072  |
| (×)= power[5]  | 16542 | (×)= power[32] | 9072  |
| ≫ power[6]     | 20412 | (×)= power[33] | 9072  |
| (×)= power[7]  | 21312 | (∞)= power[34] | 9072  |
| ≫ power[8]     | 25182 | (×)= power[35] | 9072  |
| (×)= power[9]  | 25182 | (∞)= power[36] | 9072  |
| (×)= power[10] | 20412 | (×)= power[37] | 9072  |
| ≫ power[11]    | 20412 | (×)= power[38] | 9072  |
| ≫ power[12]    | 16542 | (×)= power[39] | 9072  |
| (×)= power[13] | 20412 | (×)= power[40] | 0     |
| ≫ power[14]    | 20412 | (∞)= power[41] | 0     |
| ≫= power[15]   | 20412 | (×)= power[42] | 0     |
| ≫ power[16]    | 21312 | (×)= power[43] | 0     |
| ≫= power[17]   | 21312 | (×)= power[44] | 1170  |
| ≫ power[18]    | 21312 | (×)= power[45] | 14670 |
| ≫= power[19]   | 16542 | (×)= power[46] | 1260  |
| ≫ power[20]    | 20412 | (×)= power[47] | 1170  |
| ⇔ power[21]    | 16542 | (×)= power[48] | 15570 |
| ≫ power[22]    | 20412 | (×)= power[49] | 17100 |
| ⇔= power[23]   | 20412 | (≫= power[50]  | 6660  |
| ∞ power[24]    | 26082 | (∞)= power[51] | 7020  |
| (x)= power[25] | 25182 | (×)= power[52] | 1080  |

| Name           | Value |                             |              |
|----------------|-------|-----------------------------|--------------|
| (*)= power[53] | 1080  |                             |              |
| (*)= power[54] | 1080  |                             |              |
| (x)= power[55] | 30600 | Outline Make Targets (*** V | Disassembly  |
| ⇔= power[56]   | 1008  |                             |              |
| ⇔= power[57]   | 1188  | Name<br>Ø= power[80]        | Value<br>648 |
| ⇔ power[58]    | 1188  | © power[80]                 | 648          |
| ⋈= power[59]   | 648   | (%) power[82]               | 648          |
| (x)= power[60] | 648   | (%)= power[83]              | 648          |
| (x)= power[61] | 648   | (×)= power[84]              | 648          |
| (%)= power[62] | 648   | (≫= power[85]               | 648          |
| (x)= power[63] | 648   | (≫= power[86]               | 648          |
| (x)= power[64] | 648   | (≫= power[87]               | 648          |
| (x)= power[65] | 648   | (x)= power[88]              | 648          |
|                |       | (×)= power[89]              | 648          |
| ⇔= power[66]   | 648   | (×)= power[90]              | 648          |
| ⇔= power[67]   | 648   | ⇔ power[91]                 | 648          |
| ⋈= power[68]   | 648   | ⇔ power[92]                 | 648          |
| ⇔= power[69]   | 648   | 60= power[93]               | 648          |
| (x)= power[70] | 648   | 60: power[94]               | 648          |
| (x)= power[71] | 648   | ⋈• power[95]                | 648          |
| (×)= power[72] | 648   | (xill lowest                | 32767000     |
|                |       | ₩ <sup>®</sup> taskprice    | 0            |
| ⇔= power[73]   | 648   | <del>(⊭</del> j             | 95           |
| (×)= power[74] | 648   | 🚧 m                         | 8            |
| ⇔ power[75]    | 648   | ko≇ i                       | 96           |
| (*)= power[76] | 10548 | ≪ <sup>#</sup> n            | 4            |
| ⋈= power[77]   | 10548 | oo≇ ii                      | 120          |
| (x)= power[78] | 10548 | 🥵 cost_total                | 7168536      |
| (x)= power[79] | 648   | 🛷 tasknumber<br>🗉 🗳 sched   | 120          |

Figure 28. Simulation result

If we don't use any optimized way to assign these tasks, the power consumption curve would become very sharp in the high-demand time periods. After using our proposed algorithm, the curve becomes flatter. The total cost in this case is 7168536/3600=1991.26cents.

The scheduling time is about 10 minutes in this case for 120 tasks. This is for the first scheduling at the beginning of the day. During the day, if the consumer want to change several tasks or add some new tasks to the loads, the controller will only do the scheduling for these tasks, not all the tasks for the whole community. The scheduling time for several tasks is less than 1 minutes. The speed is acceptable.

## VII. Problem Solution

- 1. If the onchip memory is insufficient, use SDRAM to substitute it.
- 2. When build project in NIOS II.

```
Using cable "USB-Blaster [USB-0]", device 1, instance 0x00
Pausing target processor: OK
Initializing CPU cache (if present)
OK
Downloading 00800000 ( 0%)
Downloading 00810000 ( 0%)
Downloaded 77KB in 1.3s (59.2KB/s)
Verifying 00800000 ( 0%)
Verify failed between address 0x800000 and 0x80FFFF
Leaving target processor paused
```

First of all, check the address in SOPC builder to see which component has error, most of the time the errors occur in memory component.

Then check the design in Quartus especially the pin assignment to see if all the pins are correctly connected. Data bus must be bidirectional, and it is very easy to forget it.

If it is the sdram, pll module is needed and the phase shift in pll module should be corrected.

3. The data would be lost in sdram after shut down the FPGA. Altera's DE0 Nano board has NO flash memory.





Switch the button from PROG to RUN

5. Because of the compatibility issues, the following problem would occur very often in Win7 system.

[main] ? (5680) D:\altera\80\quartus\bin\cygwin\bin\sh.exe: \*\*\* fatal error couldn't allocate heap, Win32 error 487, base 0x870000, top 0x890000, reser ve\_size 126976, allocsize 131072, page\_const 4096 2 [main] sh 3244 fork: child -1 died waiting for longjmp before initialization, retry 0, exit code 0x100, errno 1 1

It is not enough to change the compatibility in properties. The reason to cause it is that the capacity of *Cygwin*'s heap is not big enough and Windows does not add its capacity automatically. We need to open the Registry, under HKEY\_LOCAL\_MACHINE or HKEY\_CURRENT\_USER section, add a DWORD key named *heap\_chunk\_in\_mb* under the *Cygwin* folder. Change the value of it to 1024 in decimal to limit the capacity of heap to 1024 Mb. Even though the problem would still occur sometimes, the probability becomes much lower.

# IX. Conclusion

Using our proposed dynamic programming based algorithm could significantly reduce the time complexity to schedule tasks for multi-users, compared with the classical algorithm like the method of enumeration. On the other hand, I am satisfied with the accuracy of finding a solution set that is close to the global optimal solution.

Altera's DE2 FPGA board we used fits our task. Furthermore, Smart Home system consists of a lot of applications to provide improved comfort, convenience and efficiency. Due to FPGA's large amount of I/O interfaces and low complexity, it is very easy for us to do the further development of smart behavior on FPGA.

## X. Coding in NIOS II

```
/*
* Project: DESIGN AND IMPLEMENT DYNAMIC PROGRAMMING BASED DISCRETE
POWER LEVEL SMART HOME SCHEDULING
 * Name : XIN YANG
 * Advisor: SHIYAN HU
* This project consists of 3 parts:
* 1: Read user information from the computer and save it into flash
memory in FPGA
* 2: Schedule the tasks use our proposed dynamic programming based
algorithm
* 3: Demonstrate the results using the onboard LEDs
 *
 */
#include <stdio.h>
#include <stddef.h>
#include <stdlib.h>
#include "system.h"
#include "io.h"
#include "altera_avalon_pio_regs.h"
#define hours 96
#define task max number 200
#define repeat times 10
#define value size 6 //maxium size of each input value
#define BUF SIZE (30*task max number)
// [0] start time [1] end time [2] power level 1 [3] power level 2 [4]
total time
int task[task max number][5];
// [0] Accumulated power threshold [1] unit power level price <=</pre>
threshold [2] unit power level price > threshold
int price[hours][3];
// [0] power consumed [1] cost [2] power level [3] path
int sched[hours][task max number][4];
int best[hours][task max number];
int power[hours] = {0};
int lowest = 9999999;
volatile int taskprice = 0;
int delay;
int condition;
```

```
volatile int j=0;
volatile int m=0;
volatile int i=0;
volatile int n=0;
volatile int ii=0;
volatile int cost total=0;
volatile int tasknumber;
Function: taskread
* Purpose: Read the tasks information from the file input from
           the consumers
void taskread(FILE* fp)
{
 char buffer[BUF SIZE] = {0x20};
 char value[value size];
 int read size;
 int i,j,p;
 int ptr;
  read size = fread (buffer, 1, BUF SIZE, fp); //the total size of the
file
  for (p=0; p<value size; p++) value[p] = 0;</pre>
  for(i=0; i<value size; i++)</pre>
   if ((buffer[i] == 0xa) | (buffer[i] == 0x20) | (buffer[i] == 0xd))
         // if it is a newline or space or Enter, then break
break;
   else value[i] = buffer [i];
  }
 ptr = i+2;
 tasknumber = atoi(value);
  for(i=0; i<tasknumber; i++)</pre>
  {
   for(j=0; j<5; j++)
    {
       for (p=0; p<value size; p++) value[p] = 0;</pre>
       for (p=ptr; p<ptr+value size; p++)</pre>
       {
           if ((buffer[p] == 0xa) \mid (buffer[p] == 0x20) \mid (buffer[p]
== 0xd)) break; // if it is a newline or space or Enter, then break
           else value[p-ptr] = buffer[p];
       }
       ptr = p+1;
       task[i][j] = atoi(value);
       if (buffer[p] == 0xd) {ptr++; break;}
    }
```

```
}
* Function: hoursread
 Purpose: Read the hourly price information from the file input from
         the utility company
void hoursread(FILE* fp)
 char buffer[BUF_SIZE] = {0x20};
 char value[value size];
 int read size;
 int i,j,p;
 int ptr=0;
 read size = fread (buffer, 1, BUF SIZE, fp); //the total size of the
file
 for (p=0; p<value size; p++) value[p] = 0;</pre>
 for(i=0; i<hours; i++)</pre>
   for(j=0; j<3; j++)
   {
      for (p=0; p<value size; p++) value[p] = 0;</pre>
      for (p=ptr; p<ptr+value size; p++)</pre>
      {
         if ((buffer[p] == 0xa) | (buffer[p] == 0x20) | (buffer[p]
== 0xd)) break; // if it is a newline or space or Enter, then break
         else value[p-ptr] = buffer[p];
      }
      ptr = p+1;
      price[i][j] = atoi(value);
      if (buffer[p] == 0xd) {ptr++; break;}
   }
 }
}
*
 Function: Initialization
* Purpose: Open the users' task information file and utility
         company's power rates information file in the
         flash memory
void Initialization()
{
     FILE *fp;
```

}

```
fp = fopen ("/mnt/rozipfs/file1.txt", "r");
  if (fp == NULL)
  {
     printf ("Cannot open file.\n");
     exit (1);
   }
 taskread(fp);
  fclose (fp);
  fp = fopen ("/mnt/rozipfs/file2.txt", "r");
  if (fp == NULL)
   {
     printf ("Cannot open file.\n");
     exit (1);
   }
 hoursread(fp);
  fclose (fp);
}
* Function: cost
 Purpose: Return the cost. If the accumulated power level is larger
        or equal to the threshold value, use the 1st power rate.
        Otherwise, use the 2nd power rate.
int cost(int hour now, int power consume)
{
  int sum;
  if (power consume<=price[hour now][0])</pre>
    sum = price[hour_now][1] * power_consume;
  else
    sum = price[hour_now][2] * power_consume;
 return sum;
}
* Function: Schedule the tasks
 Purpose: Use our proposed algorithm to schedule the tasks
void go(int task now)
{
  int good;
  int cost cach;
```

```
int lowest=9999999;
   int count;
   int lowest time; // it means the last time we found the lowest cost
   int Fst hour=task[task now][0]; // First hour
   lowest time = 0;
   // for repeatly schedualing
   for (j=Fst hour; j<=task[task now][1]; j++)</pre>
            cost total=cost total-cost(j,power[j])+cost(j,power[j]-
best[j][task now]);
            power[j]=power[j]-best[j][task_now];
            best[j][task_now]=0;
        }
    //sched[j][0][0] means the number of situation in hour j
   sched[Fst hour][0][0]=3;
   sched[Fst hour][1][1]=cost total;
   sched[Fst hour][2][0]=task[task now][2];
sched[Fst hour][2][1]=cost total+cost(Fst hour,power[Fst hour]+task[tas
k now][2])-cost(Fst hour,power[Fst hour]);
   sched[Fst hour][2][2]=task[task now][2];
   sched[Fst hour][3][0]=task[task now][3];
sched[Fst hour][3][1]=cost total+cost(Fst hour,power[Fst hour]+task[tas
k now][3])-cost(Fst hour,power[Fst hour]);
   sched[Fst hour][3][2]=task[task now][3];
  // j means hours
   for (j=Fst hour; j<task[task now][1]; j++)</pre>
   {
    sched[j+1][0][0]=1;
    sched[j+1][1][3]=1;
    sched[j+1][1][1]=sched[j][1][1];
    for (m=1; m<=sched[j][0][0]; m++)</pre>
    if ((m==1) | (sched[j][m][0]!=0))
      if (sched[j][m][0]<task[task now][4])</pre>
         //n means solutions
         for (n=2; n<=3; n++)</pre>
         if (sched[j][m][0]+task[task now][n]<=task[task now][4])</pre>
         {
            i=1;
            count=0;
            good=0;
cost cach=sched[j][m][1]+cost(j+1,power[j+1]+task[task now][n])-
cost(j+1,power[j+1]);
            while (i<=sched[j+1][0][0])</pre>
              if (((sched[j][m][0]+task[task now][n]>sched[j+1][i][0])
& (cost cach<=sched[j+1][i][1])) |
((sched[j][m][0]+task[task now][n]>=sched[j+1][i][0]) &
                                    - 65 -
```

```
(cost cach<sched[j+1][i][1])))</pre>
              if (good==0)
              {
               sched[j+1][i][0]=sched[j][m][0]+task[task now][n];
               sched[j+1][i][1]=cost cach;
               sched[j+1][i][2]=task[task now][n];
               sched[j+1][i][3]=m;
               qood=i;
              }
              else {sched[j+1][i][0]=0; sched[j+1][i][1]=0;}
             if ((sched[j][m][0]+task[task now][n]>sched[j+1][i][0]) &
(cost cach>sched[j+1][i][1]))
                count=count+1;
             i=i+1;
            }
           if (count>=sched[j+1][0][0])
           {
               sched[j+1][0][0]=i;
               sched[j+1][i][0]=sched[j][m][0]+task[task now][n];
               sched[j+1][i][1]=cost cach;
               sched[j+1][i][2]=task[task now][n];
               sched[j+1][i][3]=m;
               good=count+1; // good is the new solution added in
the schedule
           }
           if ((sched[j][m][0]+task[task now][n]==task[task now][4]) &
((cost_cach<lowest) | ((cost_cach==lowest) &
(power[lowest_time]>power[j+1]))))
               {
                 lowest=cost cach;
                 lowest time=j+1;
                 cost total=cost cach;
                 for (i=0; i<hours; i++)</pre>
                   best[i][task now]=0;
                 best[j+1][task now]=task[task now][n];
                 for (i=j+1; i>0; i--)
                       best[i-1][task now]=sched[i-
1][sched[i][good][3]][2];
                       good=sched[i][good][3];
                   }
               }
        }
   }
  for (i=0; i<hours; i++)</pre>
       power[i]=power[i] + best[i][task_now];
}
*
  Function: LEDs
 Purpose: Give the outputs of the NIOS II core specific values
                                  - 66 -
```

```
to toggle the LEDs
     void led(int hour)
{
          IOWR ALTERA AVALON PIO DATA(PIO LEDO BASE, best[hour][0]);
          IOWR ALTERA AVALON PIO DATA(PIO LED1 BASE, best[hour][1]);
          IOWR ALTERA AVALON PIO DATA (PIO LED2 BASE, best[hour][2]);
          IOWR_ALTERA_AVALON_PIO_DATA(PIO_LED3_BASE, best[hour][3]);
          IOWR ALTERA AVALON PIO DATA (PIO LED4 BASE, best[hour][4]);
          IOWR ALTERA AVALON PIO DATA(PIO LED5 BASE, best[hour][5]);
          IOWR ALTERA AVALON PIO DATA(PIO LED6 BASE, best[hour][6]);
          IOWR ALTERA AVALON PIO DATA (PIO LED7 BASE, best[hour][7]);
          IOWR ALTERA AVALON PIO DATA (PIO LED8 BASE, best[hour][8]);
          IOWR ALTERA AVALON PIO DATA (PIO LED9 BASE, best[hour][9]);
          IOWR ALTERA AVALON PIO DATA(PIO LED10 BASE,
best[hour][10]);
          IOWR ALTERA AVALON PIO DATA(PIO LED11 BASE,
best[hour][11]);
          IOWR ALTERA AVALON PIO DATA(PIO LED12 BASE,
best[hour][12]);
          IOWR ALTERA AVALON PIO DATA(PIO LED13 BASE,
best[hour][13]);
          IOWR ALTERA AVALON PIO DATA (PIO LED14 BASE,
best[hour][14]);
          IOWR ALTERA AVALON PIO DATA(PIO LED15 BASE,
best[hour][15]);
           IOWR ALTERA AVALON PIO DATA(PIO LED16 BASE,
best[hour][16]);
          IOWR ALTERA AVALON PIO DATA(PIO LED17 BASE,
best[hour][17]);
}
Function: main
* Purpose : Just do it
int main()
{
   Initialization();
   int repeat;
   for (repeat=repeat times; repeat>0; repeat--)
       for (ii=0; ii<tasknumber; ii++)</pre>
          go(ii);
   while (1)
       int tmp;
       tmp = IORD ALTERA AVALON PIO DATA(PIO KEY BASE);
       switch (tmp)
```

```
- 67 -
```

| {    |                                 |
|------|---------------------------------|
| case | <pre>0x00: led(0);break;</pre>  |
| case | <pre>0x01: led(1);break;</pre>  |
| case | <pre>0x02: led(2);break;</pre>  |
| case | <pre>0x03: led(3);break;</pre>  |
| case | <pre>0x04: led(4);break;</pre>  |
| case | <pre>0x05: led(5);break;</pre>  |
| case | <pre>0x06: led(6);break;</pre>  |
| case | <pre>0x07: led(7);break;</pre>  |
| case | <pre>0x08: led(8);break;</pre>  |
| case | <pre>0x09: led(9);break;</pre>  |
| case | <pre>0xa: led(10);break;</pre>  |
| case | <pre>0xb: led(11);break;</pre>  |
| case | <pre>0xc: led(12);break;</pre>  |
| case | <pre>0xd: led(13);break;</pre>  |
| case | <pre>0xe: led(14);break;</pre>  |
| case | <pre>0xf: led(15);break;</pre>  |
|      | <pre>0x10: led(16);break;</pre> |
|      | <pre>0x11: led(17);break;</pre> |
|      | <pre>0x12: led(18);break;</pre> |
|      | <pre>0x13: led(19);break;</pre> |
|      | <pre>0x14: led(20);break;</pre> |
| case | <pre>0x15: led(21);break;</pre> |
| case |                                 |
|      | <pre>0x17: led(23);break;</pre> |
| }    |                                 |
| }    |                                 |
|      |                                 |

return 0;

}

# XI. Appendix

In this appendix, I would like to describe the operating instructions about using Quatus II and NIOS II.

I start with design entry using schematics since all the modules are visible and the project becomes more intuitively clear than using Verilog Code as my top level entity.

First of all, create a project in Quatus II and assign the device. In the Quartus II software, select **File** -> **New Project Wizard**. Create a working directory for the project and then type a name for the top-level design entity. Assign a specific FPGA device in **Family & Device Settings**. In this project, since DE2 board is choosing, we need to change the Device family to **Cyclone II** and select **EP2C35F672C6** as our device. Then **Finish**.

| Device family                          |                    |              |                  | -Show in 'Av | vailable dev | rice' list |
|----------------------------------------|--------------------|--------------|------------------|--------------|--------------|------------|
| Family: Cyclone II                     |                    | -            | Package:         | Any          | -            |            |
| Devices: All                           |                    |              | <u> </u>         | Pin count:   | Any          | •          |
| Target device                          |                    |              | Speed grade: Any |              | -            |            |
| C Auto device select                   | ted by the Fitter  |              |                  | 🔽 Show a     | idvanced d   | evices     |
| <ul> <li>Specific device se</li> </ul> | elected in 'Availa | ible devices | list             | HardCo       | ipy compati  | ble only   |
|                                        |                    |              |                  |              |              |            |
| vailable devices:                      |                    |              |                  |              |              |            |
| Name                                   | Core v             | LEs          | User I/          | Memor        | Embed        | PLL        |
| EP2C20F484I8                           | 1.2V               | 18752        | 315              | 239616       | 52           | 4          |
| EP2C20Q240C8                           | 1.2V               | 18752        | 142              | 239616       | 52           | 4          |
| EP2C35F484C6                           | 1.2V               | 33216        | 322              | 483840       | 70           | 4          |
| EP2C35F484C7                           | 1.2V               | 33216        | 322              | 483840       | 70           | 4          |
| EP2C35F484C8                           | 1.2V               | 33216        | 322              | 483840       | 70           | 4          |
| EP2C35F484I8                           | 1.2V               | 33216        | 322              | 483840       | 70           | 4          |
| EP2C35F672C6                           | 1.2V               | 33216        | 475              | 483840       | 70           | 4          |
| EP2035E67207                           | 1.27/              | 33216        | 475              | 483840       | 70           | 4          |
| •                                      |                    | III          |                  |              |              | P          |
|                                        |                    |              |                  |              |              |            |
| Companion device                       |                    |              |                  |              |              |            |
| Companion device                       |                    |              |                  |              |              |            |

Figure 29. Specify the device

Create a top-level schematic design file Scheduling.bdf by selecting **File** -> **New**, and choose **Block Diagram/Schematic File**, then **OK**.



Figure 30.New BDF

Select **Tools** ->**SOPC Builder** to configure the NIOS II on chip system.



| system Contents System Generation                                                                                                                        |                           |                                                      |                    |         |       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------------------------------|--------------------|---------|-------|
| Component Library                                                                                                                                        | Target                    | Clock Settings                                       |                    |         |       |
| Project<br>                                                                                                                                              | Device Family: Cyclone II | Name                                                 | Source             | MHz     | Remov |
| -Interface Protocols     -Legacy Components     -Memories and Memory Controllers                                                                         | Use C M I Create Net      |                                                      | Clo                | ck Base | End   |
|                                                                                                                                                          |                           |                                                      |                    |         |       |
| Peripherals     PL     Processor Additions     Processors     SLS     Video and Image Processing     Video and Image Processing     Mex     Edit     Add |                           | Verlog<br>VHDL<br>fy a new system name.<br>OK Cancel | Address Map) File  | r\$     |       |
| PILL Processor Additions Processor Additions Structure Processors Stss Video and Image Processing                                                        | Target HDL: @             | Verlog<br>VHDL<br>fy a new system name.<br>OK Cancel | Address Map) [File | ŕ\$     |       |

Figure 31.SOPC System

Select Library -> Processors -> NIOS II Processor to open the wizard as shown below to configure our CPU component. Click Finish

| Component Library                               |                                     |                              |                                   |                                          |                                 |
|-------------------------------------------------|-------------------------------------|------------------------------|-----------------------------------|------------------------------------------|---------------------------------|
| Project                                         | 1111                                | s II Processo                | r                                 |                                          | About Documentation             |
| Library                                         | MagaCare'                           |                              |                                   |                                          | woode poedsentarion             |
| Avalon Verification Suite                       | Parameter                           |                              |                                   |                                          |                                 |
| Bridges and Adapters                            | Settings                            |                              |                                   |                                          |                                 |
| Interface Protocols                             | Core Nos II Car                     | thes and Memory Interfaces   | Advanced Features                 | MMU and MPU Settings > JTAGE             | ebug Module Custom Instructions |
| (i) ASI                                         | Core Nios II                        |                              | /                                 |                                          | - / /                           |
| Ethernet                                        | CONTRACT                            |                              |                                   |                                          |                                 |
| High Speed                                      | Select a Nios II core:              |                              |                                   |                                          |                                 |
| ⊕ PCI                                           |                                     | CARLES HE                    | 0.000                             | CONTRA 110                               |                                 |
| G Serial                                        |                                     | ONios II/e                   | ONios II/s                        | Nios II/f                                | 11                              |
| <ul> <li>Avalen-ST JTAG Inte</li> </ul>         | A17 11                              | RISC                         | RISC                              | RISC                                     |                                 |
| <ul> <li>Avalon-ST Serial Per</li> </ul>        | Nios II                             | 32-bit                       | 32-bit                            | 32-bt                                    |                                 |
|                                                 | Selector Guide                      |                              | Instruction Cache                 | Instruction Cache                        |                                 |
| UART (R5-232 Serial                             | Family: Cyclone II                  |                              | <b>Branch Prediction</b>          | Branch Prediction                        |                                 |
|                                                 |                                     |                              | Hardware Multiply                 | Hardware Multiply                        | 1                               |
| Legacy Components                               | f <sub>system</sub> 50.0 MHz        |                              | Hardware Divide                   | Hardware Divide                          |                                 |
| Memories and Memory Controllers     Peripherals | could: 0                            |                              |                                   | Barrel Shifter                           |                                 |
| Perportan     PLL                               |                                     |                              |                                   | Data Cache                               |                                 |
| Processor Additions                             |                                     |                              |                                   | <b>Oynamic Branch Prediction</b>         |                                 |
| Processor Addeons     Processors                | Performance at 50.0 M               | Hz Up to 5 DMIPS             | Up to 25 DMPS                     | Up to 51 DMPS                            |                                 |
| Nos I Processor                                 | Logic Usage                         | 600-700 LEs                  | 1200-1400 LEs                     | 1400-1800 LEs                            | -                               |
| ⊕ SLS                                           | Hardware Multiply: Em               | bedded Multipliers           | Hardware Divide                   |                                          |                                 |
| Video and Image Processing                      |                                     |                              |                                   |                                          |                                 |
|                                                 | Reset Vector: Me                    | emory.                       | · Offset or                       | 0                                        |                                 |
|                                                 | Exception Vector Memory Offset 0x20 |                              |                                   |                                          |                                 |
|                                                 | Exception vector. Me                | nery                         | → Onsec  0±2                      | N                                        |                                 |
|                                                 | IT include MMU                      |                              |                                   |                                          |                                 |
|                                                 | The second second                   |                              |                                   |                                          |                                 |
|                                                 | Only include the MMU v              | when using an operating sys  | tem that explicitly supports an M |                                          |                                 |
|                                                 | Fast TLB Miss Exception             | in Vector: Memory:           |                                   | - Offset: Ox0                            |                                 |
|                                                 |                                     |                              |                                   |                                          |                                 |
|                                                 | Include MPU                         |                              |                                   |                                          |                                 |
|                                                 | 🔥 Warning: Reset vec                | tor and Exception vector car | not be set until memory devices   | s are connected to the Nios II processor |                                 |
| x x                                             |                                     |                              |                                   |                                          | Cancel Suck Bert > Finish       |
|                                                 |                                     |                              |                                   |                                          | (TINIA)                         |

Figure 32.NIOS II Processor

The NIOS II/f we chose is with the best performance compared to the NIOS II/e and NIOS II/s. Even though we do not need this high performance in our project, I decide to use SDRAM, which has 8MB, as our memory and we do not really care about the extra memory space by choosing the high performance. In some other cases, when we use on chip memory, which has very small memory space like several KB, high performance processors may not be able to be used since there may not be enough memory space to support it. Choose Library -> Interface Protocols -> Serial -> JTAG UART to open wizard and add JTAG UART by clicking Finish. See the figure below.



Figure 33. JTAG UART

Choose Library -> Memories and Memory Controllers -> SDRAM -> SDRAM **Controller** to open the wizard as shown below and add SDRAM to our system.

| DRAM Controller - sdram 0 Brown Brow                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| About Brownstation<br>ender<br>more Profile Trang<br>bethe Custom<br>ta width<br>ta wi |
| About Brownstation<br>ender<br>more Profile Trang<br>bethe Custom<br>ta width<br>ta wi |
| note<br>nour Profile Traing<br>to width<br>to width<br>its fife •<br>hitsectre<br>hip select 5 • Banks 4 •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| note<br>nour Profile Traing<br>to width<br>to width<br>its fife •<br>hitsectre<br>hip select 5 • Banks 4 •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ngo<br>Incur Profile Training Service Countern<br>Its wirdth<br>Its Wirdth<br>Its 16 • Intercharter<br>Anthecture<br>Ithis service Service Countercharter Count                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ter folk in the second                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| nttr: Cuatom • ]<br>ts width<br>Its (16 • )<br>Intecture<br>Inbiselect 5 • Banks (4 • )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ta width<br>ta width<br>ta Star<br>ta width<br>ta width<br>ta width<br>ta Star<br>ta width<br>ta Star<br>ta Width<br>ta Star<br>ta Width<br>ta Star<br>ta Width<br>ta Star<br>ta  |
| ta width<br>ta width<br>ta Star<br>ta width<br>ta width<br>ta width<br>ta Star<br>ta width<br>ta Star<br>ta Width<br>ta Star<br>ta Width<br>ta Star<br>ta Width<br>ta Star<br>ta  |
| ta width<br>ta width<br>ta Star<br>ta width<br>ta width<br>ta width<br>ta Star<br>ta width<br>ta Star<br>ta Width<br>ta Star<br>ta Width<br>ta Star<br>ta Width<br>ta Star<br>ta  |
| Rs [16 ]<br>hileClure<br>hip select [5 ] Banks [4 ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Rs [16 ]<br>hileClure<br>hip select [5 ] Banks [4 ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| hitecture<br>hip select 1 • Banks 4 •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| hitecture<br>hip select 1 • Banks 4 •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| hip select 1 • Banks 4 •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| hip select 1 • Banks 4 •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| draes widths                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| uress wivers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ow: 12 Column: g                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| are pins via tristate bridge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| are prise na matale energy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Controller shares doldgmladdr I/O pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ristate bridge selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| neric memory model (simulation only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Include a functional memory model in the system testbench                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Memory size = 8 MBytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4194304 x 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 64 MBts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Figure 34. SDRAM Controller

The configuration of this SDRAM Controller including Timing Setting is described in the report at page 22 in details.

Click module *CPU* in the component list we have already built, update Reset Vector and Exception Vector as shown in figure below. Then click Finish.

| rameter<br>ettings<br>ore Nios II                                           | Caches | and Memory Interfaces >                         | Advanced Features                                                                                | MMU and MPU Settings                                                                                                                                 | > лас      | Debug Module | Custom Instructi |
|-----------------------------------------------------------------------------|--------|-------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------------|------------------|
| elect a Nios II c                                                           | ore:   |                                                 |                                                                                                  |                                                                                                                                                      |            |              |                  |
|                                                                             |        | Nios II/e                                       | ○Nios II/s                                                                                       | ○Nios II/f                                                                                                                                           |            |              |                  |
| Nios II<br>Selector Guide<br>Family: Cyclone<br>system: 50.0 MH<br>cpuid: 0 |        | RISC<br>12-bit                                  | RISC<br>32-bit<br>Instruction Cache<br>Branch Prediction<br>Hardware Multiply<br>Hardware Divide | RISC<br>32-bit<br>Instruction Cache<br>Branch Prediction<br>Hardware Multiply<br>Hardware Divide<br>Barrel Shifter<br>Data Cache<br>Dynamic Branch P | rediction  |              |                  |
| erformance at 50                                                            |        |                                                 | Up to 25 DMIPS                                                                                   | Up to 51 DMIPS                                                                                                                                       |            |              |                  |
| ogic Usage<br>ardware Multiply                                              |        | 800-700 LEs                                     | Hardware Divide                                                                                  | 1400-1800 LEs                                                                                                                                        | _          |              |                  |
| eset Vector:                                                                | Memo   | ny: sdram                                       | • Offset: 0x0                                                                                    |                                                                                                                                                      | 0×0080000  | 00           |                  |
| ception Vector:                                                             |        |                                                 | · Offset 0x20                                                                                    |                                                                                                                                                      | 0x00800020 | ,            |                  |
|                                                                             |        | n using an operating system t<br>ector: Memory: |                                                                                                  | U<br>Offset: 0x0                                                                                                                                     |            |              |                  |

Figure 25. Nios II Processor Memory configuration

Choose Library -> Memories and Memory Controllers -> Flash -> Flash Memory Interface (CFI) to open the wizard to add the Flash Memory Interface as shown below.

| -Interface Protocols                                 | I Flash Memory Interface (CFI) - cfi_flash                                                                                                                                                                                                                                                                  |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ⊕-Ethernet<br>⊕-High Speed<br>⊕-PCI                  | Flash Memory Interface (CFI)                                                                                                                                                                                                                                                                                |
| Serial                                               | Parameter<br>Settings       Attributes     Timing       Presets:     Custom       Size     Address Width (bits): 22                                                                                                                                                                                         |
|                                                      | Address Width (bits): 22  Data Width (bits): 8  Create an interface to any industry-standard CFI (Common Flash Interface)-compliant flash memory device. Select from a list of tested flash memories or provide interface and timing information for a CFI memory device which does not appear on the list. |
| D     SDRAM      DDR SDRAM Controller MegaCore Funct | (1) Info: Flash memory capacity: 4.0 MBytes (4194304 bytes).                                                                                                                                                                                                                                                |

Figure 26. Flash Memory Interface (CFI)

The configuration of this Flash Memory Interface (CFI) including Timing Setting is also described in the report at page 22 in details.

Look back to Figure 4, the example of a NIOS II Processor System, Tristate Bridge is needed for the system to connect off-chip memory, like Flash Memory. Choose Library -> Bridges and Adapters -> Memory Mapped -> Avalon-MM Tristate Bridge to open the wizard as shown below to add the Tristate Bridge.

| Library                                                                                                                   | Avalon-MM Instate Bridge - tri_state_bridge_0                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Avalon Verification Suite     Aridges and Adapters     Amory Mapped     O Avalon MM DDR Memory Half Rate Bridge           | Avalon-MM Tristate Bridge                                                                                                     |
| Avalon-MM Clock Crossing Bridge     Avalon-MM Pipeline Bridge     Avalon-MM Tristate Bridge     Avalon-MM Tristate Bridge | Parameter<br>Settings<br>[Incoming Signals] > Shared Signals >                                                                |
| JTAG to Avaion Master Bridge     SPI Slave to Avaion Master Bridge     Sriger                                             | Registered                                                                                                                    |
| Interface Protocols     Interface Components                                                                              | Increases off-chip fmax, but also increases latency.  Not registered                                                          |
| Hemories and Memory Controllers     Peripherals     PLL                                                                   | Reduces latency, but also reduces fmax.<br>Note: Check the input setup times analysis in the Quartus compilation report       |
| Processor Additions     Processors                                                                                        | to be sure your bus inputs meet system-level timing requirements. Outquing address and control signals are always registered. |
| te-SLS                                                                                                                    |                                                                                                                               |
|                                                                                                                           |                                                                                                                               |
|                                                                                                                           | Cancel Suck Heat > Finish                                                                                                     |

Figure 37. Tristate Bridge

Remember to connect the Tristate Bridge from the Tristate Master side to the Tristate Slave side of Flash Memory. See figure below.

|   | _ |               | ⊡ cfi_flash        | Flash Memory Interface (CFI)         |        |
|---|---|---------------|--------------------|--------------------------------------|--------|
|   | ľ | $\rightarrow$ | s1                 | Avalon Memory Mapped Tristate Slave  | clk_50 |
|   |   |               | tri_state_bridge_0 | Avalon-MM Tristate Bridge            |        |
| ┝ | ⊢ | $\rightarrow$ | avalon_slave       | Avalon Memory Mapped Slave           | clk_50 |
|   |   | $\smile$      | tristate_master    | Avalon Memory Mapped Tristate Master |        |

Figure 38. Connection between Tristate Master and Tristate Slave

Choose Library -> Peripherals -> Microcontroller Peripherals -> PIO (Parallel I/O) to open the wizard to add the Parallel inputs and outputs as shown below.

| Library                                                                                             | 12 PIO (Parallel I/O) - pio_LED10                                                                                                                 |
|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardson Verification Suite     Bridges and Adapters     Interface Protocols     B-Legacy Components | PIO (Parallel I/O)                                                                                                                                |
|                                                                                                     | Parameter<br>Settings     Input Options     Simulation       Width     Width (1-32 bits) : 4       Direction     © Bidirectional (tristate) ports |
| <ul> <li>Processors</li> <li>SLS</li> <li>→Video and Image Processing</li> </ul>                    | Input ports only     Both input and output ports     Output ports only      Output Port Reset Value                                               |
|                                                                                                     | Output Forreset value       Reset Value:       0x0       Output Register       Enable individual bit setting/clearing                             |

Figure 39. Parallel I/O

Since we need to use 18 LEDs to demonstrate the arrangement of tasks and a KEY input to control the hours, 18 4-bits wide output and 1 5-bits wide input are created in SOPC as shown below.

|              |             | Prevalent memory mapped mistate muster |        |               |            |
|--------------|-------------|----------------------------------------|--------|---------------|------------|
|              |             | PIO (Parallel VO)                      |        |               |            |
|              |             | Avalon Memory Mapped Slave             | clk 50 | 0x01803000    | 0x0180300f |
|              | Fi pio LED1 | PIO (Parallel VO)                      | CIK_00 | - 0201003000  | 0201003001 |
|              |             | Avalon Memory Mapped Slave             | clk_50 | 0x01803010    | 0x0180301f |
| <b>V</b>     | FI pio LED2 | PIO (Parallel VO)                      | Cik_00 | - 0101003010  | 0201003011 |
|              |             | Avalon Memory Mapped Slave             | clk 50 | 0x01803020    | 0x0180302f |
|              | Dio LED3    | PIO (Parallel VO)                      | Cik_00 | 0101003020    | 0201003021 |
|              |             | Avalon Memory Mapped Slave             | clk 50 | ■ 0x01803030  | 0x0180303f |
|              | FI pio LED4 | PIO (Parallel VO)                      | Cik_00 | . 0101003030  | 0101003031 |
|              |             | Avalon Memory Mapped Slave             | clk 50 | 0x01803040    | 0x0180304f |
|              | E pio LED5  | PIO (Parallel VO)                      | 000    | - 0401000010  | 0.01000011 |
|              |             | Avalon Memory Mapped Slave             | clk 50 | 0x01803050    | 0x0180305f |
|              | E pio LED6  | PIO (Parallel VO)                      | 0.00   | - 0.01000000  |            |
|              | s1          | Avalon Memory Mapped Slave             | clk 50 | 0x01803060    | 0x0180306f |
|              | FI pio LED7 | PIO (Parallel VO)                      |        |               |            |
|              | s1          | Avalon Memory Mapped Slave             | clk 50 | 0x01803070    | 0x0180307f |
|              | E pio LED8  | PIO (Parallel I/O)                     | -      |               |            |
|              | s1          | Avalon Memory Mapped Slave             | clk 50 | 0x01803080    | 0x0180308f |
| V            | pio_LED9    | PIO (Parallel VO)                      | -      |               |            |
|              | S1 S1       | Avaion Memory Mapped Slave             | clk_50 |               | 0x0180309f |
|              | ■ pio_LED10 | PIO (Parallel I/O)                     |        |               |            |
|              | → s1        | Avalon Memory Mapped Slave             | clk_50 | 0x018030a0    | 0x018030af |
| V            | pio_LED11   | PIO (Parallel I/O)                     |        |               |            |
|              | ►→ s1       | Avalon Memory Mapped Slave             | clk_50 |               | 0x018030bf |
| <b>V</b>     | □ pio_LED12 | PIO (Parallel I/O)                     |        |               |            |
|              | ►→ s1       | Avalon Memory Mapped Slave             | clk_50 |               | 0x018030cf |
| 1            | pio_LED13   | PIO (Parallel VO)                      |        |               |            |
|              | → s1        | Avalon Memory Mapped Slave             | clk_50 |               | 0x018030df |
| V            | pio_LED14   | PIO (Parallel I/O)                     |        |               |            |
|              | S1 S1       | Avalon Memory Mapped Slave             | clk_50 | Ox018030e0    | 0x018030ef |
| V            | pio_LED15   | PIO (Parallel I/O)                     |        |               |            |
| _            | S1 S1       | Avaion Memory Mapped Slave             | clk_50 | = 0x018030f0  | 0x018030ff |
| $\checkmark$ | pio_LED16   | PIO (Parallel VO)                      |        |               |            |
|              | S1 S1       | Avalon Memory Mapped Slave             | clk_50 | Ox01803100    | 0x0180310f |
| V            | pio_LED17   | PIO (Parallel VO)                      |        |               |            |
|              | s1          | Avalon Memory Mapped Slave             | clk_50 | if 0x01803110 | 0x0180311f |
| V            | □ pio_KEY   | PIO (Parallel VO)                      |        |               |            |
|              | → s1        | Avalon Memory Mapped Slave             | clk_50 | 0x01803120    | 0x0180312f |

Figure 40. Parallel I/O setup

Choose System -> Auto-Assign Base Addresses. After these base addresses are assigned, choose File -> Refresh System. No errors would be displayed in the message window as shown in the figure below

| I Intre die Jaarh Tresh menny capacity 4.9 Mbytes (449204 hbytes).<br>I Intre pag, gettr PO anpla are not Nederleich in best benot. Holdneide skutes will be read from PO inplat during simulation. |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Intr pag_EVEr. PO reputs are set fractional in test bands. Undefined values will be need from DO reputs during semantine.                                                                           |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |
| Ext. Rep. ( Prov. Real ) Connents                                                                                                                                                                   |
|                                                                                                                                                                                                     |
|                                                                                                                                                                                                     |

Figure 41. No errors

**Generate** the system and **exit** the SOPC builder after the system is successfully generated.

In Quatus II, choose **Edit** -> **Insert Symbol...** and you will find the system module we just created in **Libraries**.

| Symbol                                                  |                                 | × |
|---------------------------------------------------------|---------------------------------|---|
| Libraries:                                              | out_port_from_the_pio_LED14[30] |   |
| D brightness                                            | out_port_from_the_pio_LED15[30] |   |
| \$7 hours_display<br>\$7 lpm_constant1<br>\$7 sdram_pll | out_port_from_the_pio_LED16[30] |   |
|                                                         | out_port_from_the_pio_LED17[30] |   |
| ⊕ DE2_Board     ⊕ c:/altera/91/quartus/libraries/       | out_port_from_the_pio_LED2[30]  |   |
|                                                         | out_port_from_the_pio_LED3[30]  |   |
|                                                         | out_port_from_the_pio_LED4[30]  |   |
| Name:<br>                                               | out_port_from_the_pio_LED5[30]  |   |
| system_0                                                | out_port_from_the_pio_LED6[30]  |   |
| Insert symbol as block                                  | out_port_from_the_pio_LED7[30]  |   |
| Launch MegaWizard Plug-In                               | out_port_from_the_pio_LED8[30]  |   |
| MegaWizard Plug-In Manager                              |                                 |   |
| OK Cancel                                               |                                 |   |

Figure 42. Insert Symbol

Click **OK** and put the module at anywhere in the schematic file we created.

Next we need to use Quartus to add a Phase Lock Loop (PLL) Megafunction.

Choose Edit -> Insert Symbol.

Click Megawizard Plug-In Manager and following window would appear.



Figure 43. Megawizard Plug-In Manager Page1

Click Next.

Choose I/O -> ALTPLL. Under "Which device family will you be using", choose Cyclone II since we are using DE2 FPGA development, which is embedded with Altera's Cyclone II device. Choose Verilog HDL and give this PLL module a new name like sdram\_pll. Then click Next.

| MegaWizard Plug-In Manager [page 2a]                                                         | X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Which megafunction would you like to customize?<br>Select a megafunction from the list below | Which device family will you be using?       Cyclone II         Which type of output file do you want to create?       AHDL         AHDL       YHDL         Verilog HDL       Verilog HDL         What name do you want for the gutput file?       Browse         E: MyProject\Schedualing\Scheduling stram_pll       Browse         Return to this page for another create operation       Note: To compile a project successfully in the Quartus II software, your design files must be in the project dialog box (Tools menu), or a user library specified in the User Libraries page of the Settings dialog box (Sourcent), or a user library specified in the User Libraries page of the Settings dialog box (Sourcent), or a user library specified in the User Libraries page of the Settings dialog box (Sourcent), or a user library directories are: |
|                                                                                              | Cancel < <u>B</u> ack <u>N</u> ext > Einish                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Figure 44. Megawizard Plug-In Manager Page2

Configure the ALTPLL followed by the figures shown below.

| ALTPLL                                                       |              |                                                                 |         |           |           |
|--------------------------------------------------------------|--------------|-----------------------------------------------------------------|---------|-----------|-----------|
| 4                                                            |              |                                                                 | About   | Qoc.      | mentatio  |
| Parameter Duput DEDA                                         |              |                                                                 |         |           |           |
| neral/Modes > Inputs/Look > Ck                               | x switchover |                                                                 |         |           |           |
|                                                              |              | Currently selected device family:                               | Cve     | ione II   |           |
| sdram_pll                                                    |              |                                                                 |         | fatch pro | ject/defa |
| inck0 inck0 frequency: 50.000 MHz<br>Operation Model: Nermal | _ c0, ,      | ble to implement the requested PLL                              |         |           |           |
| Chi Ratio Ph (8g) DC (%)<br>c0 1/1 -54.00 50.00              |              | General                                                         |         |           |           |
|                                                              | Cyclone II   |                                                                 |         |           |           |
|                                                              | Cyclone II   | Which device speed grade will you be using?                     | 6       |           |           |
|                                                              |              | Use military temperature range devices only                     |         |           |           |
|                                                              |              | What is the frequency of the indock0 input?                     | 50.00   | 0         | MHz S     |
|                                                              |              | Set up PLL in LyDS mode Data rate:                              | 300.0   | 00        | v Mbp     |
|                                                              |              | PLL type                                                        |         |           |           |
|                                                              |              | Which PLL type will you be using?                               |         |           |           |
|                                                              |              | O Fast PJL                                                      |         |           |           |
|                                                              |              | O Enhanced PU.                                                  |         |           |           |
|                                                              |              | Select the PLL type automatically                               |         |           |           |
|                                                              |              | Operation mode                                                  |         |           |           |
|                                                              |              | How will the PLL outputs be generated?                          |         |           |           |
|                                                              |              | Use the feedback path inside the PLL                            |         |           |           |
|                                                              |              | In Normal Mode                                                  |         |           |           |
|                                                              |              | O In Source-Synchronous Compensation Mode                       |         |           |           |
|                                                              |              | 🔿 In Zero Delay Buffer Mode                                     |         |           |           |
|                                                              |              | Connect the forminic port (bidirectional)                       |         |           |           |
|                                                              |              | O with no compensation                                          |         |           |           |
|                                                              |              | O Create an 'fbin' input for an external feedback (External Fee | dback M | ode)      |           |
|                                                              |              | Which output clock will be compensated for?                     | e0      | 4         |           |
|                                                              |              |                                                                 |         |           |           |

Figure 45. Step 1 PLL configuration



Figure 46. Step 2 PLL configuration



Figure 47. Step 3 PLL configuration

## Then Finish.

Then insert this module in the schematic like we did for adding the system module.

Create other components modules and name the connecting wires between them, and then we could obtain the schematic in Figure 5. After assigning the pin assignment, compiling the project and downloading the sof file to the board, we finish the hardware design part. We could close the Quartus II Programmer or leave it open in the background.

Open Nios II IDE.

Choose File -> Switch Workspace to set the workspace to your project folder.



Figure 48. Switch Workspace

Choose File -> New -> NIOS II C/C++ Application to open the New Project Wizard.

| Name: Scheduling                                                                                                                          | ]     |                                                                                                                                                                                                                                                 |
|-------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                           | ched  | ualing\Scheduling\software Browse                                                                                                                                                                                                               |
| Select Target Hardware.                                                                                                                   |       |                                                                                                                                                                                                                                                 |
| SOPC Builder System PTF                                                                                                                   | File: | E:\MyProject\Schedualing\Scheduling\system_0.ptf 👻 Browse                                                                                                                                                                                       |
| CPU:                                                                                                                                      |       | сри                                                                                                                                                                                                                                             |
| Select Project Template                                                                                                                   |       |                                                                                                                                                                                                                                                 |
| Board Diagnostics<br>Count Binary<br>Hello Freestanding<br>Hello MicroC/OS-II<br>Hello World Small<br>Memory Test<br>Simple Socket Server | •     | Description<br>Reads from a file system in flash memory<br>Details<br>Zip File System reads a zip file system that you program<br>into flash memory, opens two text files from the file<br>system, and prints each of their contents to STDOUT. |
| Simple Socket Server<br>Web Server<br>Zip File System                                                                                     | ~     | This software example runs on the following Nios II $\ensuremath{\mathbf{\tau}}$                                                                                                                                                                |

Figure 49. New Project

Then fill the code in the part "Coding in NIOS II".

Choose **Tools** -> **Flash Programmer**. Under Flash Programmer, create a new flash programmer and configure it. See the figures below.

| 😽 Flash Programmer                        |                                                                                                            |                                                                                                             |                             |  |  |  |  |
|-------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-----------------------------|--|--|--|--|
| Program project to flash memory on ta     |                                                                                                            |                                                                                                             | 🍝                           |  |  |  |  |
| [Target Connection]: Select a JTAG cable. | . If none are available, you must install one first.                                                       |                                                                                                             |                             |  |  |  |  |
| 🕆 🖹 🗶 🖻 🕆                                 | Name: flash programmer                                                                                     |                                                                                                             |                             |  |  |  |  |
| type filter text                          |                                                                                                            |                                                                                                             |                             |  |  |  |  |
| E- Ish Programmer                         | MainTarget Connection Target Board: CYCLONEII < no target board specified in the SOPC Builder system> Help |                                                                                                             |                             |  |  |  |  |
| flash programmer                          |                                                                                                            | Target Board: CYCLONEII <no board="" builder="" in="" sopc="" specified="" system="" target="" the=""></no> |                             |  |  |  |  |
|                                           | Program software project into flash memo                                                                   | ny                                                                                                          |                             |  |  |  |  |
|                                           | scheduling_0                                                                                               | Project:                                                                                                    |                             |  |  |  |  |
|                                           | Nios II ELF Executable:                                                                                    |                                                                                                             | Browse                      |  |  |  |  |
|                                           | Debug/scheduling_0.elf                                                                                     |                                                                                                             |                             |  |  |  |  |
|                                           | Debug/scheduling_0.elf Search                                                                              |                                                                                                             |                             |  |  |  |  |
|                                           | SOPC Builder System PTF File: E:\MyProject\Scheduling\Scheduling\system_0.ptf                              |                                                                                                             |                             |  |  |  |  |
|                                           | CPU:                                                                                                       | сри                                                                                                         | Ţ                           |  |  |  |  |
|                                           | Additional nios2-flash-programmer argu                                                                     |                                                                                                             | Load JDI File               |  |  |  |  |
|                                           | Additional sof2flash arguments:                                                                            |                                                                                                             |                             |  |  |  |  |
|                                           | Additional sorzitash arguments:                                                                            |                                                                                                             |                             |  |  |  |  |
|                                           | Program FPGA configuration data into hardware-image region of flash memory                                 |                                                                                                             |                             |  |  |  |  |
|                                           | FPGA Configuration (SOF): E:\MyProject\S                                                                   |                                                                                                             | Browse                      |  |  |  |  |
|                                           | Hardware Image: Custom                                                                                     | Memory: cfi_flash 		 Offset: 0x0                                                                            |                             |  |  |  |  |
|                                           |                                                                                                            | ☑ Program a file into flash memory                                                                          |                             |  |  |  |  |
|                                           | File: E:\MyProject\Schedualing\Sched                                                                       | duling\scheduling_0_syslib\files.zip                                                                        | Browse                      |  |  |  |  |
|                                           | Memory: cfi_flash                                                                                          | ▼ Offset: 0x100000                                                                                          |                             |  |  |  |  |
|                                           | ☑ Validate Nios II system ID before software                                                               | e download                                                                                                  |                             |  |  |  |  |
|                                           |                                                                                                            | Ap                                                                                                          | nlu Pauart                  |  |  |  |  |
|                                           |                                                                                                            | Ар                                                                                                          | pl <u>y</u> Re <u>v</u> ert |  |  |  |  |
| ٩                                         |                                                                                                            |                                                                                                             |                             |  |  |  |  |
| ?                                         |                                                                                                            | Program                                                                                                     | m Flash Close               |  |  |  |  |

Figure 50. Flash Programmer

Offset must be 0x100000 in this case. Then click **Program Flash.** Following messages would appear and that is fine.

Choose **Project** -> **Properties** to open the wizard and choose **Associated System Library**, then click **System Library Properties.** 

| Properties for scheduling_0                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                       |                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| type filter text                                                                                                                                                                                                                                                                                                                | Associated System Library                                                                                                                                                             | ⇔ • ⇔ •                       |
| <ul> <li>Info</li> <li>Associated System Library</li> <li>Builders</li> <li>C/C++ Build</li> <li>C/C++ Documentation</li> <li>C/C++ File Types</li> <li>C/C++ Include Paths and S</li> <li>C/C++ Indexer</li> <li>C/C++ Indexer</li> <li>C/C++ Make Project</li> <li>C/C++ Project Paths</li> <li>Project References</li> </ul> | Project<br>Target: Nios II Application<br>System Library: scheduling_0_syslib<br>Note: A rebuild of this project is recommended if the associated system<br>System Library Properties | Browse<br>library is changed. |
|                                                                                                                                                                                                                                                                                                                                 | Help Restore Defau                                                                                                                                                                    | lts <u>A</u> pply             |
|                                                                                                                                                                                                                                                                                                                                 | ОК                                                                                                                                                                                    | Cancel                        |

Figure 51. Properties of the project

Remember to set the memory location to *SDRAM* and uncheck *Small C library*. Small C library has no file relate operation command. See the figure below.

| Properties for scheduling_0_sy                                                                                                                                                                                                        | yslib                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                           |                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| type filter text                                                                                                                                                                                                                      | System Library                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                           | ⇔ - ⇒ -        |
| Info<br>- Builders<br>- C/C++ Build<br>- C/C++ Build<br>- C/C++ File Types<br>- C/C++ Include Paths and S<br>- C/C++ Include Paths and S<br>- C/C++ Make Project<br>- C/C++ Project Paths<br>- Project References<br>- System Library | Target Hardware         SOPC Builder System:         E:\MyProj         CPU:         cpu         System Library Contents         RTOS:         RTOS Options         stdout:         stdout:         stderr:         stdin:         System clock timer:         Timestamp timer:         Max file descriptors:         Program never exits         Isophysent C++         Lightweight device driver API         Link with profiling library         Onimplemented instruction har         Software Components | ect\Schedualing\Scheduling\system_0.ptf<br>none (single-threaded) •<br>itag_uart •<br>itag_uart •<br>itag_uart •<br>none •<br>32<br>Clean exit (flush buffers)<br>Reduced device drivers<br>Small C library<br>ModelSim only, no hardware support<br>ModelSim only, no hardware support<br>adder • Run time stack checking | Linker Script<br>Custom linker script<br>none<br>Use auto-generated linker script<br>Program memory (text):<br>Read-only data memory (rodata):<br>Read/write data memory (rodata):<br>Heap memory:<br>Stack memory:<br>Use a separate exception stack<br>Exception stack memory:<br>Maximum exception stack size (bytes): | Browse         |
| <                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                            | Help                                                                                                                                                                                                                                                                                                                      | Defaults Apply |
| 0                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                                         | K Cancel       |

Figure 52. System Library

Then click Software Components, check the following information to make sure it is right.

| Software Components           |                                 |                                     |                                        |                            |
|-------------------------------|---------------------------------|-------------------------------------|----------------------------------------|----------------------------|
| Altera Host Based File System | Altera Zip Read-Only File Syste | em                                  |                                        |                            |
| NicheStack TCP/IP Stack       |                                 | HAL file system. The contents becom | ne available via C standard library fu | unctions, such as fopen(). |
|                               | Flash memory device             | cfi_flash ╺                         |                                        |                            |
|                               | Offset                          | 0x100000                            | ]                                      | 1                          |
|                               | Mount-point                     | /mnt/rozipfs                        |                                        |                            |
|                               | Zip file (must be uncompressed) | files.zip                           |                                        | Browse                     |
|                               |                                 |                                     |                                        |                            |
|                               |                                 |                                     |                                        |                            |
|                               |                                 |                                     |                                        |                            |
|                               |                                 |                                     |                                        |                            |
|                               |                                 |                                     |                                        |                            |
|                               |                                 |                                     |                                        |                            |
| 4                             |                                 |                                     |                                        | Restore Defaults           |
| 0                             |                                 |                                     | Ok                                     | Cancel                     |

Figure 53. Software Components

Finally, build up our project and Debug it and we could see the results on FPGA.

## REFERENCES

- [1] "The smart grid: An introduction," U.S. Dept. Energy, 2009.
- [2] M. Shinwari, "A Water-Filling Based Scheduling Algorithm for the Smart Grid." *Smart Grid, IEEE Transactions on.,* vol. 3(2): 710-719, Feb. 2012
- [3] R. Krishnan, "Meters of tomorrow," *IEEE Power Energy Mag.*, vol. 6, pp. 92–94, Mar. 2008.
- [4] (2009). "Ontario's MicroGeneration Feed-Tarriff." Available: <u>http://renaud.ca/wordpress/?tag=cost-of-electricity</u>
- [5] "Ontario demand and market prices," Independent Electricity System Operator, Sep. 2011 [Online]. Available: <u>http://www.ieso.ca</u>
- [6] (2012). "How does Power Stoplight help the environment?" Available: <u>http://www.powerstoplight.com/?page\_id=10</u>
- [7] A. Lew and H. Mauch, *Dynamic Programming: A Computational Tool.* Springer-Verlag Berlin Heidelberg 2007
- [8] (2013) "Ontario Hydro Rates: Time-of-use Pricing", Apr. 2013, Available: http://www.ontario-hydro.com/index.php?page=current\_rates
- [9] M. J. Osborne and A. Rubinstein, *A Course in Game Theory*. Cambridge, MA: MIT, 1994.
- [10] Osborne, Martin J., and Ariel Rubinstein. *A Course in Game Theory*. Cambridge, MA: MIT, 1994. Print
- [11] Barr, N. (2004). *Economics of the welfare state*. New York, Oxford University Press (USA)
- [12] Nash, J. F. "Non-Cooperative Games." Ann. Math. 54, 286-295, 1951.
- [13] "DE0-Nano Development and Education Board," Altera, Available: <u>http://www.altera.com/education/univ/materials/boards/de0-nano/unv-de0-nano-board.html</u>
- [14] "Cyclone II Device Handbook," Altera, Available: http://www.altera.com/literature/hb/cyc2/cyc2\_cii5v1.pdf

- [15] "Nios II Processor Reference Handbook," Altera, Available: <u>http://www.altera.com/literature/lit-</u> <u>nio2.jsp?GSA\_pos=1&WT.oss\_r=1&WT.oss=NIOS%20II%20Processor%</u> <u>20System</u>
- [16] Manual for Breville the Smart Oven, Available: http://www.brevilleusa.com/media/mediaappearance/4539/BOV800XL.pdf
- [17] Manual for Breville the Risotto Plus, Available: <u>http://www.brevilleusa.com/media/mediaappearance/12563/BRC600XL\_I</u> <u>B\_A12\_FA\_LowRes.pdf</u>
- [18] Features for Samsung 7.5 cu. Ft. King-size Capacity, Electric Touch Screen LCD Front-Load Dryer, Available: <u>http://www.samsung.com/us/appliances/washers-</u> dryers/DV457EVGSGR/AA-specs
- [19] "Estimating Appliance and Home Electronic Energy Use", Energy.gov, August 31, 2012, Available: <u>http://energy.gov/energysaver/articles/estimating-appliance-and-home-electronic-energy-use</u>