Terminal And Bash

## Week 3 Homework: A High Stakes Investigation ### Scenario You have just been hired by Lucky Duck Casino as a security analyst. – Lucky Duck has lost a significant amount of money on the roulette tables over the last month. – The largest losses occurred on March 10, 12, and 15. – Your manager believes there is a player working with a Lucky Duck dealer to steal money at the roulette tables. – The casino has a large database with data on wins and losses, player analysis, and dealer schedules. – You are tasked with navigating, modifying, and analyzing these data files to gather evidence on the rogue player and dealer. – You will prepare several evidence files to assist the prosecution. – You must work quickly as Lucky Duck can’t afford any more losses. Lucky Duck Casino has provided you with the following files if required: – [Roulette Player Data: Week of March 10](Resources/Roulette_Player_WinLoss_0310.zip) – [Employee Dealer Schedule: Week of March 10](Resources/Dealer_Schedules_0310.zip) **Note**: The instructions ask you to set up the files using a `wget` command, but the files are also provided in compressed zip format if the command does not work. ### Lab Environment – You will use your local Vagrant virtual machine for today’s activities. Please note that instructors and students have different access credentials. – Username: `sysadmin` – Password: `cybersecurity` ### Instructions Use your command-line skills to uncover the identities of the rogue casino player and dealer colluding to scam Lucky Duck out of thousands of dollars. After your investigation, you will provide a summary of your findings to the casino. #### Step 1: Investigation Preparation Your first task is to set up directories to prepare for your investigation. 1. Begin by making a single directory titled `Lucky_Duck_Investigations`. 2. In this directory, create a directory for this specific investigation titled `Roulette_Loss_Investigation`. 3. In `Roulette_Loss_Investigation`, create the following directories: – `Player_Analysis` to investigate the casino player. – `Dealer_Analysis` to investigate the dealers. – `Player_Dealer_Correlation` to summarize your findings of the collusion. 4. Create empty files called `Notes_<Directory Name>` under each subdirectory to store investigation notes. – For example: `Notes_Player_Analysis` #### Step 2: Gathering Evidence Your next task is to move evidence from the specific days that Lucky Duck experienced heavy losses at the roulette tables. 1. Navigate to the directory where you created the `Lucky_Duck_Investigations` directory and run the following command to set up the evidence files: – `wget “https://tinyurl.com/3-HW-setup-evidence” && chmod +x ./3-HW-setup-evidence && ./3-HW-setup-evidence` After running this command your current directory should have the following subdirectories: – `Dealer_Schedules_0310`: Contains the dealer schedules. – `Lucky_Duck_Investigations`: Contains the investigation directories and notes files you created. – `Roulette_Player_WinLoss_0310`: Contains the data for player wins and losses. 2. The `Dealer_Schedules_0310` and `Roulette_Player_WinLoss_0310` directories contain the dealer schedules and win/loss player data from the roulette tables during the week of March 10. – Since the losses occurred on March 10, 12, and 15, move the schedules for those days into the directory `Dealer_Analysis`. – Move the files for those days into the directory `Player_Analysis`. #### Step 3: Correlating the Evidence Your next task is to correlate the large losses from the roulette tables with the dealer schedule. This will help you determine which dealer and player are colluding to steal money from Lucky Duck. **Note:** Winnings for Lucky Duck Casino are indicated with a positive number and losses are indicated with a negative number. Complete the player analysis. 1. Navigate to the `Player_Analysis` directory. 2. Use `grep` to isolate all of the losses that occurred on March 10, 12, and 15. 3. Place those results in a file called `Roulette_Losses`. 4. Preview the file `Roulette_Losses` and analyze the data. – Record in the `Notes_Player_Analysis` file: – The times the losses occurred on each day. – If there is a certain player that was playing during each of those times. – The total count of times this player was playing. – **Hint:** Use the `wc` command to find this value. Complete the dealer analysis. 1. Navigate to the `Dealer_Analysis` directory. 2. This file contains the dealer schedules for the various Lucky Duck casino games: Blackjack, Roulette, and Texas Hold ‘Em. – Preview the schedule to view the format and to understand how the data is separated. 3. Using your findings from the player analysis, create a separate script to look at each day and time that you determined losses occurred. Use `awk`, `pipes`, and `grep` to isolate out the following four fields: – Time – a.m./p.m. – First name of roulette dealer – Last name of roulette dealer For example, if a loss occurred on March 10 at 2 p.m., you would write one script to find the roulette dealer who was working at that specific day and time. – **Hint:** You will have many scripts, but only a small change is required for each script. 5. Run all of the scripts and append those results to a file called `Dealers_working_during_losses`. 6. Preview your file `Dealers_working_during_losses` and analyze the data. – Record in the `Notes_Dealer_Analysis` file: – The primary dealer working at the times where losses occurred. – How many times the dealer worked when major losses occurred. 3. Complete the player/employee correlation. – In the notes file of the `Player_Dealer_Correlation` directory, add a summary of your findings noting the player and dealer you believe are colluding to scam Lucky Duck. – Make sure to document your specific reasons for this finding. #### Step 4: Scripting Your Tasks You manager is impressed with the work you have done so far on the investigation. They tasked you with building a shell script that can easily analyze future employee schedules. They will use this to determine which employee was working at a specific time in the case of future losses. Complete the following tasks: 1. Remain in the `Dealer_Analysis` directory. Develop a shell script called `roulette_dealer_finder_by_time.sh` that can analyze the employee schedule to easily find the roulette dealer at a specific time. **Hint:** You will be using a script similar to the one you created for the dealer analysis step, but you will not output the results into a file. – Design the shell script to accept the following two arguments: – One for the date (four digits) – One for the time **Note:** The argument should be able to accept a.m. or p.m. 3. Test your script on the schedules to confirm it outputs the correct dealer at the time specified. #### Bonus – In case there is future fraud on the other Lucky Duck games, create a shell script called `roulette_dealer_finder_by_time_and_game.sh` that has the three following arguments: – Specific time – Specific date – Casino game being played **Hint:** The argument does not need to name the specific casino game. ### Submission Guidelines – Move the following to the `Player_Dealer_Correlation` directory: – All note files – Evidence files: – `Roulette_Losses` – `Dealers_working_during_losses` – Shell script(s) – Compress the `Player_Dealer_Correlation` folder to a zip file and submit it. — © 2020 Trilogy Education Services, a 2U, Inc. brand. All Rights Reserved.

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

Encryption And Decryption Using Vigenere With Cipher Block Chaining: Up To 50 Dollars Will Be Given

Modular Arithmetic Dr. Y. Chu CIS3360: Security in Computing 0R02 Spring 2018

1

Information

Reading: Appendix B.2 in textbook (will be posted in Webcourses)

Reference: online tutorials

2

Modulo Operation

Given any positive integer n and any integer a, when a is divided by n, we get an integer quotient, q, and integer remainder, b, that obey the following relationship:

a = q · n + b, where 0 <= b <= n-1

Then we define b= a modulo n or b= a mod n.

Note: b (modular value) is always non-negative

Examples:

5 mod 11 = 5, 5=0x11+5, so q=0 and b=5

17 mod 11 = 6, 17=1×11+6, so q=1 and b=6

-11 mod 7 = 3. (-11)=(-2)x7+3, so q=-2 and b=3

3

b is always non-negative

Congruent Modulo

Two integers, a and b, are congruent modulo n if and only if a mod n = b mod n

When a and b are divided by n, they have the same remainder

a ≡ b (mod n) ⇔ a mod n = b mod n

Example:

100 mod 11 = 1; 34 mod 11 = 1

So 100 ≡ 34 (mod 11)

In arithmetic modulo n, a and b are equivalent if their difference, (a – b), is a multiple of n

n | (a – b)

Example:

10 ≡ 2 (mod 4) because 4 | (10 − 2)

4

Modular Arithmetic

Modular arithmetic is ‘clock arithmetic’

For clock, time goes from 1 to 12, and back to 1 again

For modulo arithmetic, we start with 0, go up to n-1, and then go back to 0

Modular arithmetic uses a finite number of values, and loops back from either end

