Compare commits
	
		
			3 Commits
		
	
	
		
			a2e924418a
			...
			embedded
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 70b6c810cf | ||
|  | 5cde32c99f | ||
|  | 8af1d2ff70 | 
							
								
								
									
										231
									
								
								Daniel Chen.typ
									
									
									
									
									
								
							
							
						
						
									
										231
									
								
								Daniel Chen.typ
									
									
									
									
									
								
							| @@ -27,105 +27,75 @@ | ||||
|  | ||||
| // MAIN CONTENT STARTS here | ||||
|  | ||||
| = Education | ||||
|  | ||||
| #indent[ | ||||
|   #work_entry( | ||||
|     "University of Waterloo", | ||||
|     "B.A.Sc. in Computer Engineering", | ||||
|     start_date: "Sep 2022", | ||||
|     end_date: "Apr 2027", | ||||
|     location: "Waterloo, ON", | ||||
|     tasks: ( | ||||
|       [Courses: OOP, data structures & algorithms, digital logic & circuits, embedded | ||||
|         microprocessors], | ||||
|       // [Extracurriculars: Creative Writing Club, Hack the North, UW Orbital Design Team], | ||||
|     ), | ||||
|   ) | ||||
| ] | ||||
|  | ||||
| = Skills | ||||
|  | ||||
| #indent[ | ||||
|   *Languages:* Python, TypeScript, JavaScript, SQL, Rust, C++, Java, HTML, CSS \ | ||||
|   // Dart, Ruby | ||||
|   *Frameworks:* React, Node.js, Vue, Flutter, Spring Boot, Next.js, Express, | ||||
|   Prisma, Axum \ | ||||
|   *Languages:* Python, C/C++, VHDL, Verilog, MATLAB, Rust, Java, SQL, JavaScript, | ||||
|   HTML, CSS \ | ||||
|   // Qt, Jest / Pytest, Apollo, Prisma, Rails | ||||
|   *Tools:* Linux, Git, Docker, PostgreSQL, AWS/GCP, Redis, Kubernetes, Terraform, | ||||
|   GraphQL, nginx // Jenkins, systemd, Jira | ||||
| ] | ||||
|  | ||||
| = Experience | ||||
|  | ||||
| #indent[ | ||||
|   // #work_entry( | ||||
|   //   "Technical Volunteer", | ||||
|   //   "Organization for Transformative Works", | ||||
|   //   start_date: "Feb 2024", | ||||
|   //   end_date: "present", | ||||
|   //   location: "Remote", | ||||
|   //   tools: "Python, Ruby on Rails, React, MySQL", | ||||
|   //   tasks: ( | ||||
|   //     [Upgrading archive import pipelines to migrate 4000+ user works to be accessible | ||||
|   //       to *7 million registered users*], | ||||
|   //   ), | ||||
|   // ) | ||||
|  | ||||
|   #work_entry( | ||||
|     "Software Developer Intern", | ||||
|     "Immigr8", | ||||
|     start_date: "Jan 2024", | ||||
|     end_date: "Apr 2024", | ||||
|     location: "Remote", | ||||
|     tools: "Next.js, Spring Boot, PostgreSQL, AWS, Terraform", | ||||
|     tasks: ( | ||||
|       // [Improved client responsiveness by *80* by employing stale-while-revalidate hooks for caching and ?? SWR performance, caching, error handling], | ||||
|       [Reduced manual user inputs by *40%* by extracting data from users' uploaded | ||||
|         documents in S3 with Textract], | ||||
|       [Planned and executed a roadmap to SOC 2 security compliance by *implementing | ||||
|         role-based permissions with JWTs*, sending backend logs and alerts to | ||||
|         CloudWatch, and introducing new privacy controls for user data], | ||||
|       [*Introduced CI/CD for AWS Lambdas* by codifying them in Terraform for | ||||
|         reproducible and automatic deployments], | ||||
|       [Set up a staging environment via *EC2 and Jenkins* with parallel builds to | ||||
|         *reduce production errors by 90%*], | ||||
|     ), | ||||
|   ) | ||||
|  | ||||
|   #work_entry( | ||||
|     "Software Engineering Intern", | ||||
|     "Dropbase", | ||||
|     start_date: "May 2023", | ||||
|     end_date: "Aug 2023", | ||||
|     location: "Remote", | ||||
|     tools: "React, Python, PostgreSQL, AWS", | ||||
|     tasks: ( | ||||
|       [Owned and launched a HubSpot/Airtable to Google Sheets sync feature to *46000+ | ||||
|         enterprise users* by writing AWS Lambda functions in Python, abstracting | ||||
|         interfaces to easily support future sources], | ||||
|       [Wrote and deployed a new *React* data query builder for our business | ||||
|         intelligence visualisation service to *33000+ users*, eliminating the need for | ||||
|         clients to manually write API calls or Python code], | ||||
|       [Designed a conflict resolution algorithm for merging databases, *reducing | ||||
|         unrecoverable errors by 75%*], | ||||
|       [Developed a *serverless microservice* that asynchronously ingests email | ||||
|         attachments directly into ETL pipelines], | ||||
|       // [??? emphasise test driven development or remove line *Reduced request errors by 30%* by creating backend testing infrastructure with | ||||
|       //   *Pytest* to catch regressions and test new features across database engines with | ||||
|       //   *90% code coverage*], | ||||
|     ), | ||||
|   ) | ||||
|  | ||||
|   #work_entry( | ||||
|     "Backend Lead", | ||||
|     "Hack the North", | ||||
|     start_date: "Mar 2023", | ||||
|     end_date: "present", | ||||
|     location: "Waterloo, ON", | ||||
|     tools: "Express, Redis, GraphQL, Docker, Kubernetes", | ||||
|     tasks: ( | ||||
|       [Shipped a new *bus registration tool* for attendees by creating new database | ||||
|         tables and GraphQL resolvers], | ||||
|       [Created a real-time event statistics dashboard by implementing GraphQL | ||||
|         *subscriptions with Redis PubSub*], | ||||
|       [Diagnosed and *recovered from load spike crashes* by debouncing queries, using | ||||
|         rate limiting as a stopgap], | ||||
|       [Reduced event check-in times by *80%* for *1900+ attendees* by generating | ||||
|         digital wallet passes over Express], | ||||
|       [*Led and mentored a team of 6* to ideate, scope, and deliver features for | ||||
|         *Canada's largest hackathon*], | ||||
|     ), | ||||
|   ) | ||||
|   *Tools:* Linux, Git, PostgreSQL, Qt, STM32, Quartus Prime, Valgrind, GDB | ||||
| ] | ||||
|  | ||||
| = Projects | ||||
| #set strong(delta: SMALL_STRONG) | ||||
|  | ||||
| #indent[ | ||||
|   #project("FPGA Diagnostic Tool", "C, Verilog, Tcl") | ||||
|   - Assembled various IP cores in Quartus and Verilog to create a diagnostic tool | ||||
|     for an FPGA board with Tcl scripts | ||||
|   - Developed a C program to communicate with the FPGA over UART and display | ||||
|     diagnostic information | ||||
|  | ||||
|   #project("PNG Validator", "C") | ||||
|   - Created a PNG file validator to find common errors and corruption by checking | ||||
|     metadata and computing CRCs | ||||
|   // memory safety w/Valgrind | ||||
|   - Ran tests behind Valgrind to ensure memory safety, prevent memory leaks, and | ||||
|     maintain accuracy | ||||
|  | ||||
|   #project( | ||||
|     "Box Box Revolution", | ||||
|     "Rust, STM32", | ||||
|     repo_link: "https://github.com/potatoeggy/boxboxrevolution", | ||||
|   ) | ||||
|   - Created a rhythm game to detect punches with an ultrasonic sensor in time with | ||||
|     notes of popular songs | ||||
|   - Developed firmware to measure from an ultrasonic sensor, tone a buzzer, and show | ||||
|     scrolling notes on an LCD | ||||
|  | ||||
|   #project("Climate Controller", "ARM Assembly, VHDL") | ||||
|   - Programmed an FPGA to heat/cool a theoretical room to a target temperature given | ||||
|     switch-controlled inputs | ||||
|   - Added conditions such as avoiding changes if windows are open, vacation mode, | ||||
|     and realistic heating curves | ||||
|  | ||||
|   // #project( | ||||
|   //   "Kobo Sync Server", | ||||
|   //   "Rust, Axum", | ||||
|   //   repo_link: "https://github.com/potatoeggy/kobink", | ||||
|   // ) | ||||
|   // - *Reimplemented the Kobo Store Sync protocol* in an Axum backend to instead sync | ||||
|   //   personal ebook files | ||||
|   // - Deployed the service behind an nginx reverse proxy and Cloudflare DNS to allow | ||||
|   //   syncing over the internet | ||||
|  | ||||
|   #project( | ||||
|     "Mandown Comic Downloader", | ||||
|     "Python, Qt", | ||||
| @@ -138,16 +108,6 @@ | ||||
|   - Implemented *image caching and multithreading* to increase download and update | ||||
|     speeds by *300%* | ||||
|  | ||||
|   #project( | ||||
|     "Kobo Sync Server", | ||||
|     "Rust, Axum", | ||||
|     repo_link: "https://github.com/potatoeggy/kobink", | ||||
|   ) | ||||
|   - *Reimplemented the Kobo Store Sync protocol* in an Axum backend to instead sync | ||||
|     personal ebook files | ||||
|   - Deployed the service behind an nginx reverse proxy and Cloudflare DNS to allow | ||||
|     syncing over the internet | ||||
|  | ||||
|   // #project( | ||||
|   //   "Genshin Rewards Simulator", | ||||
|   //   "Vue, TypeScript", | ||||
| @@ -159,17 +119,6 @@ | ||||
|   // - Reduced action latency by *90%* by lazily loading art assets at opportune times, | ||||
|   //   such as during cutscenes | ||||
|  | ||||
|   #project( | ||||
|     "Jeopardy!", | ||||
|     "Vue, TypeScript, WebSockets", | ||||
|     repo_link: "https://github.com/potatoeggy/jeopardy", | ||||
|     demo_link: "https://jeopardy.eggworld.me/host", | ||||
|   ) | ||||
|   - Created a beautiful and polished remote game where participants buzz in on their | ||||
|     devices over WebSockets | ||||
|   - Synchronised game state between clients and the host with shared TypeScript | ||||
|     types and the observer pattern | ||||
|  | ||||
|   // #project( | ||||
|   //   "RecipeReady", | ||||
|   //   "https://github.com/vincentjguo/recipeready-server", | ||||
| @@ -197,21 +146,65 @@ | ||||
|   //   with *SDL2* and *Vulkan* | ||||
|   // - WebGPU and WASM for portability, typestate to guarantee everything is always | ||||
|   //   valid | ||||
|  | ||||
| ] | ||||
|  | ||||
| = Education | ||||
| = Experience | ||||
|  | ||||
| #indent[ | ||||
|   #work_entry( | ||||
|     "University of Waterloo", | ||||
|     "B.A.Sc. in Computer Engineering", | ||||
|     start_date: "Sep 2022", | ||||
|     end_date: "Apr 2027", | ||||
|     location: "Waterloo, ON", | ||||
|     "Software Developer Intern", | ||||
|     "Immigr8", | ||||
|     start_date: "Jan 2024", | ||||
|     end_date: "Apr 2024", | ||||
|     location: "Remote", | ||||
|     tools: "Next.js, Spring Boot, PostgreSQL, AWS, Terraform", | ||||
|     tasks: ( | ||||
|       [Courses: Object-oriented programming, data structures & algorithms, digital | ||||
|         logic & circuits], | ||||
|       // [Extracurriculars: Creative Writing Club, Hack the North, UW Orbital Design Team], | ||||
|       // [Improved client responsiveness by *80* by employing stale-while-revalidate hooks for caching and ?? SWR performance, caching, error handling], | ||||
|       [Planned and executed a roadmap to SOC 2 security compliance by *implementing | ||||
|         role-based permissions with JWTs*, sending backend logs and alerts to | ||||
|         CloudWatch, and introducing new privacy controls for user data], | ||||
|       [*Introduced CI/CD for AWS Lambdas* by codifying them in Terraform for | ||||
|         reproducible and automatic deployments], | ||||
|       [Set up a staging environment via *EC2 and Jenkins* with parallel builds to | ||||
|         *reduce production errors by 90%*], | ||||
|     ), | ||||
|   ) | ||||
|  | ||||
|   #work_entry( | ||||
|     "Software Engineering Intern", | ||||
|     "Dropbase", | ||||
|     start_date: "May 2023", | ||||
|     end_date: "Aug 2023", | ||||
|     location: "Remote", | ||||
|     tools: "React, Python, PostgreSQL, AWS", | ||||
|     tasks: ( | ||||
|       [Owned and launched a HubSpot/Airtable to Google Sheets sync feature to *46000+ | ||||
|         enterprise users* by writing AWS Lambda functions in Python, abstracting | ||||
|         interfaces to easily support future sources], | ||||
|       [Wrote and deployed a new *React* data query builder for our business | ||||
|         intelligence visualisation service to *33000+ users*, eliminating the need for | ||||
|         clients to manually write API calls or Python code], | ||||
|       // [??? emphasise test driven development or remove line *Reduced request errors by 30%* by creating backend testing infrastructure with | ||||
|       //   *Pytest* to catch regressions and test new features across database engines with | ||||
|       //   *90% code coverage*], | ||||
|     ), | ||||
|   ) | ||||
|  | ||||
|   #work_entry( | ||||
|     "Backend Lead", | ||||
|     "Hack the North", | ||||
|     start_date: "Mar 2023", | ||||
|     end_date: "present", | ||||
|     location: "Waterloo, ON", | ||||
|     tools: "Express, Redis, GraphQL, Docker, Kubernetes", | ||||
|     tasks: ( | ||||
|       [Shipped a new *bus registration tool* for attendees by creating new database | ||||
|         tables and GraphQL resolvers], | ||||
|       [Diagnosed and *recovered from load spike crashes* by debouncing queries, using | ||||
|         rate limiting as a stopgap], | ||||
|       [Reduced event check-in times by *80%* for *1900+ attendees* by generating | ||||
|         digital wallet passes over Express], | ||||
|     ), | ||||
|   ) | ||||
| ] | ||||
		Reference in New Issue
	
	Block a user