Day1
Individual activity: Tropical plan traits data
The goals of this activity are:
- To practice usage of main R functions to process data tables (read, summarize and write as CSV files) using RStudio.
- To apply a good workflow of version control with git on a local repository using RStudio.
- For this assignment, we are going to use the plant trait data from:
    - Razafindratsima OH, Brown KA, Carvalho F, Johnson SE, Wright PC, Dunham AE (2017) Data from: Edge effects on components of diversity and above-ground biomass in a tropical rainforest. Dryad Digital Repository. https://doi.org/10.5061/dryad.jn743
 
- Follow the link to the dataset and download the .xlsx file.
- Open the file in a spreadsheet program (like excel) and save the trait tab as a CSV (comma delimited) file. Make sure you saved the CSV file in the data-rawfolder of your project.
- Create a new file called “tropical-plant-trait.R” file.
- In this file, write the necessary R code to perform the following challenges. After each challenge, add and commit the R script file, using an informative commit message for each commit:
    - Read the CSV file using the function read.csvand assign it to an object calleddata_table.
- Use the functions uniqueandlengthto show the number of unique families found in the data frame. First, you will need to subset accordingly yourdata_tableobject using square brackets[ ].
- Do the same to find the number of unique “dispersal modes” and “fruit colors”.
- Use the meanfunction to calculate the average fruit width in cm.
- Use the function summaryon yourdata_tableobject. Can you find the average fruit width in the output of the function? Is it the same as the one you obtained using the functionmean?
- Look at the output of the function  summary. What is the average fruit length in cm?
- Create the following subset tables from your original data_tableobject. Use square brackets to create:- A subset of data_tablethat contains the first 10 rows.
- A subset of data_tablethat contains the last 20 rows.
- A subset of data_tablethat contains rows 12, 17, 23 and 145.
- A subset of data_tablethat contains the first 10 rows and rows 12, 17, 23 and 145.
- A subset of data_tablethat contains the first 5 columns and all rows.
- A subset of data_tablethat contains the last 2 columns and all rows.
- A subset of data_tablethat contains columns with “family”, “fruit_color” and “growth_rate”, and all rows.
- A subset of data_tablethat contains the first 5 columns and rows 12, 17, 23 and 145.
 
- A subset of 
- Remember to comment your code.
- Use the function write.csvto write CSV files for each subset into thedatafolder. Note: you have to use the argumentfileto provide the path and name for the subset CSV files, otherwise they will not be written to the correct folder or at all. If you do not know how to use thefileargument, runhelp(write,csv)or?write.csv.
 
- Read the CSV file using the function 
- Add and commit all CSV files that you generated. Use an informative commit message.
- Display your git history and take a snapshot. Send the snapshot to your instructor.
Day2
Group activity: absolute and relative paths
The goals of this activity are:
- To practice usage of absolute and relative paths.
- For this activity we will use a section of the code from the previous activity.
- Go into groups and compare the file paths you used to save the CSV files in the datafolder, and answer:- Did you use relative or absolute paths?
- If you all used the absolute path to save any CSV file, what does the path look like? Do you all have the same path? What are the differences?
- If you all used relative paths to save any of your CSV files, what does the path look like? Do you all have the same path? What are the differences?
 
- Create a script called paths.R, save it to yourscriptsfolder, and write the code to:- Write the data_tableobject as a CSV file in your computer’s home directory using an absolute path and a relative path.
- Write the data_tableobject as a CSV file in your project’s home directory using an absolute path and a relative path.
 
- Write the 
- Add and commit all the files that you generated. Use an informative commit message.
- Display your git history and take a snapshot. Send the snapshot to your instructor.
Individual activity: logical comparisons
- For this assignment, we are going to keep on working with the plant trait data from:
    - Razafindratsima OH, Brown KA, Carvalho F, Johnson SE, Wright PC, Dunham AE (2017) Data from: Edge effects on components of diversity and above-ground biomass in a tropical rainforest. Dryad Digital Repository. https://doi.org/10.5061/dryad.jn743
 
- Create a new file called logical-comparisons.Rand save it in yourscriptsfolder.
- Write the necessary code to:
    - Read the CSV file with trait plant data using the function read.csvand assign it to an object calleddata_table.
- Subset your data table and create an object called all_dispersal_modesthat contains all rows from column “dispersal mode”.
- Run the following code all_dispersal_modes == "lemur". What is the class of this output? What is it telling you about dispersal mode?
- Besides the indices of rows and columns, we can use logical operators to subset a data frame. Use the code from the previous line to subset your data_tableobject to keep only those rows that have a dispersal_mode equal to “lemur”. Create an object calleddata_table_lemur.
- Apply the function nrowto your newly created object. How many plant species are dispersed by lemurs?
- Use the same logic and procedure to find out the follwing:
        - how many plant species in data_tableare dispersed by birds?
- how many plant species have an average height above 10?
- how many plant species have an average height exactly equal to 10?
- how many plant species have an average height below 10?
- how many plant species belong to the family Lauraceae?
 
- how many plant species in 
 
- Read the CSV file with trait plant data using the function 
- Add and commit all the files that you generated. Use an informative commit message.
- Display your git history and take a snapshot. Send the snapshot to your instructor.