When we do modular arithmetic, we can first perform the operation and then modulo reduce the answer

Examples:

( 12 + 8 ) mod 5 = 20 mod 5 = 0

( 12 x 8 ) mod 5 = 96 mod 5 = 1

5

Modulo Reduction

The results of modular computations must remain within Zn = {0, 1, 2, … n-1}

For large values, modulo reduction is used to simplify modular computations.

Modulo properties:

Reducing each intermediate result modulo n yields the same result as doing the entire calculation, and then reducing the result to modulo n

For integers a, b, and c, and for positive n, we have:

( a + b ) mod n = ( ( a mod n ) + ( b mod n ) ) mod n

( a – b ) mod n = ( ( a mod n ) – ( b mod n ) ) mod n

( a · b ) mod n = ( ( a mod n ) · ( b mod n ) ) mod n

a (b+c) mod n = ( ( a b mod n ) · ( a c mod n ) ) mod n

Examples

( 12 + 8 ) mod 5 = ( ( 12 mod 5 ) + ( 8 mod 5 ) ) mod 5 = ( 2 + 3 ) mod 5 = 5 mod 5 = 0

(12 – 8) mod 5 = ( (12 mod 5 ) – ( 8 mod 5) ) mod 5 = ( 2 – 3 ) mod 5 = -1 mod 5 = 4

( 12 · 8 ) mod 5 = ( ( 12 mod 5 ) · ( 8 mod 5 ) ) mod 5 = ( 2 · 3 ) mod 5 = 6 mod 5 = 1

26 mod 5 = ( ( 22 mod 5 ) · ( 24 mod 5 ) ) mod 5 = (( 4 mod 5 ) · ( 16 mod 5 ) ) mod 5= (4*1) mod 5 = 4

Other properties:

Transitive law: a ≡ b ≡ c, then a ≡ c

Commutative: a + b = b + a

Associative: (a + b) + c = a + (b + c)

Distributive: a(b + c) = ab + ac

6

Modular Inverse

Given two positive integers x and y, both less than some other positive integer n, we say that y is the modular inverse of x, modulo n, and x is the modular inverse of y, modulo n,

if and only if (x · y) mod n = 1, for 0 < x < n and 0 < y < n

x-1 = y (mod n)

Example:

Prove 7 and 3 are inverses modulo 10

Steps:

Compute the multiplication

Compute the modulo value of the result

If the modulo value is 1, the numbers are inverses

7 · 3 = 21

21 mod 10 = 1

Since the modulo value is 1, 7 and 3 are inverses modulo 10

7

Properties of Modular Inverse

The number 1 is always the modular inverse of 1 for any modulus.

Not all values less than a particular modulus have inverses

Inverse of 2, mod 14 does not exist

Look at the row of 2

This row does not have 1

For the number a and modulo n, the inverse can be found if a and n are relatively prime

Relatively prime: two numbers a, n are relatively prime if gcd(a,n) = 1, where gcd is greatest common divisor

In the table, we can see 1, 3, 5, 9, 11 and 13 are relatively prime to 14.

So those rows contains 1, indicating modular inverses

8

Mod 14 multiplication table

Summary

What is Modulo Operation

Concept of Congruent Modulo

Modular Arithmetic

Modulo Reduction

Modular Inverse

Properties of Modular Inverse

9

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

#6925 Computer Science Database

Adventure Works Cycles Company Story

Business

Adventure Works Cycles, the fictitious company on which the AdventureWorks sample databases are based, is a large, multinational manufacturing company. The company manufactures and sells metal and composite bicycles to North American, European, and Asian commercial markets. While its base operation is located in Bothell, Washington, with 290 employees, several regional sales teams are located throughout its market base.

In 2000, Adventure Works Cycles bought a small manufacturing plant, Importadores Neptuno, located in Mexico. Importadores Neptuno manufactures several critical subcomponents for the Adventure Works Cycles product line. These subcomponents are shipped to the Bothell location for final product assembly. In 2001, Importadores Neptuno, became the sole manufacturer and distributor of the touring bicycle product group.

Coming off a successful fiscal year, Adventure Works Cycles is looking to broaden its market share by targeting its sales to its best customers, extending its product availability through an external website, and reducing cost of sales through lower production costs.

Product Overview

As a bicycle manufacturing company, Adventure Works Cycles has four product lines:

· Bicycles that are manufactured at the Adventure Works Cycles company.

· Bicycle components that are replacement parts, such as wheels, pedals, or brake assemblies.

· Bicycle apparel that is purchased from vendors for resale to Adventure Works Cycles customers.

· Bicycle accessories that are purchased from vendors for resale to Adventure Works Cycles customers.

Manufacturing Overview

· Bill of materials: List of the products used or contained in another product.

· Work orders: Manufacturing orders by work center.

· Locations: Major manufacturing and inventory areas, such as frame forming, paint, subassembly, and so on.

· Manufacturing and product assembly instructions by work center.

· Product inventory: The physical location of a product in the warehouse or manufacturing area, and the quantity available in that area.

· Engineering documentation: Technical specifications and maintenance documentation for bicycles or bicycle components.

Assignment 1

The purpose of this assignment is to practice navigating and identifying database tables and related fields.

For this assignment, assume you have just been hired by Adventure Works Cycles company. As part of the orientation process, you have been asked to learn a little about the company by reading the “Adventure Works Cycles Company Story.”

Your supervisor also wants you to gain an understanding of the content included in the company database. To do this, you must utilize SELECT and FROM statements like the example provided below.

EXAMPLE: SELECT * FROM [Database].[Schema_Name].[Table_Name]

Access the “AdventureWorks 2016 and Scripts for SQL Server 2016 CTP3” database and use SELECT and FROM statements to find the answer to each of the questions below. Create a Word document that includes the SQL queries used to explore the database tables and answer the following questions using the queries completed in steps 1-5.

Please note that when SQL queries are run, results are generated in the form of data. This data should be exported and saved to an Excel file for a visual check of accuracy.

1. Locate the “Person” table and run a basic SELECT query as listed in the example. List all the available fields and how many records exist in that table.

2. On what table and schema would you locate an applicant’s resume data?

3. When is the CEO’s Birthday?

4. What is the list “ListPrice” of the product “HL Touring Seat Assembly?”

5. Is “Holiday Skate & Cycle” a preferred vendor?

Compile the Excel data file and Word document containing the SQL queries and answers to the questions into a .zip file and submit to your instructor.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

For part 2 of assignment 1

Proposal for Process Improvement

Requestor:

Business Problem:

Proposed Solution:

Required Resources:

1.

1.

Implementation Steps:

1.

1.

Benefits:

1.

1.

Potential Obstacles:

1.

1.

1. The purpose of this assignment is to practice making proposals to communicate database needs to relevant stakeholders.

1. For this assignment, assume you work at Adventure Works Cycles. Your manager recently informed you that by law, all employees must have an emergency phone number on file. This information is not currently included in the company database, so you must submit a proposal to the IT Department detailing your request to have it added.

1. Using the “Proposal for Process Improvement” template, construct a Word document that outlines the requester, business problem, proposed solution, resources, implementation steps, benefits, and potential obstacles of the request.

1. APA style is not required, but solid academic writing is expected.

1. This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

1. You are not required to submit this assignment to Turnitin.

Assignment 2

The purpose of this assignment is to analyze the structure of a relational database and demonstrate the ability to correctly document and explain additions to the structure of a relational database.

Part 1:

For this part of the assignment, you will use the “AdventureWorks 2014 OLTP Schema.” Open the schema and follow the tree/chain to answer the questions below in a Word document.

1. How does the Sales.SalesTerritory table relate to the Person.StateProvince table? Which table holds the Primary and the Foreign Key? On what field do they join together?

2. If you wanted to know the Planned Cost of a Product, what route would you take to the data? Identify the tables and fields used to join on each.

3. Imagine a bonus was paid to an employee using a different currency. Identify the fields you would need so you could access the information. List all the tables involved and the fields used to join.

Part 2:

