C++: Calculate the Velocity of Star/Galaxy/Quasar Using Relativistic Redshift
by matt392 in Circuits > Software
7 Views, 0 Favorites, 0 Comments
C++: Calculate the Velocity of Star/Galaxy/Quasar Using Relativistic Redshift
data:image/s3,"s3://crabby-images/a99db/a99dbbef137bc7e195ff3e171639daf981e368f1" alt="c++image.jpg"
data:image/s3,"s3://crabby-images/b0930/b093075d274312e54da78b95873527339bf6eb6e" alt="CalculatingVelocityRedshift.png"
C++ Program that calculates the velocity of a star/galaxy/quasar using relativistic redshift. Below and attached. PDF flowchart also attached.
#include
#include
using namespace std;
int main()
{ // start main function
double observedWavelength;
double elementWavelength;
double changeWavelength;
double redshift;
double velocity;
double topOfFraction;
double bottomOfFraction;
cout << "Program to calculate the velocity of a star, galaxy or quasar using relativistic redshift.\n";
cout << "Enter the observed wavelength in Angstroms: ";
cin >> observedWavelength;
cout << "Enter the element's wavelength in Angstroms: ";
cin >> elementWavelength;
// Calculate the change in the wavelength
changeWavelength = observedWavelength - elementWavelength;
cout << "The change in wavelength is: " << changeWavelength << endl;
// Calculate the redshift value
cout << "The redshift formula is: redshift = (change in wavelength/wavelength of the element.)\n";
redshift = (changeWavelength/elementWavelength);
cout << "The redshift of the star or galaxy is: " << redshift << endl;
cout << "=============\n";
// Calculate the velocity of the star, galaxy or quasar
cout << "The relativistic redshift formula is: ( (((redshift+1)^2) - 1)/(((redshift+1)^2) + 1) ) * 300000)\n";
// Raising a number to a power function: pow(a, b) = a to the b power
// Calculating the fraction
topOfFraction = ((pow((redshift+1),2))-1);
cout << "The top of the fraction is: " << topOfFraction << endl;
bottomOfFraction = ((pow((redshift+1),2))+1);
cout << "The bottom of the fraction is: " << bottomOfFraction << endl;
// Calculate velocity using top and bottom of fraction
velocity = ((topOfFraction)/(bottomOfFraction)) * 300000;
cout << "The velocity of the star, galaxy or quasar is: " << velocity << " km/s.\n";
cout << "Note that a positive value means the object is moving away from Earth.\n";
cout << "A negative value means that the object is moving towards Earth.\n";
cout << "Thank you to Professor Morgan at the University of Northern Iowa for the formula and explanation.\n";
return 0;
} // end main function
Supplies
data:image/s3,"s3://crabby-images/35d95/35d951cb1ea800e592cc63fcf8ab7b2e79fab2a8" alt="codeblocks.jpg"
data:image/s3,"s3://crabby-images/77887/778870047ade476bed5bda087ca3084953527fae" alt="GNU_Compiler_Collection_logo.svg.png"
- Code::Blocks Integrated Development Environment (or any other C++ IDE)
- C++ compiler (Code::Blocks includes the GCC)
C++ Code
data:image/s3,"s3://crabby-images/cfb5c/cfb5c3674428aa5ad577359c32b52676251881fe" alt="CalculatingVelocityRedshift.png"
data:image/s3,"s3://crabby-images/8af2d/8af2dfb99531439de94710c3b3c4ac14e4b35fd8" alt="c++image.jpg"
C++ Program that calculates the velocity of a star/galaxy/quasar using relativistic redshift. Below and attached. Flowchart is also attached.
#include
#include
using namespace std;
int main()
{ // start main function
double observedWavelength;
double elementWavelength;
double changeWavelength;
double redshift;
double velocity;
double topOfFraction;
double bottomOfFraction;
cout << "Program to calculate the velocity of a star, galaxy or quasar using relativistic redshift.\n";
cout << "Enter the observed wavelength in Angstroms: ";
cin >> observedWavelength;
cout << "Enter the element's wavelength in Angstroms: ";
cin >> elementWavelength;
// Calculate the change in the wavelength
changeWavelength = observedWavelength - elementWavelength;
cout << "The change in wavelength is: " << changeWavelength << endl;
// Calculate the redshift value
cout << "The redshift formula is: redshift = (change in wavelength/wavelength of the element.)\n";
redshift = (changeWavelength/elementWavelength);
cout << "The redshift of the star or galaxy is: " << redshift << endl;
cout << "=============\n";
// Calculate the velocity of the star, galaxy or quasar
cout << "The relativistic redshift formula is: ( (((redshift+1)^2) - 1)/(((redshift+1)^2) + 1) ) * 300000)\n";
// Raising a number to a power function: pow(a, b) = a to the b power
// Calculating the fraction
topOfFraction = ((pow((redshift+1),2))-1);
cout << "The top of the fraction is: " << topOfFraction << endl;
bottomOfFraction = ((pow((redshift+1),2))+1);
cout << "The bottom of the fraction is: " << bottomOfFraction << endl;
// Calculate velocity using top and bottom of fraction
velocity = ((topOfFraction)/(bottomOfFraction)) * 300000;
cout << "The velocity of the star, galaxy or quasar is: " << velocity << " km/s.\n";
cout << "Note that a positive value means the object is moving away from Earth.\n";
cout << "A negative value means that the object is moving towards Earth.\n";
cout << "Thank you to Professor Morgan at the University of Northern Iowa for the formula and explanation.\n";
return 0;
} // end main function