subject

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.

ansver
Answers: 3

Another question on Computers and Technology

question
Computers and Technology, 22.06.2019 22:00
Consider the following declarations (1, 2, 3, 5, 7)class bagtype{public: void set(string, double, double, double, double); void print() const; string getstyle() const; double getprice() const; void get(double, double, double, double); bagtype(); bagtype(string, double, double, double, double); private: string style: double l; double w; double h; double price; }; a.) write the definition of the number function set so that private members are set according to the parametersb.) write the definition of the member function print that prints the values of the data membersc.) write the definition of the default constructor of the class bagtype so that the private member variables are initialized to "", 0.0, 0.0, 0.0, 0.0, respectively d.) write a c++ statement that prints the value of the object newbag.e.) write a c++ statement that declares the object tempbag of type bagtype, and initialize the member variables of tempbag to "backpack", 15, 8, 20 and 49.99, respectively
Answers: 3
question
Computers and Technology, 22.06.2019 22:20
Pp 4.1 design and implement a class called sphere that contains instance data that represents the sphere’s diameter. define the sphere constructor to accept and initialize the diameter and include getter and setter methods for the diameter. include methods that calculate and return the volume and surface area of the sphere (see pp 3.5 for the formulas). include a tostring method that returns a one-line description of the sphere. create a driver class called multisphere, whose main method instantiates and updates several sphere objects.
Answers: 1
question
Computers and Technology, 23.06.2019 02:30
People with high self-esteem: accept their strengths and weaknesses. believe that failed experiences are failures of their whole self. feel good about who they are only when they reach total success. need positive external experiences to counteract negative feelings that constantly plague them.
Answers: 1
question
Computers and Technology, 23.06.2019 04:40
The narrative structure of the popular movies can be broken down into
Answers: 3
You know the right answer?
Consider the following C++ program. It prompts the user for a number and calculates and prints the s...
Questions
Questions on the website: 13722367