For Coursera Getting and Cleaning Data class assignment.
The project involves combining multiple text files into one dataset, arranging the table, and then creating a new table that summarizes the data as the final output. (tidydata.txt)
The data in this assignment is motion sensor readings from a smartphone. You can read about the data here http://archive.ics.uci.edu/ml/datasets/Human+Activity+Recognition+Using+Smartphones and you can download the data here https://d396qusza40orc.cloudfront.net/getdata%2Fprojectfiles%2FUCI%20HAR%20Dataset.zip
It is not necessary to understand the data to complete the assignment, though I briefly explain it in the Code Book section below.
In Dataset.zip there are 8 files that you need to use. The data is broken into training and test datasets and you need to combine all of the files below into one dataset.
- features.txt (Stores the collum names for the X_ files)
- activity_labels.txt (List of friendly activity names,such as "Walking")
- train/X_train.txt (This is the main data files)
- train/y_train.txt (Index of activity names from 1-6 that correspond to the activities in activity_labels.txt. These needs to be added as a column to the X_train.txt)
- train/subject_train.txt (Numeric index that corresponds to the study participants. These needs to be added as a column to the X_train.txt)
- test/X_test.txt (This is the main data files)
- test/y_test.txt (Index of activity names from 1-6 that correspond to the activities in activity_labels.txt. These needs to be added as a column to the X_test.txt)
- test/subject_test.txt (Numeric index that corresponds to the study participants. X_test.txt. These needs to be added as a column to the X_test.txt)
run_analysis.R performs the following actions on the data in the above files. I used dplyr functions as much as I could.
- Reads X_train.txt & X_test.txt and combines into a single data.table called alldata
- Reads features.txt and saves as vector colheaders
- Search for columns with search that have "mean" or "std" in the name and use those as names for the columns in all data
- select the columns that we have named and assign them back to alldata. Now alldata will only have 79 columns
- Then read the files that have the subject and activity collums and add them to alldata as new columns on the left side of the table.
Now you should have an alldata table with 10,299 rows and 81 columns.
Next we want to calculate the average of each variable, for each subject, and each activity--and save in a new tidydata table.
You can this very simply with one line of code using dpylr funtions
alldata %>% group_by(Activity, Subject) %>% summarise_each(funs(mean))
This is the basic format of the table, though there are 81 columns
Activity | Subject | tBodyAcc-mean()-X | tBodyAcc-mean()-Y |
---|---|---|---|
1 | LAYING | 0.2215982 | -0.040513953 |
2 | LAYING | 0.2813734 | -0.01815874 |
3 | LAYING | 0.2755169 | -0.018955679 |
Then I saved the output to tidydata.txt
The data in tidydata.txt is a summary of the data in the original set. It has 91 columns, though the original had more than 500. The tidydata dataset only has the collumns that show the mean and the standard deviations of the data sets. The tidydata is grouped to show the mean for each combination of activity, subject, and variable.
The actual data collected in data is quite technical and complicated. I took below description from the the features_info.txt file in the zip file that contains the full data set.
The features selected for this database come from the accelerometer and gyroscope 3-axial raw signals tAcc-XYZ and tGyro-XYZ. These time domain signals (prefix 't' to denote time) were captured at a constant rate of 50 Hz. Then they were filtered using a median filter and a 3rd order low pass Butterworth filter with a corner frequency of 20 Hz to remove noise. Similarly, the acceleration signal was then separated into body and gravity acceleration signals (tBodyAcc-XYZ and tGravityAcc-XYZ) using another low pass Butterworth filter with a corner frequency of 0.3 Hz.
Subsequently, the body linear acceleration and angular velocity were derived in time to obtain Jerk signals (tBodyAccJerk-XYZ and tBodyGyroJerk-XYZ). Also the magnitude of these three-dimensional signals were calculated using the Euclidean norm (tBodyAccMag, tGravityAccMag, tBodyAccJerkMag, tBodyGyroMag, tBodyGyroJerkMag).
Finally a Fast Fourier Transform (FFT) was applied to some of these signals producing fBodyAcc-XYZ, fBodyAccJerk-XYZ, fBodyGyro-XYZ, fBodyAccJerkMag, fBodyGyroMag, fBodyGyroJerkMag. (Note the 'f' to indicate frequency domain signals).
These signals were used to estimate variables of the feature vector for each pattern:
'-XYZ' is used to denote 3-axial signals in the X, Y and Z directions.
Full list of columns in tidydata.txt (Unless otherwise stated, the values of the table are numeric readings with formats such as "0.2215982" or "-0.018955679")
- Activity >> Notes: 6 Values "WALKING", "WALKING_UPSTAIRS", "WALKING_DOWNSTAIRS", "SITTING", "STANDING", "LAYING"
- Subject >> Note: This is a number between 1:30, corresponding to the 30 subjects
- tBodyAcc-mean()-X
- tBodyAcc-mean()-Y
- tBodyAcc-mean()-Z
- tBodyAcc-std()-X
- tBodyAcc-std()-Y
- tBodyAcc-std()-Z
- tGravityAcc-mean()-X
- tGravityAcc-mean()-Y
- tGravityAcc-mean()-Z
- tGravityAcc-std()-X
- tGravityAcc-std()-Y
- tGravityAcc-std()-Z
- tBodyAccJerk-mean()-X
- tBodyAccJerk-mean()-Y
- tBodyAccJerk-mean()-Z
- tBodyAccJerk-std()-X
- tBodyAccJerk-std()-Y
- tBodyAccJerk-std()-Z
- tBodyGyro-mean()-X
- tBodyGyro-mean()-Y
- tBodyGyro-mean()-Z
- tBodyGyro-std()-X
- tBodyGyro-std()-Y
- tBodyGyro-std()-Z
- tBodyGyroJerk-mean()-X
- tBodyGyroJerk-mean()-Y
- tBodyGyroJerk-mean()-Z
- tBodyGyroJerk-std()-X
- tBodyGyroJerk-std()-Y
- tBodyGyroJerk-std()-Z
- tBodyAccMag-mean()
- tBodyAccMag-std()
- tGravityAccMag-mean()
- tGravityAccMag-std()
- tBodyAccJerkMag-mean()
- tBodyAccJerkMag-std()
- tBodyGyroMag-mean()
- tBodyGyroMag-std()
- tBodyGyroJerkMag-mean()
- tBodyGyroJerkMag-std()
- fBodyAcc-mean()-X
- fBodyAcc-mean()-Y
- fBodyAcc-mean()-Z
- fBodyAcc-std()-X
- fBodyAcc-std()-Y
- fBodyAcc-std()-Z
- fBodyAcc-meanFreq()-X
- fBodyAcc-meanFreq()-Y
- fBodyAcc-meanFreq()-Z
- fBodyAccJerk-mean()-X
- fBodyAccJerk-mean()-Y
- fBodyAccJerk-mean()-Z
- fBodyAccJerk-std()-X
- fBodyAccJerk-std()-Y
- fBodyAccJerk-std()-Z
- fBodyAccJerk-meanFreq()-X
- fBodyAccJerk-meanFreq()-Y
- fBodyAccJerk-meanFreq()-Z
- fBodyGyro-mean()-X
- fBodyGyro-mean()-Y
- fBodyGyro-mean()-Z
- fBodyGyro-std()-X
- fBodyGyro-std()-Y
- fBodyGyro-std()-Z
- fBodyGyro-meanFreq()-X
- fBodyGyro-meanFreq()-Y
- fBodyGyro-meanFreq()-Z
- fBodyAccMag-mean()
- fBodyAccMag-std()
- fBodyAccMag-meanFreq()
- fBodyBodyAccJerkMag-mean()
- fBodyBodyAccJerkMag-std()
- fBodyBodyAccJerkMag-meanFreq()
- fBodyBodyGyroMag-mean()
- fBodyBodyGyroMag-std()
- fBodyBodyGyroMag-meanFreq()
- fBodyBodyGyroJerkMag-mean()
- fBodyBodyGyroJerkMag-std()
- fBodyBodyGyroJerkMag-meanFreq()