Academic Integrity: tutoring, explanations, and feedback — we don’t complete graded work or submit on a student’s behalf.

use c++ You are to create a program to help in the analysis of data obtained fro

ID: 3594909 • Letter: U

Question

use c++

You are to create a program to help in the analysis of data obtained from an x-ray powder diffractometer used to characterize materials. In the diffractometer a sample is exposed to x-rays of a specific wavelength and a detector placed on a goniometer is used to measure the angles where constructive interference of the diffracted beam occurs (called peaks) and the intensity of these peaks. The location of these peaks is dependent on the atomic structure of the material being examined. This relationship is given by Bragg’s law which states n = 2dsin() where n is the harmonic of the diffracted beam (n = 1 for these experiments), is the wavelength of the x-ray, d is the interplanar spacing between planes of specific orientation in the material and (theta) is the angle between the x-ray beam and the sample of the material. What is measured the goniometer is actually twice the angle () used Bragg’s law and is referred to as two-theta or 2. You are to create a program that will read the 2-theta values and the intensities from a file and create a table that will contain the 2-theta values, the intensities, the d values and Q values where Q = 1/(sin())2 . The first line of the data file will contain the sample name which should be stored as a string object (note that this name may contain spaces). The second line will contain the anode (the elemental source of the x-ray) as a 2-character symbol which should also be stored as a string object. You will need to use this symbol to determine the wavelength of the x-ray using the table below. You should assume the format of the 2-character symbol will be an upper case letter followed by a lower case letter and the symbol will be one of those listed in the table below.

Anode Wavelength

Cu 1.54059 Cr 2.28973 Fe 1.93604 Co 1.78900 Mo 0.70932 The 2-theta (first column) and intensity values (second column) will start on the third line and continue on subsequent lines. The intensity values are whole numbers. You should design your program so it will continue to read data until the end of file is reached and count the number of peaks observed. Your output should be a file that contains the name of the sample, the wavelength and a table containing the 2-theta and intensity values from the file plus the calculated d and Q values. The Programming Project 2 2 CMPSC 201 – Fall 2017 wavelength should be output with 6 significant digits, the 2-theta values with 5 significant digits, the d values with 6 significant digits and the Q values with 7 significant digits. The table that you output should contain column headings then the values similar to the example given below. Your output file should have the extension “.txt” Your program should allow the user to enter the name of the data file, but you do not need to worry about the folder path (assume the data file is in the same folder as your *.cpp file) and the name of the output file to be generated. A data file called “Project2data.dat” has been placed on CANVAS. This file contains different peaks than what is shown in the table below. This file can be opened with Notepad or Wordpad. Do not change the name of this file. Your program should also allow the user to analyze data from another file without rerunning the program. For sample Project 2 demo with anode of Cu and wavelength of 1.54059 the values are 2-theta Intensity d values Q values 16.375 20 5.40889 49.30620 20.845 55 4.25800 30.55609 26.622 100 3.34567 18.86480 33.097 45 2.70443 12.32647 36.520 5 2.45842 10.18587 39.439 21 2.28293 8.783553 40.263 34 2.23809 8.441890 There were 7 peaks in the file. Would you like to analyze data from another file (y/n

Explanation / Answer

/* Analysis of data obtained from an x-ray powder diffractimeter
n(lambda) = 2dsin(theta), where n=1
So,
d = lambda/2sin(theta)
Q = 1/(sin(theta))^2 */

#include <iostream>
#include <cstdio>
#include <cmath>
#include <iomanip>
#include <cstdlib>
#define PI 3.14159265
using namespace std;

double calcQ(double theta)
{
/* using the equation Q = 1/(sin(theta))^2 */
double val = sin(theta*PI/180);
return 1/pow(val,2);
}

double calcD(double theta, double wl)
{
/* using the equation d = (n*lambda)/(2*sin(theta)), where n=1 */
double val = sin(theta*PI/180);
return wl/(2*val);
}

int main()
{
string sampleName, anode;
double theta, intensity,wl, d, Q;
int in;
const char separator = ' ';
const int nameWidth = 14;
const int numWidth = 14;

FILE *fp1 = freopen("input.txt", "r", stdin);
FILE *fp2 = freopen("output.txt", "w", stdin);

getline(cin, sampleName);
cin >> anode;

string anode_arr[5] = {"Cu", "Cr", "Fe", "Co", "Mo"};
double wl_arr[5] = {1.54059, 2.28973, 1.93604, 1.78900, 0.70932 };

if(anode == "Cu") in=0;
else if(anode == "Cr") in=1;
else if(anode == "Fe") in=2;
else if(anode == "Co") in=3;
else if(anode == "Mo") in=4;

wl = wl_arr[in];

cout << "For sample " << sampleName << " with anode of " << anode << " and wavelength of " << setprecision(5) << fixed << wl << "the values are ";
cout << left << setw(nameWidth) << setfill(separator) << "2-theta";
cout << left << setw(nameWidth) << setfill(separator) << "Intensity";
cout << left << setw(nameWidth) << setfill(separator) << "d values";
cout << left << setw(nameWidth) << setfill(separator) << "Q values";
cout<<" ";

while(fp1 != EOF)
{
cin >> theta >> intensity;
d = calcD(theta, wl);
Q = calcQ(theta);
cout << left << setprecision(4) << fixed << setw(numWidth) << setfill(separator) << theta;
cout << left << setw(numWidth) << setfill(separator) << intensity;
cout << left << setprecision(5) << fixed << setw(numWidth) << setfill(separator) << d;
cout << left << setprecision(6) << fixed << setw(numWidth) << setfill(separator) << Q;
cout<<" ";
}

cout << theta << intensity << d << Q ;

return 0;
}