Ask Computer Engineering Expert

Fuzzy Controller for the Inverted Pendulum Problem

Instructions

Your task is mainly to design and implement a fuzzy controller (Zero-order Sugeno Fuzzy Inference System) for balancing an inverted pendulum system. A written report detailing your system design and characterisation of its performance must accompany your program submission.

A start-up program using second-order derivative physics equations and the emulated BGI graphics library are provided, simulating the complete dynamics of the cart-pendulum system. In addition, it also includes a function for collecting data points for plotting a control surface, and a fuzzy logic engine that you can utilise to implement a complete fuzzy controller.
Details of the requirements:

Part 1: Fuzzy System Design

1. Use the following inputs (you may combine several inputs together, as suggested in Yamakawa's paper):
• x - position of the cart
• x_dot - horizontal velocity of the cart
• theta - angle of the pole with respect to the vertical
• theta_dot - angular velocity of the pole

2. Write the fuzzy control rules.
• Depending on your controller design, you may take two of the inputs together to create a FAMM (Fuzzy Associative Memory Matrix).
• You may use multiple FAMMs, each with two inputs, or one big FAMM that uses all the inputs at once.
• You can start by examining the fuzzy rules (based on Stephen Welstead's book) used in the lectures for the inverted pendulum. In the lecture slides, we have two FAMMs that were combined together to solve the balancing problem. However, the fuzzy systems for the inverted pendulum described in the lectures need to be further improved, calibrated and tested.
• A better fuzzy controller design can be found in Takeshi Yamakawa's paper, entitled "A Fuzzy Inference Engine in Nonlinear Analog Mode and Its Application to a Fuzzy Logic Control". Refer to page 517 of his paper to see what inputs were used in his design. This research paper is available for download in our Stream website.

3. Define the rule outputs associated with each of the fuzzy rules (e.g. NL = -40, PL = 40, etc.). Note that we are implementing a Zero-Order Sugeno Fuzzy Inference System, and so the rule outputs are constants.

4. Define the fuzzy sets corresponding to the linguistic terms in your fuzzy rules.
• The fuzzy sets need to be defined according to the range of possible values for the input variables.
• Example: Input range of input variables:
o x: [-2.4 - 2.4] meters
o x_dot: [-4.5, 4.5] meters/second
o angle: [-0.15, 0.15] radians
o angle_dot: [-0.22, 0.22] radians/second

5. Implement the fuzzy sets as membership functions in your program. You may use any of the membership functions we discussed in class. (The fuzzy engine contains a trapezoidal membership function, if you want to use it.)
6. Define the defuzzification method for your system. (The fuzzy engine contains a centroid defuzzification method, if you want to use it.)
7. Incorporate your fuzzy controller into the start-up program provided. (Tips on where to insert codes are provided in the start-up codes)
8. Note that in the start-up codes, there are blocks of statements that should not be modified as they are part of the implementation of the dynamics of the system. There are comments in the codes that identify these blocks of codes.
9. It is up to you to write and add any functions, classes or data structures that you may require to complete the system.
10. Your simulation system should demonstrate that the fuzzy controller is able to balance the inverted pendulum.

Part 2: System Calibration

11. Calibrate your fuzzy controller by modifying the rules, shape of membership functions, etc. until it is able to balance the pendulum without exceeding the boundaries of the platform. Aim for a control solution that can balance the pendulum in a smooth fashion.

Part 3: Results and Analysis

12. Generate the control surface data points using void generateControlSurface().
• The control surface comes with the following dimensions: angle of pole, angular velocity of pole, and Force calculated by the fuzzy controller.
• Calling generateControlSurface() will apply all the necessary physics equations to update the state of the world. It will also store the data points into a text file (data_angle_vs_angle_dot.txt) that you can use later for 3D surface plotting using MS-Excel.
• Note that a statement calling generateControlSurface() is already in place inside the main function
13. Plot the control surface using MS-Excel. Include the Excel file in your assignment submission.
• MS-Excel requires a specific format for the tabulation of data points for 3D surface generation. Therefore, to plot a 3D surface, make sure that you delete the first zero value on the first row (upper-left corner) of the data points in the worksheet. The zero value is only there to align the columns properly, as required by the tabulation of data points by Excel.

14. Test the fuzzy controller system by setting the initial angle of the pole with different values. The bigger the initial angle is, the more challenging the problem becomes for the controller. Record the maximum angle that your system can successfully handle.
1. Characterise your control system by answering the following questions:
o What is the smallest (most negative) and biggest (most positive) initial angles that your fuzzy controller can handle?
- You can check this by setting prevState.angle to represent the initial angle of the pole, and running the simulation to see if the pole can still be balanced by the controller. As an example, to set the initial angle to 8 degrees, you can have the following statement: prevState.angle = 8 * (3.14/180));
- Note that the multiplier (3.14/180) converts the angle to radians.

o For how long can your fuzzy controller successfully balance the pendulum?

Part 4: Documentation

• Fuzzy Logic Controller: Discuss the complete fuzzy system that you have designed
o System Design:
- Show details of the inputs, fuzzy rules, fuzzy sets, rule outputs and defuzzification method
o Controller Performance:
- Specify the smallest (most negative) and biggest (most positive) initial angles that your fuzzy controller can successfully handle.
- Specify the maximum time your fuzzy controller can successfully balance the pendulum, and at what initial pole angle and cart position.
o Submit this as a type-written report (e.g. MS-Word/ OpenOffice/pdf file).
• Control Surface: Show the plot of the (3D) control surface (angle vs. angular velocity)
o Submit the actual MS-Excel file.


Submission Requirements Checklist:
1. Complete source code of your fuzzy controller and simulation system (*.cpp, *.h, makefile, etc.)
2. Documentation: (MS-Word/OpenOffice/pdf) and MS-Excel files

References
1. T. Yamakawa, A Fuzzy Inference Engine in Nonlinear Analog Mode and Its Application to a Fuzzy Logic Controller, IEEE Transaction on Neural Networks, vol. 4, no. 3, pp. 496-522, 1993

2. Neural Network and Fuzzy Logic Applications in C-C++ Paperback - August, 1994  by Stephen T. Welstead Nothing follows.

Attachment:- fuzzy_logic_engine.rar

Computer Engineering, Engineering

  • Category:- Computer Engineering
  • Reference No.:- M91976202

Have any Question?


Related Questions in Computer Engineering

Does bmw have a guided missile corporate culture and

Does BMW have a guided missile corporate culture, and incubator corporate culture, a family corporate culture, or an Eiffel tower corporate culture?

Rebecca borrows 10000 at 18 compounded annually she pays

Rebecca borrows $10,000 at 18% compounded annually. She pays off the loan over a 5-year period with annual payments, starting at year 1. Each successive payment is $700 greater than the previous payment. (a) How much was ...

Jeff decides to start saving some money from this upcoming

Jeff decides to start saving some money from this upcoming month onwards. He decides to save only $500 at first, but each month he will increase the amount invested by $100. He will do it for 60 months (including the fir ...

Suppose you make 30 annual investments in a fund that pays

Suppose you make 30 annual investments in a fund that pays 6% compounded annually. If your first deposit is $7,500 and each successive deposit is 6% greater than the preceding deposit, how much will be in the fund immedi ...

Question -under what circumstances is it ethical if ever to

Question :- Under what circumstances is it ethical, if ever, to use consumer information in marketing research? Explain why you consider it ethical or unethical.

What are the differences between four types of economics

What are the differences between four types of economics evaluations and their differences with other two (budget impact analysis (BIA) and cost of illness (COI) studies)?

What type of economic system does norway have explain some

What type of economic system does Norway have? Explain some of the benefits of this system to the country and some of the drawbacks,

Among the who imf and wto which of these governmental

Among the WHO, IMF, and WTO, which of these governmental institutions do you feel has most profoundly shaped healthcare outcomes in low-income countries and why? Please support your reasons with examples and research/doc ...

A real estate developer will build two different types of

A real estate developer will build two different types of apartments in a residential area: one- bedroom apartments and two-bedroom apartments. In addition, the developer will build either a swimming pool or a tennis cou ...

Question what some of the reasons that evolutionary models

Question : What some of the reasons that evolutionary models are considered by many to be the best approach to software development. The response must be typed, single spaced, must be in times new roman font (size 12) an ...

  • 4,153,160 Questions Asked
  • 13,132 Experts
  • 2,558,936 Questions Answered

Ask Experts for help!!

Looking for Assignment Help?

Start excelling in your Courses, Get help with Assignment

Write us your full requirement for evaluation and you will receive response within 20 minutes turnaround time.

Ask Now Help with Problems, Get a Best Answer

Why might a bank avoid the use of interest rate swaps even

Why might a bank avoid the use of interest rate swaps, even when the institution is exposed to significant interest rate

Describe the difference between zero coupon bonds and

Describe the difference between zero coupon bonds and coupon bonds. Under what conditions will a coupon bond sell at a p

Compute the present value of an annuity of 880 per year

Compute the present value of an annuity of $ 880 per year for 16 years, given a discount rate of 6 percent per annum. As

Compute the present value of an 1150 payment made in ten

Compute the present value of an $1,150 payment made in ten years when the discount rate is 12 percent. (Do not round int

Compute the present value of an annuity of 699 per year

Compute the present value of an annuity of $ 699 per year for 19 years, given a discount rate of 6 percent per annum. As