Welcome to the Data Engineering MTA Turnstile project! This repository leverages real-world MTA Turnstile data, offering a comprehensive guide to data engineering concepts through hands-on experience.
-
Extensive Book: Data Engineering Process Fundamentals. Dive deep into the core concepts of data engineering with this detailed guide.
-
YouTube Videos: Follow along with detailed video tutorials that explain each step and concept in detail.
-
Comprehensive Codebase: Our codebase features:
- Python: Core scripts and data processing.
- Jupyter Notebooks: Interactive data exploration and visualization.
- SQL: Database queries and transformations.
- Looker Studio: Advanced analytics and reporting.
- Cloud Data Lake: Efficient and scalable data storage.
- Data Warehouse: Structured data management.
- Other Cloud Technologies: Utilize various cloud-based tools to implement your solution step-by-step.
- Real-World Application: Based on actual MTA Turnstile data, providing a practical learning experience.
- Process-Oriented Approach: Implement data engineering using a systematic, process-oriented approach for better clarity and efficiency.
- Step-by-Step Implementation: Follow along with the book and videos to implement each component of the solution.
- Free and Accessible: Leverage cloud technologies that are freely available, ensuring you can recreate and extend the project without barriers.
Use this project Wiki for installation and configuration information
👉 Join this list to receive updates on new content about Data Engineering Sign up here
👉 Follow us on Twitter
👉 Data Engineering Process Fundamental Blog Series
👉 Data Engineering Process Fundamental YouTube Video Podcast
👉 Data Engineering Process Fundamental Book on Amazon
Data Engineering Process Fundamentals: Master the Fundamentals of Data Engineering with a Hands-on Approach
If you find this project useful, please consider giving it a ⭐️ on GitHub! Your support helps us grow and reach more developers.
Why Star This Project?
- Stay updated with the latest features and improvements.
- Show your support for open-source development.
- Help others discover a valuable resource for data engineering.
- Visit the Data Engineering MTA Turnstile GitHub Repository.
- Click on the "Star" button in the top-right corner.
Thank you for your support! 🌟
In the city of New York, commuters use the Metropolitan Transportation Authority (MTA) subway system for transportation. There are millions of people that use this system every day; therefore, businesses around the subway stations would like to be able to use Geofencing advertisement to target those commuters or possible consumers and attract them to their business locations at peak hours of the day.
Geofencing is a location based technology service in which mobile devices’ electronic signal is tracked as it enters or leaves a virtual boundary (geo-fence) on a geographical location. Businesses around those locations would like to use this technology to increase their sales.
The MTA subway system has stations around the city. All the stations are equipped with turnstiles or gates which tracks as each person enters or leaves the station. MTA provides this information in CSV files, which can be imported into a data warehouse to enable the analytical process to identify patterns that can enable these businesses to understand how to best target consumers.
We are using the MTA Turnstile data for 2023. Using this data, we can investigate the following criteria:
- Stations with the high number of exits by day and hours
- Stations with high number of entries by day and hours
Exits indicates that commuters are arriving to those locations. Entries indicate that commuters are departing from those locations.
The data can be grouped into stations, date and time of the day. This data is audited in blocks of fours hours apart. This means that there are intervals of 8am to 12pm as an example. We analyze the data into those time block intervals to help us identify the best times both in the morning and afternoon for each station location. This should allow businesses to target a particular geo-fence that is close to their business.
https://lookerstudio.google.com/reporting/94749e6b-2a1f-4b41-aff6-35c6c33f401e
By looking at the dashboard, the following conclusions can be observed:
- The stations with the highest distribution represent the busiest location
- The busiest time slot for both exits and entries is the hours between 4pm to 9pm
- All days of the week show a high volume of commuters
With these observations, plans can be made to optimize the marketing campaigns and target users around a geo-fence area and hours of the day with proximity to the corresponding business locations.
This project was executed following this process. The details for each of these steps can be found in this project subdirectories.
Note: Follow each link for more details
- Discovery
- Data analysis
- Define Scope of work
- Design and Infrastructure Planning
- Provision accounts
- Build Infrastructure
- Orchestration Implementation
- Code blocks for authorization of the code
- Data ingestion workflows
- Deployment and schedules
- Data Warehouse and Modeling
- Use the data lake as source
- Build the data models
- Build the Incremental models for continuous data ingestion
- Scheduled tasks
- Data Analysis and Visualization
- Identify the relevant dimensions and measures to report on
- Identify the filters
- Identify the visualizations for distributions and aggregated daily statistics
The following technologies have been used for this project:
- GitHub and Git
- Docker and Docker Hub
- Terraform
- Visual Studio Code
- Python language
- SQL
- Jupyter Notes
- Google Cloud
- VM, Storage, BigQuery
- Prefect Cloud (Workflow automation)
- dbt Cloud (Data modeling)