For this part of the assignment, you will continue to assume you work at Adventure Works Cycles company. In the Topic 1 assignment, you made a request to add a field to the company database. That request has been approved, and now the database diagram needs to be accurately updated.

Create a simple OpenOffice Draw document demonstrating how your new table will connect to the Human Resources.Person table on the diagram. Since this is a new table, add new fields to create the proper relationships as you see fit.

In a one or two paragraph Word document, explain how these fields relate to the rest of the database content.

Compile the OpenOffice Draw file and Word document into a .zip file and submit to your instructor.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

Assignment 3

The purpose of this assignment is to identify business problems that can be addressed through analyzing database content.

For this assignment, assume the role of a data analyst at Adventure Works Cycles company. Your manager recently approached you with a problem. The company is losing money on its popular model “LL Road Frame-Black 60” but cannot determine why sales are down. You have been tasked to research potential reasons why this product, which your manager believes is solid, is not selling.

In order to address this business problem, you must deconstruct it. Study the entity relationship diagram (ERD) titled “AdventureWorks 2014 OLTP Schema,” and use it determine the specific questions that must be asked and answered to address the problem.

In a 250-word document, address the following. Include basic information related to the problem along with specific information about the tables that should be researched.

1. Explain what methods will be used to set the parameters for the query.

2. Define the specific questions that need to be asked and answered in order to address the specified business problem.

3. Explain how the entity relationship diagram (ERD) was used in addressing questions 1-2 above.

4. Describe ethical dilemmas that could be encountered as a result of the research being done to address the business problem.

5. Explain what resources you will use to assist with addressing ethical dilemmas.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

Assignment 4

The purpose of this assignment is to design and implement queries that will assist in developing answers to business problems.

For this assignment, continue to operate in the role of a data analyst at Adventure Works Cycles company. Based upon “LL Road Frame-Black 60” scenario and questions formulated for the Topic 3 assignment, write queries for the “AdventureWorks 2016” database using SQL Server 2016 Developer Edition.

Please note that when SQL queries are run, results are generated in the form of data. This data should be exported and saved to Excel for a visual check of accuracy.

Create a Word document that includes the SQL queries used to explore the database tables, and answer the following questions.

1. Find the product ID for the LL Road Frame – Black 60.

2. Find the listing price of the LL Road Frame – Black 60.

3. How would you rewrite the query used in question 2 to exclude NULL values?

4. How many orders have been placed for LL Road Frame – Black 60?

5. Rename the OrderQty to Quantity in your results.

Compile the Excel data file and Word document containing the SQL queries and answers to the questions into a .zip file and submit to your instructor.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

Assignment 5

The purpose of this assignment is to design and implement queries that will assist in developing answers to business problems.

For this assignment, continue to operate in the role of a data analyst at Adventure Works Cycles company. Based upon “LL Road Frame-Black 60” scenario and questions formulated for the Topic 3 assignment, write queries for the “AdventureWorks 2016” database using SQL Server 2016 Developer Edition.

Please note that when SQL queries are run, results are generated in the form of data. This data should be exported and saved to Excel for a visual check of accuracy.

Create a Word document that includes the SQL queries used to explore the database tables, and answer the following questions.

1. Find the product ID for the LL Road Frame – Black 60.

2. Find the listing price of the LL Road Frame – Black 60.

3. How would you rewrite the query used in question 2 to exclude NULL values?

4. How many orders have been placed for LL Road Frame – Black 60?

5. Rename the OrderQty to Quantity in your results.

Compile the Excel data file and Word document containing the SQL queries and answers to the questions into a .zip file and submit to your instructor.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

Part 2

The purpose of this assignment is to create temporary tables and document them using an entity relationship diagram (ERD).

For this assignment, continue to play the role of the data analyst for Adventure Works Cycling Company.

Please note that when SQL queries are run, results are generated in the form of data. This data should be exported and saved to Excel for a visual check of accuracy.

Create a Word document that includes the SQL query code for the temporary table that includes the dates of each sales order.

1. Create a temporary table for each of the Topic 4 assignment data components.

2. Use the skills you have learned and practiced to write a query to determine the dates of each sales orders from a table you have not looked at yet. Create a temporary table for this information.

3. Use OpenOffice Draw to create a new entity relationship diagram (ERD) to document the addition of the temporary tables and the work stream. Show the relationship between the tables.

Compile the OpenOffice Draw, Excel data file, and Word document containing the SQL queries and answers to the questions into a .zip file and submit to your instructor.

APA format is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

Assignment 6

The purpose of this assignment is to complete two complex queries, join them, and validate the expected results of the join.

For this assignment, continue to assume the role of a data analyst at Adventure Works Cycling Company. As you work to address the business problem surrounding sales of the “LL Road Frame-Black 60,” you must continue to refine the data by condensing them into two tables. This requires you to join the table data sets together. While this is an important process, you must be aware of the data integrity issues that can occur as a result of completing joins.

Please note that when SQL queries are run, results are generated in the form of data. This data should be exported and saved to Excel for a visual check of accuracy.

Create a Word document that includes the SQL query code used to explore the database tables and answer the following questions.

Complete the steps below to practice joins.

1. Combine MyProduct and MyPriceHistory displaying the fields into a new temporary table called MyProductPriceHistory. Display ProductID, Name, EndDate, and List Price.

2. Combine MyProduct and MySalesOrderDetail displaying the fields into a new temporary table called MySalesOrderDetailbyName. Display ProductID, Name, SalesOrderID, and Quantity.

3. Combine MySalesOrderDetailbyName and ALLSalesOrderDates displaying the fields into a new temporary table called MySalesHistory. Display ProductID, Name, OrderDate, and SumOfQuantity. This will require you using the SUM and GROUP BY statements.

Create a Word document that includes the SQL query code used for each of the joins listed. Additionally, identify and analyze the data integrity issues you encountered in SQL.

1. Discuss bad queries and bad table data in your analysis.

2. Explain the impact of the data integrity issues.

3. Indicate what needs to be revised in the code.

4. Discuss specifically what needs to be done to fix the data integrity issues created by the join. Please note that as part of your final project for the course you will be adding these new tables to the ERD you created in Topic 5.

Compile the Excel data file and Word document containing the SQL queries and answers to the questions into a .zip file and submit to your instructor.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

Assignment 7

he purpose of this assignment is to update a previous query and present it in an easily readable format.

For this assignment, continue to assume the role of a data analyst at Adventure Works Cycles company.

Please note that when SQL queries are run, results are generated in the form of data. This data should be exported and saved to Excel for a visual check of accuracy.

Create a Word document that includes the SQL query code used to explore the database tables and answer the following questions.

Part 1:

1. Using what you have learned, replicate the data found in #MySalesOrderDetailbyDate and #MyProductPriceHistory using a single line of SQL code. Refer back to the Topic 5 assignment for this information.

2. Modify the query completed in the Topic 6 assignment, and present it in an easy-to-read format. To do this, write the query in two single statements without temporary tables, using abbreviations and line spacing.

Part 2:

Karen Berge, a document control assistant at the company, comes to you with a request. Karen wants the titles and file names of all of the documents she has produced and has asked you to generate this information for her. Using what you have learned, produce a query in one statement to give her the information she needs. Note that constructing the query will require some thinking outside the box since the relationships are not well documented.

Please note that when SQL queries are run, results are generated in the form of data. This data should be exported and saved to Excel for a visual check of accuracy. This Excel file should include the names of all documents Karen has produced.

Add to the Word document you created in Part 1 and include the SQL query code associated with the query you wrote to locate Karen’s documents.

Compile the Excel data file and Word document containing the SQL queries and answers to the questions into a .zip file and submit to your instructor.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

Assignment 8

The purpose of this assignment is to analyze data and use it to provide stakeholders with potential answers to a previously identified business problem.

For this assignment, continue to assume the role of a data analyst at Adventure Works Cycling Company. Evaluate the data associated with the drop in sales for the popular model “LL Road Frame-Black 60.” Provide a hypothesis on what could be contributing to the falling sales identified in the initial business problem presented by your manager.

In 250-500 words, share these recommendations in a Word document that addresses the following.

1. Summary of the business problem including the requestor who initially brought the problem to you.

