Started a cmake tutorial
This commit is contained in:
15
Step2/MathFunctions/CMakeLists.txt
Normal file
15
Step2/MathFunctions/CMakeLists.txt
Normal file
@ -0,0 +1,15 @@
|
||||
# TODO 14: Remove mysqrt.cxx from the list of sources
|
||||
|
||||
# TODO 1: Add a library called MathFunctions with sources MathFunctions.cxx
|
||||
# and mysqrt.cxx
|
||||
# Hint: You will need the add_library command
|
||||
|
||||
# TODO 7: Create a variable USE_MYMATH using option and set default to ON
|
||||
|
||||
# TODO 8: If USE_MYMATH is ON, use target_compile_definitions to pass
|
||||
# USE_MYMATH as a precompiled definition to our source files
|
||||
|
||||
# TODO 12: When USE_MYMATH is ON, add a library for SqrtLibrary with
|
||||
# source mysqrt.cxx
|
||||
|
||||
# TODO 13: When USE_MYMATH is ON, link SqrtLibrary to the MathFunctions Library
|
15
Step2/MathFunctions/MathFunctions.cxx
Normal file
15
Step2/MathFunctions/MathFunctions.cxx
Normal file
@ -0,0 +1,15 @@
|
||||
#include "MathFunctions.h"
|
||||
|
||||
// TODO 11: include cmath
|
||||
|
||||
// TODO 10: Wrap the mysqrt include in a precompiled ifdef based on USE_MYMATH
|
||||
#include "mysqrt.h"
|
||||
|
||||
namespace mathfunctions {
|
||||
double sqrt(double x)
|
||||
{
|
||||
// TODO 9: If USE_MYMATH is defined, use detail::mysqrt.
|
||||
// Otherwise, use std::sqrt.
|
||||
return detail::mysqrt(x);
|
||||
}
|
||||
}
|
5
Step2/MathFunctions/MathFunctions.h
Normal file
5
Step2/MathFunctions/MathFunctions.h
Normal file
@ -0,0 +1,5 @@
|
||||
#pragma once
|
||||
|
||||
namespace mathfunctions {
|
||||
double sqrt(double x);
|
||||
}
|
28
Step2/MathFunctions/mysqrt.cxx
Normal file
28
Step2/MathFunctions/mysqrt.cxx
Normal file
@ -0,0 +1,28 @@
|
||||
#include "mysqrt.h"
|
||||
|
||||
#include <iostream>
|
||||
|
||||
namespace mathfunctions {
|
||||
namespace detail {
|
||||
// a hack square root calculation using simple operations
|
||||
double mysqrt(double x)
|
||||
{
|
||||
if (x <= 0) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
double result = x;
|
||||
|
||||
// do ten iterations
|
||||
for (int i = 0; i < 10; ++i) {
|
||||
if (result <= 0) {
|
||||
result = 0.1;
|
||||
}
|
||||
double delta = x - (result * result);
|
||||
result = result + 0.5 * delta / result;
|
||||
std::cout << "Computing sqrt of " << x << " to be " << result << std::endl;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
}
|
||||
}
|
7
Step2/MathFunctions/mysqrt.h
Normal file
7
Step2/MathFunctions/mysqrt.h
Normal file
@ -0,0 +1,7 @@
|
||||
#pragma once
|
||||
|
||||
namespace mathfunctions {
|
||||
namespace detail {
|
||||
double mysqrt(double x);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user