Computers and Technology

Consider the following C++ program. It prompts the user for a number and calculates and prints the square root of the number using the "sqrt" function and the "pow" function.

#include
#include
using namespace std;

int main()
{
double num, root, error;
cout << "Enter number:\n";
cin >> num;

root = sqrt(num);
cout << "sqrt(" << num << ")= " << root << endl;

root = pow(num, 0.5);
cout << "pow(" << num << ",1/2)= " << root << endl;

return 0;
}
Step 1: Copy this program into your C++ program editor, and compile it. Hopefully you will not get any error messages.

Step 2: Run the program and type in the number "42" to see what it prints. You should see the square root of 42 calculated using the "sqrt" function. The second output line shows 42 raised to the power 1/2 which is another way to calculate the square root. Try several other input values. Do the two square root calculations always match each other?

Step 3: Type in "man sqrt" in your Linux window to see the manual page for this function. Near the top of the manual page you will see the function prototype "double sqrt(double x);". If you read the description you will see that the sqrt function expects one double parameter and returns a double value that is the "nonnegative square root of x".

Step 4: Type in "man pow" in your Linux window to see the manual page for this function. Near the top of the manual page you will see the function prototype "double pow(double x, double y);". If you read the description you will see that the pow function expects two double parameters and returns a double value that is equal to "x raised to the power of y".

Step 5: If you entered the number "4" above you saw that the square root was equal to 2, which is exactly correct. On the other hand, we can only approximate the square root of "3" using a double in C++ because the true answer has infinite length. To see what the error in this square root calculation is, copy/paste the following two lines after the "cout << sqrt" and "cout << pow" lines above.

error = num - root * root;
cout << "error= " << error << endl << endl;
Step 6: Compile and run your program and try a few different input values. What is your error when you input a perfect square like "49" as input? What is the error when you input a prime number like "3"? Is there any difference in error between "sqrt" and "pow"?

Step 7: Type in "man cbrt" in your Linux window to see the manual page for this function. Near the top of the manual page you will see the function prototype "double cbrt(double x);". If you read the description you will see that the cbrt function expects one double parameter and returns a double value that is the "real cube root of x".

Step 8: Your next task is to extend your program to calculate cube roots two ways and compare their errors. Edit your program and use copy/paste to duplicate your sqrt, pow and error calculations. Next, change sqrt to cbrt, and change the pow exponent to 1.0/3.0. Finally, modify the error calculations accordingly. When you compile and run your program with an input of "42", it should output the following:

sqrt(42)= 6.48074
error= 0

pow(42,1/2)= 6.48074
error= 0

cbrt(42)= 3.47603
error= 0

pow(42,1/3)= 3.47603
error= 0
Step 9: Run your new program several times with different input values. What happens if you input a negative value? What happens if you enter a 5 digit input value? Is sqrt(x) as accurate as pow(x,1/2)? Is cbrt(x) as accurate as pow(x,1/3)? For most applications these small errors are not an issue. On the other hand, if you are calculating the gross domestic product of the country or the trajectory of a rocket to mars, these differences DO matter.

answer
Answers: 3

Other questions on the subject: Computers and Technology

image
Computers and Technology, 22.06.2019 20:00, Jana1517
What is the worst-case complexity of the maxrepeats function? assume that the longest string in the names array is at most 25 characters wide (i. e., string comparison can be treated as o( class namecounter { private: int* counts; int nc; string* names; int nn; public: namecounter (int ncounts, int nnames); int maxrepeats() const; }; int namecounter: : maxrepeats () { int maxcount = 0; for (int i = 0; i < nc; ++i) { int count = 1; for (int j = i+1; j < nc; ++j) { if (names[i] == names[j]) ++count; } maxcount = max(count, maxcount); } return maxcount; }
Answers: 3
image
Computers and Technology, 23.06.2019 09:00, paulusl19
The first screen you see when you open word2016 what is called?
Answers: 1
image
Computers and Technology, 23.06.2019 16:50, lukeakalucas
15: 28read the summary of "an indian's view of indian affairs."15 betterin "an indian's view of indian affairs," it is asserted that conflicts could be reduced if white americansunderstood native americans..pswhich of the following would make this summary more complete? eleo the fact that chief joseph believes the great spirit sees everythinthe fact that chief joseph was born in oregon and is thirty-eight years oldo the fact that chief joseph states that he speaks from the hearthehehethe fact that chief joseph of the nez percé tribe made this claimebell- ==feetle===-felsefe ==submitmark this and retum.=
Answers: 3
image
Computers and Technology, 24.06.2019 04:10, kris1920
Write a program that reads a set of floating-point values. ask the user to enter the values, then print • the average of the values. • the smallest of the values. • the largest of the values. • the range, that is the difference between the smallest and largest. of course, you may only prompt for the values once.
Answers: 3
Do you know the correct answer?
Consider the following C++ program. It prompts the user for a number and calculates and prints the s...

Questions in other subjects:

Konu
Social Studies, 29.12.2021 19:00