Ask Computer Engineering Expert

Question :

Suppose you have a ray of light that hits a flat surface such as a mirror and is reflected. What is the direction of reflection? This is a problem that arises in areas such as optics and computer graphics. To solve it, we need to know the original direction of the light ray, and the orientation of the surface. Let the direction be given by a vector v = (vx , vy, vz), and let the surface orientation be specified by an outward normal vector n = (nx , ny , nz) of the surface1.

To compute the reflection vector we first check if v is heading towards the surface. If it is not, then it will not reflect off the surface. This check is done by using the dot product v · n = vxnx + vyny + vznz .

Your first task in this part is to write a function: double dotProduct(double vx, double vy, double vz, double nx, double ny, double nz) that computes the dot product. If the dot product is greater than or equal to zero, the ray of light is headed away from (or parallel to) the surface, and so no reflection occurs. So we only compute the reflection vector if the dot product is less than zero. In this case, the next step is to normalize the surface normal vector by dividing each component by the vector's length2; this ensures the resulting vector has unit length. Write a function:

void normalize(double& wx, double& wy, double& wz) that, given any vector (w x , w y , w z ), computes its length, divides each component by that length, and then uses call by reference to return those components. The final step is to use the formula r = v - 2(v . n)n to compute the reflection vector. Here n is the normalized vector from the last step. Write a function:

1 A normal of a flat surface is a vector perpendicular to the surface. An outward normal is any such vector pointing outward from the surface object rather than inward.

2 Recall the length of a 3D vector w is given by void reflectionVector(double vx, double vy, double vz, double nx, double ny, double nz, double& rx, double& ry, double& rz) that does the following:

(i) takes the original surface normal vector n and normalizes it using the  normalize function,

(ii) computes the reflection vector r = (rx, ry, rz ) (note to do this the formula above needs to be applied three times: once for each of the x, y, and z components; also note that computing the reflection vector requires use of the dotProduct function), and

(iii) uses call by reference to return the reflection vector components. Finally, write a main driver program that does the following:

1. Asks the user to input the original direction, and then input the surface outward normal.

2. Checks if reflection occurs. To do this it should use the dotProduct function.

3. If reflection does not occur, your main program should print out an appropriate message. If reflection does occur, your main program should call the reflectionVector function to compute the reflection vector, and should print out that vector.

4. In either case, your main program should then ask the user if they wish to continue. If they do, the program should allow the user to continue this process as many times as they wish.

Here is some example input and output.

Input the original direction vx vy vz: 0 -1 0

Input the surface outward normal nx ny nz: 1 1 0

Reflection vector: 1 -2.22045e-16 0

Continue (y/n)? y

Input the original direction vx vy vz: 1.5 2.5 3.5

Input the surface outward normal nx ny nz: 1 1 1

No reflection

Continue (y/n)? y

Input the original direction vx vy vz: 1.5 2.5 3.5

Input the surface outward normal nx ny nz: -1 -1 1

Reflection vector: 1.16667 2.16667 3.83333

Computer Engineering, Engineering

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

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