Class times: this is an individual studies class, meetings by appointment
Instructor: Vladik Kreinovich, office CCSB 3.0404, email email@example.com, phone 747-6951
Office hours: MW 1:30-3 pm, M 4:30-5:30 pm, or by appointment
Main objective: to learn theoretical and applied aspects of interval computations.
Course description An overview of interval computations that take into account how input uncertainties influence the computation result. A review of the main ideas behind interval computations, main interval techniques, and applications to practical problems such as robotics, computer graphics, control, and bioinformatics.
What are interval computations?
Need for indirect measurements. In many practical situations, we are interested in the value of the quantity y that is difficult or even impossible to measure directly. To estimate the value of y, we:
Problem: measurements are never 100% exact. The problem is that measurements are never 100% exact. For example, a person is not exactly 5 feet 7 inches or 170 pounds, the actual height or weight are slightly different. because of the difference di = Xi - xi =/= 0 between measured value Xi and the (unknown) actual value xi, the result Y = f(X1,...,Xn) of data processing is somewhat different from the actual value y = f(x1,...,xn) of the quantity of interest.
Traditionally, computers simply return a number Y without specifying how accurate is this number, i.e., how big the inaccuracy d = Y - y can be. From the practical viewpoint, however, it is important to know this accuracy. For example, in geophysical applications, if we estimated the amount of oil in a field as 100 million ton, then if it is 100 +- 10, this is good news, we should start exploiting this area; however, if it is 100 +- 200, then maybe there is no oil at all, so it would be better to perform additional measurements before investing into this area.
Traditional approach assumes that we know probabilities. Traditional engineering approach to this uncertainty (the one that students learn, e.g., in engineering labs) assumes that we know the probabilities of different values of measurement error di. Usually, it is assumed that there errors are independent and normally distributed.
In practice, sometimes, we do not know these probabilities. In many practical situations, we only know the upper bounds Di on the measurement errors: |di| <= Di.
This means that after we measure the value as Xi, the actual value of the measured quantity can be anywhere within the interval [xi] = [Xi - Di, Xi + Di].
For example, if a thermometer shows 86 F, and its accuracy is half a degree, it does not mean that the temperature is exactly 86.000: it could be anywhere between 85.5 and 86.5.
For a single measurement result, this inaccuracy is easy to handle. However, when we process thousands of data points, these inaccuracies add up.
Main problem of interval computations. When the only thing we know about each input xi is the interval [xi] of possible values, then the natural question is: what is the range [y] of possible values of y = f(x1,...,xn)? The problem of computing this range is called the problem of interval computations.
Where are interval computations used? They started with the Department of Defense trying to make sure that the intercontinental missiles fall within the desired range. They continued with NASA designing a trajectory which is guaranteed to hit the Moon.
Nowadays, they are used everywhere: in manufacturing, in robotics, in geoinformatics (processing geophysical data), in bioinformatics (processing bioinformatics data), in economics, in computer graphics, in computer security and privacy (where intervals are introduced on purpose, to avoid disclosing exact values).
Non-CS students. Due to the inter-disciplinary character of potential applications, we welcome not only CS students, but also students from geosciences, environmental sciences, computational sciences, and from other disciplines in which fuzzy techniques can be (and are) useful such as bioinformatics, engineering (especially control), etc. The presence of such students will help application problems.
We realize that some non-CS students may not be as good in programming different fuzzy-related algorithms as our own CS students. With this in mind, we plan to tailor homeworks and other assignments to such students, so that these tailored assignments are more focused on applications and somewhat less on programming.
What will be in the course
Project. After learning the basic interval techniques, students will start working on an (individual or group) project. Ideally, a project should be related to the main topic of student research (we can help with that) and help the student in working on his or her dissertation, thesis, or project.
For those who have not yet selected a topic, or who are interested in making interval computations their research topic, there are many interesting open research problems in which they can help.
1. Knowledge and Comprehension
a. Understand why data processing and imprecise measurements are needed in practice
b. Understand the main practical problem solved by interval computations: estimating uncertainty of the results of data processing and imprecise measurements
c. Understand the main ideas behind the statistical approach to the problem of estimating uncertainty of the results of data processing - the approach which is mainly used in science and engineering
d. Understand why in many practical situations, it is impossible to use the traditional statistical approach
e. Explain why in many practical situations in which traditional statistical methods are not applicable, we need to estimate the range of a function on given intervals
f. Know linearization techniques for range estimation; understand the limitations of such techniques; know practical problems where approximate methods such as linearization are not sufficient
g. Know calculus-based techniques for solving the problem of range estimation; understand why these techniques are not always sufficient
h. Know the formulas for interval arithmetic - estimating ranges for arithmetic operations
i. Understand the main idea behind straightforward interval computations: parsing the function and replacing each elementary operation with the corresponding operation of interval arithmetic
j. Understand how to take round-off errors into account when performing interval computations
k. Understand the drawbacks of straightforward interval computations
l. Understand the main ideas behind improved interval computations: bisection, centered form, constraint propagation techniques, generalized (affine) interval computations; understand the advantages and disadvantages of these ideas
m. Know other problems solved by interval computations techniques, such as solving systems of equations and optimization under uncertainty; understand the practical need for these problems, how they are solved now, and how interval techniques help
n. Understand how interval techniques can be parallelized
o. Understand the computational complexity of the main problem of interval computations (it is NP-hard)
p. Know applications of interval computations to practical problems, e.g., to robotics, computer graphics, control, and bioinformatics
q. Be familiar with the practical need to combine interval uncertainty with probabilistic and expert uncertainty, and have a general understanding of how this combination can be done
2. Application and Analysis
a. Apply calculus-based techniques to estimate ranges of simple functions
b. Parse a given function
c. Apply straightforward interval computations to estimate the range of a given function
d. Apply advanced state-of-the-art interval computation techniques to produce a better estimate for the range of a given function
e. Apply traditional techniques to other practically useful problems such as solving systems of equations and optimization
f. Apply interval techniques to other practically useful problems such as solving systems of equations and optimization
3. Synthesis and Evaluation
a. Derive formulas for interval arithmetic
b. Design programs which use traditional and interval techniques to solve reasonable size problems
c. Apply interval techniques to solve a practice-oriented problem (ideally related to the student's area of research): from extracting an appropriate sub-problem from the general problem to selecting the most appropriate interval techniques to actually using these techniques
Textbook: R. E. Moore, R. B. Kearfott, and M. J. Cloud, Introduction to Interval Analysis, Society for Industrial and Applied Mathematics, Philadelphia, Pennsylvania, 2009.
Additional source of information: Interval computations webpage http://www.cs.utep.edu/interval-comp (by the way, hosted by UTEP).
Tests and grades: There will be two tests and one final exam. Each topic means home assignments (mainly on the sheets of paper, but some on the real computer). Some of them may be graded. Maximum number of points:
A good project can help but it cannot completely cover possible deficiencies of knowledge as shown on the test and on the homeworks. In general, up to 80 points come from tests and home assignments. So:
Standards of conduct: Students are expected to conduct themselves in a professional and courteous manner, as prescribed by the Standards of Conduct. Students may discuss programming exercises in a general way with other students, but the solutions must be done independently. Similarly, groups may discuss project assignments with other groups, but the solutions must be done by the group itself. Graded work should be unmistakably your own. You may not transcribe or copy a solution taken from another person, book, or other source, e.g., a web page). Professors are required to - and will - report academic dishonesty and any other violation of the Standards of Conduct to the Dean of Students.
Disabilities: If you feel you may have a disability that requires accommodation, contact the The Center for Accommodations and Support Services (CASS) at 747-5148, go to Room 106 E. Union, or e-mail to firstname.lastname@example.org.