2. Summary of the data that were requested and how they was obtained.

3. Discussion of the limitations of the available data and ethical concerns related to those limitations.

4. Hypothesis of why sales of the popular model have dropped based upon data analysis. Reference the Excel file that summarizes the data findings that resulted from your queries.

5. Recommendations for addressing the business problem.

6. In addition to the report, the manager has requested that you submit the Excel files summarizing the data findings that resulted from your queries.

7. The manager has also requested that you update the ERD you created in the Topic 5 assignment to include the tables generated as a result of the joins completed in the Topic 6 assignment. The ERD should clearly document the work stream and relationships.

Compile the updated ERD, Excel data file, and Word document containing the SQL queries and answers to the questions into a .zip file and submit to your instructor.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

Part 2

The purpose of this assignment is to build a stored procedure that allows for the compression of data and the ability to run a process repeatedly over time.

For this assignment, continue to assume the role of a data analyst at Adventure Works Cycling Company. Your manager is waiting for you to deliver your analysis of why the company is losing money on its popular model “LL Road Frame-Black 60.” As you are preparing your final report, your manager asks you to save your final queries from Topic 6 (the two nontemporary queries) as a stored procedure so you can periodically check on them from time to time. To do this, you will need to complete the steps below.

Please note that when SQL queries are run, results are generated in the form of data. This data should be exported and saved to Excel for a visual check of accuracy.

Create a Word document that includes the SQL query code used to explore the database tables.

1. Drop all ORDER_BY statements from the query.

2. Label one as PriceHistory723.

3. Label the other as SalesOrderDetailbyDate723.

Compile the Excel data file and Word document containing the SQL queries into a .zip file and submit to your instructor.

APA style is not required, but solid academic writing is expected.

This assignment uses a rubric. Please review the rubric prior to beginning the assignment to become familiar with the expectations for successful completion.

You are not required to submit this assignment to Turnitin.

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

A+ Answers

Question 1 You have purchased an Apple desktop computer and want to set it up so that you can access your computer desktop when you are on the road. How might you do this? A. Install Remote Desktop for Apple on your desktop. B. Install Apple+ VPN on your desktop. C. Configure your desktop for Platform as a Service. D. Install the GoToMyPC client on your desktop.

 

Question 2 What is a chief concern of cloud computing? A. Cost B. Security C. Redundancy D. Speed

 

Question 3 You have a Bluetooth headset that integrates with your computer so that you can talk to partners through Microsoft Lync. This is an example of what type of wireless networking? A. WLAN B. WPAN C. WMAN D. WWIRE

 

Question 4 Your boss calls you from his home to use the VPN connection you configured for him on his laptop. He has traditionally depended on Remote Desktop to access the server. Your boss tells you that the VPN connection shows that it is connected but the server’s desktop is not appearing on his screen. What do you tell him? A. The firewall on his home router must be blocking the remote connection. B. His ISP must not allow encrypted connections through their network. C. He must be running Windows 8 which doesn’t support VPN. D. VPN doesn’t bring up a remote desktop on the local computer.

 

Question 5 Your company is trying to get out of the responsibility of purchasing and hosting its own hardware so it won’t have to finance or manage a datacenter anymore. Your boss has told you that you need to install an operating system on all of the cloud-based servers. This is an example of what type of cloud computing? A. Infrastructure as a Service B. Network as a Service C. Platform as a Service D. Software as a Service

 

Question 6 You are configuring a wireless connection on your home router. Because you live in an apartment complex, the security level of the connection is paramount. Which wireless option below is the most secure? A. SSID B. WEP C. WPA D. WPA2 Question 7 In order for your laptop to make a wireless connection, it must first find an available __________ to connect to. A. SSID B. VPN C. RSAT D. WEP

 

Question 8 Your boss wants to utilize some sort of cloud storage for his files so that all of his computing devices can replicate these files. He installs the client on all of his devices. He asks you where the cloud folder is located within Windows Explorer. What do you tell him? A. It is located in his local profile. B. It is located in Program Files. C. It is located in Program Files. (86) D. It is located in the Windows System folder.

 

Question 9 Your boss wants you to devise a way for remote contractors to be able to access the server desktop. There is one stipulation, however, in that your boss wants to ensure that the local user can see everything that the remote contractor is doing in real time. What do you suggest? A. Install TeamViewer on the server. B. Configure a VPN connection on the server. C. Install GoToMyPC on the server. D. Configure RDP within the server’s web browser.

 

Question 10 You have a number of digital pictures you recently took on your smartphone. You would like to share these pictures with all of your friends and family. What is a “Cloud”-like example of sharing these pictures with them? A. Upload them to www.flickr.com and share a link with them. B. Email them to everyone by way of email attachments. C. Save them to your My Pictures folder on your Windows 8 tablet. D. Save them to a fractional website that offers file transfer capabilities.

 

Question 11 Your boss is very skeptical about the idea of storing his files up in the cloud rather than on a local storage drive. He asks you to give him the various advantages of cloud storage. Which of the selections below would not be a reason you give him? A. He won’t have to worry about backing up his files anymore. B. Cloud storage provides unlimited storage for free. C. He can keep all of his files replicated and uniform on all of his devices. D. He can access his files from anywhere he has an Internet connection.

 

Question 12 When you connect to a remote VPN server with your laptop running Windows 8, what key item is your computer allocated? A. The desktop of the VPN server B. The desktop of the logon server C. An IP address from the remote network D. A web browser with an SSL connection

 

Question 13 How does fractional employment differ from the traditional full-time job model of today? A. Fractional employment demands complete mathematical skills. B. A work unit in fractional employment is a project or task, not a job. C. Fractional employment only employs people from outside the United States. D. Fractional employment is exclusively for IT workers.

 

Question 14 Your CEO is concerned that too much productivity is lost by having employees call each other, only to be directed to voice mail. He asks you if something can be done to counter this. What do you suggest? A. Integrate Dropbox into the company network. B. Integrate RDP into the company network. C. Integrate Microsoft Lync into the company network. D. Integrate TeamViewer into the company network.

 

Question 15 Which of the following is a proper use of the application, NetStumbler? A. Finding rogue access points within your network B. Managing multiple access points within a large network C. Disguising designated broadcast SSIDs on your network D. Creating open-ended wireless connections for easy access

 

Question 16 Making a phone call through Lync from your laptop using only your headset is an example of: A. a PBX phone connection. B. an encrypted phone conversation. C. a legacy phone conversation. D. a peer-to-peer phone conversation.

 

Question 17 Your mom wants to start using some type of cloud storage so that she can access some of her important business files from anywhere without having to remote into another machine. What do you suggest? A. TeamViewer B. GoToMyPC C. Dropbox D. Microsoft RT

 

Question 18 Your sister is considering purchasing a tablet computer that utilizes RT as the operating system. She asks you if RT is any different from her Windows 8 desktop she has at home. What do you tell her? A. Unlike her Windows 8 PC, RT does not have a tile-based interface. B. RT is an Android-based operating system so it is completely different. C. RT isn’t touch-enabled so it is a poor choice for a tablet. D. She won’t be able to install regular Windows application on RT.

 

Question 19 You have set up Remote Desktop for the company server running Server 2008 so that your users can RDP in from their XP workstations. Users are calling you saying that they are being denied the ability to remote in. What is the most likely reason? A. XP does not support Remote Desktop by default. B. Network Level Authentication is being enforced on the RDP connection. C. Server 2008 does not support Remote Desktop by default. D. Remote Desktop only works through a web browser over the Internet.

 

Question 20 Which of these devices is usually the default gateway for most home networks? A. A workstation B. A server C. A smartphone D. A wireless router

 

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

LINEAR PROGRAMMING / PROJECT MANAGEMENT – USE POM SOFTWARE

POM-QM for Windows software LINK(http://wps.prenhall.com/bp_heizer_opsmgmt_10/147/37741/9661929.cw/index.html )

For this part of this project, you will need to use the POM software:

1. Read Appendix IV of the Operations Management (Heizer and Render, 2014) textbook.

2. Review the linear programming section from the POM manual:  Weiss, H.J. (2013) POM-QM for Windows manual. Upper Saddle River, NJ: Prentice Hall. Available from the ‘Help’ menu in the POM-QM Windows software. (Accessed: 30 December 2014). You may also wish to research and review online tutorials regarding the linear programming module and/or view the following resource.

Valverde, R. (2014) QM for Windows linear programming [Online] YouTube. Available from:  https://www.youtube.com/watch?v=uHsQSG75sPk  (Accessed 23 April 2015).

3. Install and launch the POM-QM for Windows software. From the main menu, select Module and then Linear Programming.

4. Program the linear programming formulation for the problem below and solve it with the use of POM. Refer to Appendix IV from the Heizer and Render (2014) textbook.

Note: Do not program the non-negativity constraint, as this is already assumed by the software.

For additional support, please reference the POM-QM for Windows manual available from the ‘Help’ menu in the POM-QM Windows software.

Individual Project, part 1

A firm uses three machines in the manufacturing of three products:

· Each unit of product 1 requires three hours on machine 1, two hours on machine 2 and one hour on machine 3.

· Each unit of product 2 requires four hours on machine 1, one hour on machine 2 and three hours on machine 3.

· Each unit of product 3 requires two hours on machine 1, two hours on machine 2 and two hours on machine 3.

The contribution margin of the three products is £30, £40 and £35 per unit, respectively.

The following are available for scheduling:

· 90 hours of machine 1 time

· 54 hours of machine 2 time

· 93 hours of machine 3 time

The linear programming formulation of this problem is as follows:

Maximise Z = 30X1 + 40X2 + 35X3

3X1 + 4X2 + 2X3 <= 90

2X1 + 1X2 + 2X3 <=54

X1 + 3X2 + 2X3 <=93

With X1, X2, X3 >= 0

To answer this question:

Answer each question and explain your reasoning or show your calculations.

1. What is the optimal production schedule for this firm? What is the profit contribution of each of these products?

2. What is the marginal value of an additional hour of time on machine 1? Over what range of time is this marginal value valid?

3. What is the opportunity cost associated with product 1? What interpretation should be given to this opportunity cost?

4. How many hours are used for machine 3 with the optimal solution?

5. How much can the contribution margin for product 2 change before the current optimal solution is no longer optimal?

Individual Project, part 2

For this part of this project, you will need to use the POM software:

1. Review the linear programming section from the POM manual:  Weiss, H.J. (2013) POM-QM for Windows manual. Upper Saddle River, NJ: Prentice Hall. Available from the ‘Help’ menu in the POM-QM Windows software. You may also wish to research and review online tutorials regarding the linear programming module.

2. Program the project management problem below and solve it with the use of POM. Select Project Management(PERT/CPM) module, and then select the option File->New->Mean, Std dev given items.

Activity Mean duration Std. dev. (days)
A 11 0.9
B 13 1.1
C

7 0.2
D 9 0.8
E 6 1
F 7 1.2
G 10 0.7
H 9 0.6
I 8 0.8

Table 1: Activity, duration and standard deviation

To answer this question:

Answer each question and explain your reasoning or show your calculations.

1. Calculate the project completion time.

2. Indicate the critical path activities.

3. What is the probability of completing this project between 38 and 40 days?

4. What are the slack values for activities C and F? Interpret the meaning of their slack values.

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

Personas For Project Design

Quiz application

 

Questionnaire Information:

1. I’m going to select the quiz application, my project for my questionnaire and I’ve selected all age group people for that.

2. I need information from them about the interest of each age group and how much they are interested in that.

 

Questionnaire

1. Your Name:

___________________________________

2. Your age group:

1. 15-25

2. 25-35

3. 35-45

4. 45 above

3. What interests you the most?

1. Games

2. Politics

3. Movies

4. Sports

4. How many hours do you spend in self-study?

1. Below 2

2. 2-3

3. Above 3

5. Do you like playing quizzes or games on computer?

1. Yes

2. No

6. Rate your interest in quiz games out of 5:

1. Worst

2. Bad

3. Average

4. Good

5. Best

________________________________________________________________

7. How often you participate in a discussion:

1. Once a week

2. Twice

3. Thrice

4. Daily

8. What kind of topics you like to discuss in your conversation:

 

9. How many times you go to the gym for your physical fitness?

1. Once a week

2. Twice a week

3. Thrice a week

4. Daily

10. How important are the political issues in your life?

1. I don’t care about it

2. Slightly important

3. Definitely important

4. Very important

11. What sports do you like the most?

 

12. What is your favorite game in computer games?

__________________________________________________

13. What genre do you like the most in games?

1. RPG (role playing games)

2. FPS (First person shooting)

3. Strategy

4. Simulation

5. Fighting

6. Sports

14. Which is the most important thing about video games

1. Graphics

2. Game play

3. Sound

4. Customization

15. What is preferable in quiz game?

1. More options

2. Life lines

3. Difficult questions

16. How much have you spent on a game and what game?

1. 2 hours

2. 4 hours

3. 6 hours

4. above

17. Is education necessary for the intelligence or knowledge is enough?

1. Education

2. knowledge

18. Which color do you think is the best for the interactive screen for quiz game

________________________________________________________________

19. What services do you think should be in a quiz game or application?

____________________________________________________________________________________________________________________________________________________________________________________________________________________________________________________

20. Would you like to play a new game which tells you about the interest you have and then play quizzes according to your interests?

1. Yes

2. No

 

Questionnaire Response Type:

1. Demographic = Open ended was the only way

2. Age group = Select options are easy over open ended

3. Already availing any service = yes/no is better suited because this is a conclusion question

4. Importance of education and knowledge = Select options are easy over open ended

5. Appearance of application = options can describe the answer here

6. Work and interest preference = options can describe the answer here

7. Necessity of application = yes/no would be best to conclude

8. Balanced interest = yes/no can conclude

9. Source of information = options are better to describe

10. Feedback for new application = open ended for the description in detail

 

Summary for Survey

Survey plan

1. Group would use the universities and other quiz applications where young and middle age boys are there and offices and parks for upper age people are there.

2. Sequence is started from

a. Name and general information

b. Type of interest

c. Ask the interest level in politics

d. Ask the interest level in sports

e. Ask the interest level in games

f. Environment and color scheme and other questions about application should be

g. Preference of user

h. He prefers education over knowledge or discourage the education

i. Source of information of marketing

j. Feedback from user in addition

k. About the application and if interested in playing new app.

This survey defines the interest level in each category that is sports, games, movies and politics. By asking each category we can have the idea about the taste and mindset of the person. So we can have the questions majority in our quizzes according to the that category, we can make this more detailed if want to have a detailed look but right now it’s good to have the idea just what type of a person is taking the quiz.

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

Rewrite

1. Label the box below to create a two-pass schedule legend.

Ans:

ES   EF
     
     
Float Activity Name  
  Duration  
     
LS   LF
     

 

3. In the example below, label which activities are predecessors and which activities are successors.

Ans:

Predecessor: An activity which comes before another activity. So, it is activity “A” and activity “B”.

Successor: An activity that must occur after another activity. So, it is activity “C”.

 

5. Calculate early start, early finish, late start, late finish, and float for each of the activities in the network below. The duration of each activity is given.

 

Based on the analysis for the two-pass schedule:

A B C D

Duration: 12 Duration: 4 Duration: 1 Duration: 7

Early start: 0 Early start: 12 Early start: 16 Early start: 12

Early finish: 12 Early finish: 16 Early finish: 17 Early finish:19

Late start: 0 Late start: 14 Late start: 18 Late start: 12

Late finish: 12 Late finish: 18 Late finish: 19 Late finish: 19

Float: 0 Float: 2 Float: 2 Float: 0

 

E

Duration: 3 Early finish: 22 Late finish: 22

Early start:19 Late start: 19 Float: 0

 

6. Identify the critical path for the network in Exercise 5. How long should the project take?

Ans: The critical path is:

A – D – E, which has the longest path of 22 days.

 

9. Given the information below, create the project schedule network. Then, using the enumeration method, calculate and show all of the paths through the network. Show how long each path will take. Identify the critical path. Show the schedule on a Gantt chart showing critical and noncritical activities and float.

The critical path is

B – A – C – F – H – I, which takes 25 days.

Other paths:

B – E – H – I = 20 days

B – A – D – G – I = 23 days

 

 

Part 2 Scheduling Problem (50 points)

Complete the following:

Your child is a member of the school theater group and have been asked to prepare the schedule, etc. for a skit to be performed during the 4th of July celebration in the local village square.  As a volunteer, you offer to serve as the project controller because of your expertise in schedule management.

1. Construct an AON diagram similar to the format used in the Youtube videos found in the commentary using an MS Excel spreadsheet.  Ensure that you include a Start activity and a Finish activity.  Include a legend (example is the one completed in Question 1, Part 1.

1. Calculate the estimated time for each activity using PERT techniques for the 3 estimates provided.  Include a sample calculation.

1. Prepare a table that identifies all paths and their lengths.  Which path is the critical path?

1. During the execution phase of the skit project, one of the activities on the critical path is delayed by one day.  Is this serious?

1. Using the activity estimates for optimistic, pessimistic and most likely time to complete activities on the critical path, qualitatively discuss the estimate uncertainty of the critical path.

 

ANS: 1

2.

Different Paths are:

 

1. : 1-5-10-13-15

1. : 1-4-9-13-15

1. : 1-4-6-8-12-15

1. : 2-6-8-12-15

1. : 2-3-8-12-15

1. : 2-3-7-11

1. : 2-3-7-14

# Optimistic Most Likely Pessimistic
1 39 44 55
2 39 48 63
3 41 52 63
4 37 43 49
5 35 42 49
6 32 37 42
7 29 34 39

 

 

3.

Activity Duration Early Start Early Finish Late Start Late Finish Float
1 4 0 4 0 4 0
2 5 0 5 0 5 0
3 5 10 15 15 20 5
4 10 4 14 4 14 0
5 12 4 16 11 23 7
6 6 14 20 14 20 0
7 10 10 20 25 35 15
8 7 20 27 20 27 0
9 9 14 23 17 26 3
10 3 16 19 23 26 7
11 17 20 37 35 52 15
12 8 27 35 27 35 0
13 9 23 32 26 35 3
14 14 20 34 38 52 18
15 17 35 52 35 52 0

 

The critical path is 1-4-6-8-12-15 = 4+10+6+7+8+17 = 52

4.

If one activity in the critical path is delayed for one day, the critical path will delay one day and the whole project will delay for a day too.

5.

If we use optimistic time for the critical path, that is 41 days, the pessimistic path is 63 days, which means 22 days of uncertainty can be saved.

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

Computer Science

Basic Charts – Part 1

 

This Tableau file contains information on all U.S. airline flights from 2010 and 2011. Create a Tableau worksheet to answer each of the following questions:

FILE to use: your completed Flights_data.twbx

 

1. A quick viz of flights over time shows a drop of more than 300,000 flights from 2010 to 2011:

From your experience, you know that flight activity did not drop so significantly between 2010 and 2011. Why does this viz seem to indicate otherwise? Investigate flights over time in more detail to determine why these yearly numbers show such a large drop.

 

2. You are interested in identifying days that are particularly light in terms of travel each year. Are there particular holidays that seem to experience substantially lower numbers of flights?

 

3. Next, you want to know who operates the most flights. Is there one airline that operated more flights than any other single airline for each week in this dataset?

 

4. You would also like to know which states tend to experience the longest departure delays. Create a map that visualizes the departure delay that you can expect in each origin state. Allow the user to filter by airline. Colors should range from dark blue for states with short departure delays to dark red for states with long departure delays.

 

 

 

 

 

 

 

 

Dashboards – Part 2

 

As a starting point for this exercise, use the visualizations you created in Part 1 using the Flights Data. Organize those worksheets into the dashboard depicted below (try to recreate it exactly). Note that a selection on the right updates both the map and the line graph.

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

Need Help Step-By-Step How To Code Python For Data Visualization

1-  collect data using an API for TMDb

2- construct a graph representation of this data that will show which actors have acted together in various movies

3- complete all tasks according to the instructions found in the file ‘submissions_og2.py’ to complete the Graph class, the TMDbAPIUtils class, and the two global functions. The Graph class will serve as a re-usable way to represent and write out your collected graph data. The TMDbAPIUtils class will be used to work with the TMDB API for data retrieval.

4- Create a TMDb account to obtain an authentication token.

5- Producing correct nodes.csv and edges.csv

ps. other files are examples found in the intenret (not sure if can help)

 

import http.client import json import csv ############################################################################################################################# # cse6242 # All instructions, code comments, etc. contained within this notebook are part of the assignment instructions. # Portions of this file will auto-graded in Gradescope using different sets of parameters / data to ensure that values are not # hard-coded. # # Instructions: Implement all methods in this file that have a return # value of ‘NotImplemented’. See the documentation within each method for specific details, including # the expected return value # # Helper Functions: # You are permitted to write additional helper functions/methods or use additional instance variables within # the `Graph` class or `TMDbAPIUtils` class so long as the originally included methods work as required. # # Use: # The `Graph` class is used to represent and store the data for the TMDb co-actor network graph. This class must # also provide some basic analytics, i.e., number of nodes, edges, and nodes with the highest degree. # # The `TMDbAPIUtils` class is used to retrieve Actor/Movie data using themoviedb.org API. We have provided a few necessary methods # to test your code w/ the API, e.g.: get_movie_cast(), get_movie_credits_for_person(). You may add additional # methods and instance variables as desired (see Helper Functions). # # The data that you retrieve from the TMDb API is used to build your graph using the Graph class. After you build your graph using the # TMDb API data, use the Graph class write_edges_file & write_nodes_file methods to produce the separate nodes and edges # .csv files for use with the Argo-Lite graph visualization tool. # # While building the co-actor graph, you will be required to write code to expand the graph by iterating # through a portion of the graph nodes and finding similar artists using the TMDb API. We will not grade this code directly # but will grade the resulting graph data in your Argo-Lite graph snapshot. # ############################################################################################################################# class Graph: # Do not modify def __init__(self, with_nodes_file=None, with_edges_file=None): “”” option 1: init as an empty graph and add nodes option 2: init by specifying a path to nodes & edges files “”” self.nodes = [] self.edges = [] if with_nodes_file and with_edges_file: nodes_CSV = csv.reader(open(with_nodes_file)) nodes_CSV = list(nodes_CSV)[1:] self.nodes = [(n[0], n[1]) for n in nodes_CSV] edges_CSV = csv.reader(open(with_edges_file)) edges_CSV = list(edges_CSV)[1:] self.edges = [(e[0], e[1]) for e in edges_CSV] def add_node(self, id: str, name: str) -> None: “”” add a tuple (id, name) representing a node to self.nodes if it does not already exist The graph should not contain any duplicate nodes “”” return NotImplemented def add_edge(self, source: str, target: str) -> None: “”” Add an edge between two nodes if it does not already exist. An edge is represented by a tuple containing two strings: e.g.: (‘source’, ‘target’). Where ‘source’ is the id of the source node and ‘target’ is the id of the target node e.g., for two nodes with ids ‘a’ and ‘b’ respectively, add the tuple (‘a’, ‘b’) to self.edges “”” return NotImplemented def total_nodes(self) -> int: “”” Returns an integer value for the total number of nodes in the graph “”” return NotImplemented def total_edges(self) -> int: “”” Returns an integer value for the total number of edges in the graph “”” return NotImplemented def max_degree_nodes(self) -> dict: “”” Return the node(s) with the highest degree Return multiple nodes in the event of a tie Format is a dict where the key is the node_id and the value is an integer for the node degree e.g. {‘a’: 8} or {‘a’: 22, ‘b’: 22} “”” return NotImplemented def print_nodes(self): “”” No further implementation required May be used for de-bugging if necessary “”” print(self.nodes) def print_edges(self): “”” No further implementation required May be used for de-bugging if necessary “”” print(self.edges) # Do not modify def write_edges_file(self, path=”edges.csv”)->None: “”” write all edges out as .csv :param path: string :return: None “”” edges_path = path edges_file = open(edges_path, ‘w’, encoding=’utf-8′) edges_file.write(“source” + “,” + “target” + “\n”) for e in self.edges: edges_file.write(e[0] + “,” + e[1] + “\n”) edges_file.close() print(“finished writing edges to csv”) # Do not modify def write_nodes_file(self, path=”nodes.csv”)->None: “”” write all nodes out as .csv :param path: string :return: None “”” nodes_path = path nodes_file = open(nodes_path, ‘w’, encoding=’utf-8′) nodes_file.write(“id,name” + “\n”) for n in self.nodes: nodes_file.write(n[0] + “,” + n[1] + “\n”) nodes_file.close() print(“finished writing nodes to csv”) class TMDBAPIUtils: # Do not modify def __init__(self, api_key:str): self.api_key=api_key def get_movie_cast(self, movie_id:str, limit:int=None, exclude_ids:list=None) -> list: “”” Get the movie cast for a given movie id, with optional parameters to exclude an cast member from being returned and/or to limit the number of returned cast members documentation url: https://developers.themoviedb.org/3/movies/get-movie-credits :param string movie_id: a numerical movie_id :param integer limit: maximum number of returned cast members by their ‘order’ attribute e.g., limit=5 will attempt to return the 5 cast members having ‘order’ attribute values between 0-4 If after excluding, there are fewer cast members than the specified limit, then return the remaining members (excluding the ones whose order values are outside the limit range). If cast members with ‘order’ attribute in the specified limit range have been excluded, do not include more cast members to reach the limit. If after excluding, the limit is not specified, then return all remaining cast members.” e.g., if limit=5 and the actor whose id corresponds to cast member with order=1 is to be excluded, return cast members with order values [0, 2, 3, 4], not [0, 2, 3, 4, 5] :param list exclude_ids: a list of ints containing ids (not cast_ids) of cast members that should be excluded from the returned result e.g., if exclude_ids are [353, 455] then exclude these from any result. :rtype: list return a list of dicts, one dict per cast member with the following structure: [{‘id’: 97909 # the id of the cast member ‘character’: ‘John Doe’ # the name of the character played ‘credit_id’: ’52fe4249c3a36847f8012927′ # id of the credit, …}, … ] Note that this is an example of the structure of the list and some of the fields returned by the API. The result of the API call will include many more fields for each cast member. Important: the exclude_ids processing should occur prior to limiting output. “”” return NotImplemented def get_movie_credits_for_person(self, person_id:str, vote_avg_threshold:float=None)->list: “”” Using the TMDb API, get the movie credits for a person serving in a cast role documentation url: https://developers.themoviedb.org/3/people/get-person-movie-credits :param string person_id: the id of a person :param vote_avg_threshold: optional parameter to return the movie credit if it is >= the specified threshold. e.g., if the vote_avg_threshold is 5.0, then only return credits with a vote_avg >= 5.0 :rtype: list return a list of dicts, one dict per movie credit with the following structure: [{‘id’: 97909 # the id of the movie credit ‘title’: ‘Long, Stock and Two Smoking Barrels’ # the title (not original title) of the credit ‘vote_avg’: 5.0 # the float value of the vote average value for the credit}, … ] “”” return NotImplemented ############################################################################################################################# # # BUILDING YOUR GRAPH # # Working with the API: See use of http.request: https://docs.python.org/3/library/http.client.html#examples # # Using TMDb’s API, build a co-actor network for the actor’s/actress’ highest rated movies # In this graph, each node represents an actor # An edge between any two nodes indicates that the two actors/actresses acted in a movie together # i.e., they share a movie credit. # e.g., An edge between Samuel L. Jackson and Robert Downey Jr. indicates that they have acted in one # or more movies together. # # For this assignment, we are interested in a co-actor network of highly rated movies; specifically, # we only want the top 3 co-actors in each movie credit of an actor having a vote average >= 8.0. # Build your co-actor graph on the actor ‘Laurence Fishburne’ w/ person_id 2975. # # You will need to add extra functions or code to accomplish this. We will not directly call or explicitly grade your # algorithm. We will instead measure the correctness of your output by evaluating the data in your argo-lite graph # snapshot. # # GRAPH SIZE # With each iteration of your graph build, the number of nodes and edges grows approximately at an exponential rate. # Our testing indicates growth approximately equal to e^2x. # Since the TMDB API is a live database, the number of nodes / edges in the final graph will vary slightly depending on when # you execute your graph building code. We take this into account by rebuilding the solution graph every few days and # updating the auto-grader. We establish a bound for lowest & highest encountered numbers of nodes and edges with a # margin of +/- 100 for nodes and +/- 150 for edges. e.g., The allowable range of nodes is set to: # # Min allowable nodes = min encountered nodes – 100 # Max allowable nodes = max allowable nodes + 100 # # e.g., if the minimum encountered nodes = 507 and the max encountered nodes = 526, then the min/max range is 407-626 # The same method is used to calculate the edges with the exception of using the aforementioned edge margin. # ———————————————————————————————————————- # BEGIN BUILD CO-ACTOR NETWORK # # INITIALIZE GRAPH # Initialize a Graph object with a single node representing Laurence Fishburne # # BEGIN BUILD BASE GRAPH: # Find all of Laurence Fishburne’s movie credits that have a vote average >= 8.0 # FOR each movie credit: # | get the movie cast members having an ‘order’ value between 0-2 (these are the co-actors) # | # | FOR each movie cast member: # | | using graph.add_node(), add the movie cast member as a node (keep track of all new nodes added to the graph) # | | using graph.add_edge(), add an edge between the Laurence Fishburne (actress) node # | | and each new node (co-actor/co-actress) # | END FOR # END FOR # END BUILD BASE GRAPH # # # BEGIN LOOP – DO 2 TIMES: # IF first iteration of loop: # | nodes = The nodes added in the BUILD BASE GRAPH (this excludes the original node of Laurence Fishburne!) # ELSE # | nodes = The nodes added in the previous iteration: # ENDIF # # FOR each node in nodes: # | get the movie credits for the actor that have a vote average >= 8.0 # | # | FOR each movie credit: # | | try to get the 3 movie cast members having an ‘order’ value between 0-2 # | | # | | FOR each movie cast member: # | | | IF the node doesn’t already exist: # | | | | add the node to the graph (track all new nodes added to the graph) # | | | ENDIF # | | | # | | | IF the edge does not exist: # | | | | add an edge between the node (actor) and the new node (co-actor/co-actress) # | | | ENDIF # | | END FOR # | END FOR # END FOR # END LOOP # # Your graph should not have any duplicate edges or nodes # Write out your finished graph as a nodes file and an edges file using: # graph.write_edges_file() # graph.write_nodes_file() # # END BUILD CO-ACTOR NETWORK # ———————————————————————————————————————- # Exception handling and best practices # – You should use the param ‘language=en-US’ in all API calls to avoid encoding issues when writing data to file. # – If the actor name has a comma char ‘,’ it should be removed to prevent extra columns from being inserted into the .csv file # – Some movie_credits may actually be collections and do not return cast data. Handle this situation by skipping these instances. # – While The TMDb API does not have a rate-limiting scheme in place, consider that making hundreds / thousands of calls # can occasionally result in timeout errors. If you continue to experience ‘ConnectionRefusedError : [Errno 61] Connection refused’, # – wait a while and then try again. It may be necessary to insert periodic sleeps when you are building your graph. def return_name()->str: “”” Return a string containing your GT Username e.g., gburdell3 Do not return your 9 digit GTId “”” return NotImplemented def return_argo_lite_snapshot()->str: “”” Return the shared URL of your published graph in Argo-Lite “”” return NotImplemented # You should modify __main__ as you see fit to build/test your graph using the TMDBAPIUtils & Graph classes. # Some boilerplate/sample code is provided for demonstration. We will not call __main__ during grading. if __name__ == “__main__”: graph = Graph() graph.add_node(id=’5064′, name=’Meryl Streep’) tmdb_api_utils = TMDBAPIUtils(api_key=’YOURKEY’) # call functions or place code here to build graph (graph building code not graded) # Suggestion: code should contain steps outlined above in BUILD CO-ACTOR NETWORK graph.write_edges_file() graph.write_nodes_file() # If you have already built & written out your graph, you could read in your nodes & edges files # to perform testing on your graph. # graph = Graph(with_edges_file=”edges.csv”, with_nodes_file=”nodes.csv”)

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!

Excel Worksheet

A Skills Approach: Excel 2016 Chapter 8: Exploring Advanced Data Analysis

1 | Page Challenge Yourself 8.4 Last Updated 4/9/18

Challenge Yourself 8.4 In this project, you will use scenarios and a scenario summary to analyze car purchasing options. The data for

this project were downloaded from: https://www.fueleconomy.gov/feg/download.shtml You will use custom

filtering to find the data you are interested in and copy it from this very large data set to another worksheet.

You will then use Advanced Filter, conditional formatting, sorting, and subtotals to further analyze this subset

of data. You will manipulate a PivotTable created from the main vehicle data set. Finally, you will use Solver

to solve a business problem to help you pay for your new car.

Skills needed to complete this project: • Creating What-If Analysis Scenarios

• Creating Scenario Summary Reports

• Creating a Custom Filter

• Using Advanced Filter

• Creating New Conditional Formatting Rules

• Sorting Data on Multiple Criteria

• Adding Subtotals

• Changing the Look of a PivotTable

• Filtering PivotTable Data

• Activating the Solver Add-Inn

• Using Solver

1. Open the start file EX2016-ChallengeYourself-8-4. The file will be renamed automatically to include

your name. Change the project file name if directed to do so by your instructor, and save it.

2. If the workbook opens in Protected View, click the Enable Editing button in the Message Bar at the

top of the workbook so you can modify the workbook.

3. You want to purchase a new car. Your current car is worth $3,500 as a trade-in. The base sticker price on

the car you want is $24,595. The first financing offer from the dealer is 1.9% APR for 24 months, with

no cash back. The original financing offer terms are listed in cells A3:B9 on the Car Loan worksheet. Cell

B10 contains a formula with a PMT function to calculate the monthly payment. Use what-if analysis tools

to compare financing options. Create scenarios to compare financing options for the car loan.

a. Create names for the following cells on the Car Loan worksheet to make the scenarios easier to

follow:

Name cell B3: Price

Name cell B4: TradeIn

Name cell B5: CashBack

Name cell B6: Loan

Name cell B8: Months

Name cell B9: APR

Name cell B10: Payment

Name cell B12: TotalCost

Step 1

Download start file

 

 

A Skills Approach: Excel 2016 Chapter 8: Exploring Advanced Data Analysis

2 | Page Challenge Yourself 8.4 Last Updated 4/9/18

b. Create a scenario named Original Financing to save the original values in cells B3, B5, B8,

and B9.

c. Create a second scenario named Intermediate Car. Change the values as follows:

Cell B3: 33999

Cell B5: 1500

Cell B8: 36

Cell B9: 2.4%

d. Show the Intermediate Car scenario to verify your data entry.

e. Create a third scenario named Luxury Car. Change the values as follows:

Cell B3: 62700

Cell B5: 2500

Cell B8: 60

Cell B9: 3.9%

f. Show the Luxury Car scenario to verify your data entry.

4. Create a scenario summary report to compare the results for cells B10 (the monthly payment) and B12

(the total cost of the car including interest).

5. The data in the MPG Data worksheet were downloaded from the Web site

https://www.fueleconomy.gov/feg/download.shtml. The greenhouse gas scores range from 0 to 10,

where 10 is best. The vehicles with the best scores on both air pollution and greenhouse gas receive the

SmartWay designation. Use custom filtering to find cars in this data set that meet your criteria and then

copy the smaller data set to another worksheet where you can work with it further.

a. Go to the MPG Data worksheet, and display the AutoFilter arrows for the data set.

b. Create a custom number filter to show only rows where the greenhouse gas score is greater than 8.

c. Create another custom number filter to show only rows where the highway MPG is greater than 35.

d. Create a custom text filter to show only rows where the Trans column contains the word auto.

e. Create a custom text filter to show only rows where the value in the Fuel column equals Electricity

or Gasoline.

f. At this point, the list of more than 2,000 cars should be filtered down to just 48 records.

g. Copy the filtered data to cell A1 in the My Car Data worksheet. Be sure to include the heading row,

but do not include the All Models title. Paste keeping the source column widths.

6. On the My Car Data worksheet, use Advanced Filter to copy a subset of data to another location on this

worksheet.

a. Copy cells A1:P1 and paste them below the data set in row 52.

b. In cell A51, type: Criteria

c. Apply the Accent 4 cell style to cell A51.

d. Set up the criteria in the row(s) below row 52. Find cars where the value in the Fuel column is

Gasoline and the value in the Hwy MPG column is greater than 35.

 

 

A Skills Approach: Excel 2016 Chapter 8: Exploring Advanced Data Analysis

3 | Page Challenge Yourself 8.4 Last Updated 4/9/18

e. In cell A55, type: Filtered Data

f. Apply the Accent 4 cell style to cell A55.

g. Autofit column A.

h. Use Advanced Filter to find the rows that meet the criteria and copy the filtered data to another

location beginning in cell A56.

i. Sixteen rows should have been copied from the main data set to cells A57:P72.

7. Format the filtered data set (cells A56:P72) as a table. Use White, Table Style Light 1, or Table Style

Light 1. Be careful not to include row 55 in the table data range.

8. Insert a new column to the left of the Greenhouse Gas Score column. Hint: Be sure to add a column to

the worksheet, not just the table.

a. Copy the values from cells M57:M72 to N57:N72.

b. Type this column label in cell N56: Cmb MPG Icon

9. Apply a new custom conditional formatting rule to cells N57:N72 to show the 4 Ratings icon set. Show

the icon only.

10. Continue working with the filtered data that has the conditional formatting applied. Sort the table first

alphabetically by the values in the Model column and then by icon in the Cmb MPG Icon column so

the Signal Meter With Four Filled Bars icon appears at the top.

11. Go back to the main data set at the top of the My Car Data worksheet and add subtotals for each change

in Model to calculate the average for the following: Air Pollution Score, City MPG, Hwy MPG, and

Cmb MPG.

12. Collapse the data to show just the total rows.

13. Go to the MPG PivotTable worksheet. This sheet includes a PivotTable created from the data on the

MPG Data worksheet.

a. Refresh the PivotTable data.

b. Apply the White, Pivot Style Medium 1, or Pivot Style Medium 1 Quick Style to the PivotTable.

c. Display a slicer for the SmartWay field and show only data where the SmartWay value is Elite.

14. To pay for the new car, you’ve decided to start a bakery business out of your home kitchen. You have limited

capital and capacity, so you need to make wise decisions about which products to bake each day. Go to the

Bakery Business worksheet. Cell B1 uses a SUMPRODUCT formula to calculate profit. Carefully review the

assumptions and formulas in this worksheet before entering the following Solver parameters:

a. Find the maximum possible profit (cell B1) by changing the values in cells C7:C10.

b. The working hours required (B3) must be less than or equal to the number of working hours in

the day (D3).

c. The total cost of ingredients (B4) must be less than or equal to the available capital (D4).

 

 

A Skills Approach: Excel 2016 Chapter 8: Exploring Advanced Data Analysis

4 | Page Challenge Yourself 8.4 Last Updated 4/9/18

d. For each item in the range C7:C10, the number of items baked cannot exceed the maximum capacity

available per day as defined in cells F7:F10. This restriction requires four separate constraints in the

Solver Parameters dialog.

e. The items in the variable cell range C7:C10 must be whole numbers.

f. There should be a total of seven constraints.

g. Run Solver and accept the Solver solution.

15. Save and close the workbook.

16. Upload and save your project file

17. Submit project for grading.

Step 2

Upload & Save

Step 3

Grade my Project

 
Do you need a similar assignment done for you from scratch? Order now!
Use Discount Code "Newclient" for a 15% Discount!