September 12, 2017 – 1st working anniversary
What I gain in a year
- Working with like-minded people. Talking to them is so easy nowadays because we share the same vocabulary.
- A company that really invests into their employees. I am still amazed that my employer purchased that many subscriptions of Frontend Master for the dev team. I cannot speak for my colleagues but they are very useful to me.
- Pick up ES6. I did not know what fat arrow () => ‘hello world’ meant when I first started there. Now, I am applying ES6 features in project with relative ease.
- Understand the concept of JS from expert. Watching Frontend Masters courses after work is a valuable personal investment. Now, I am more confident in JS coding and make less mistakes on the job.
- Able to structure component-based AngularJS project. The concept of component-based architecture in AngularJS is solidified in my brain after watching Frontend Masters course
- Exposure to two Amazon APIs. AWS Cognito API to implement authentication and account management for our in-house system. AWS API gateway to expose restful endpoints of our in-house system.
- Exposure to two Google APIs: Google Place API and Google Calendar API.
- Good practice of Sass, Flexbox and CSS. I watched tutorials on Sass and FlexBox and tried to fix CSS bugs on my own. My CSS is still terrible but my colleagues come to rescue from time to time
CSS and efficiency are two main problems in my opinion. I can tackle the tasks assigned to me eventually but I always take a bit more time than my colleagues. Getting the job done is not enough, using appropriate design pattern and data structure to solve it in reasonable amount time is more important to the team and the entire company.
I am a long way to go but I am getting there.
Poly U Msc of Computing – IT 2015-2016 Year Semester 2 completed on 2016-04-22
1) COMP5151 – Advanced Database System:
Final Grade: A
- Calculation of access cost of hash join, merge join, nested loop join, block nested join
- Equivalence Rule to transform a relational algebra tree to another relational algebra tree to produce better cost
- Dynamic programming to find the best execution plan
- Database Concurrency, Deadlock, Precedence Graph, Wait-Die and Wound-Wait, Timestamp Ordering, Optimistic Concurrency Control
- Database Recovery (Checkpoint – Undo and Redo)
- Distributed Computing, Semi Join
- Spatial Computing, R-tree, R-tree search query, R-tree intersection
- Multimedia Index Computing, Two-step processing, Multi-step processing
- Database Hardware, CUDA, GPL, SSD
- Assignment 1 – 100/100
- Assignment 2 – 100/100
- Midterm – 82/100
- Individual Project – Studied two research papers on OLTP Database Partitioning Tools: Horiculture and JECB and wrote a paper to show what I actually learnt. Grade: 95/100
- Paper was consisted of Introduction, Problem Statement, Description on the concepts of the tools, Analysis and Comparison, and finally Conclusion.
- To show my understanding of both papers, I created my own example of database schema, stored procedures, foreign key constraints and workload trace and applied it throughout all the sections of the paper
- Horiculture used branch and bound algorithm to prune the size of search space to find the partition solution that yield the lowest cost. A partition solution may consist of horizontal partitioning of replicated table(s), read-only table(s), secondary index(es) and stored procedure routing parameter(s).
- JECB used foreign key relationships to join tables by columns to form join paths and join trees. Then, the joined columns became the partition attributes of the tables. Compatible join attributes were merged and the finer one was used to construct join paths and join trees respectively. To avoid the explosion of search space, compatible join paths and join trees were merged to reduce the number of partition solutions that were constructed. A partition solution was composed of a join tree and and an independent function. An optimal solution was a partition solution where the independent function returned the lowest distributed cost.
1) Complete Year 1 semester 2 and 3, and Year 2 Semester 1 despite heavy course work load
2) Attend my second Hong Kong Open Source Conference held at HKSTP
3) Attend inaugural PyCon HK 2015 Day 1 and 2 held at Cyberport
4) Join events organized by Open Source Hong Kong, Codeaholics, Open Innovation Lab and Hong Kong Node JS respectively
5) Continuously to learn MEAN stack. Firebase and open source tools (Grunt, Gulp, Bower, Yeoman)
7) Good health
8) Build a toy project that tracks down my event attendance; something that actually benefits me.
9) Met a PolyU classmate who shares the passion of web technology and accept my invitation to attend meetup.
10) Completed my only MOOC course in Udacity, Web tools and automation.
Goals next year :
1) Graduate next year
2) Go on my first vacation in three years
3) Read about HTML5 and CSS3 and practice Angular 1.x/2
4) Attend HKOSC 2016 (?), PyCon HK 2016 (?) and definitely TW JS Conf 2016 (Buy ticket early)
5) Try to speak clearly and communicate effectively with family, friends and colleagues
6) Enrol and finish at least 1 MOOC course. Udacity has many free courses that aim at web developers and Android developers.
Poly U Msc of Computing – IT 2014-2015 Semester 1 completed on 2014-12-20
1) COMP5324 – Internet Information Retrieval:
Final Grade: A
- Quiz A – 19/22
- Quiz B
- Group Project – Build a search engine to query relevant documents
- Languages: Shell scripting, Java and C++
- Apache Common Math Library
- Implemented Retrieval Models:
- Vector Space Model
- Boolean Retrieval Model
- LSI for Vector Space Model
2) COMP5325 – Distributed Computing:
Final Grade: B+
- Assignment 1
- Assignment 2
- Project – Build a tool to characterize YouTube Video Streaming Platform
- Java 7, Maven 3, Apache Command CLI Library
- -v: video id
- -d: enable download mode
- -p: full path
- -f: filename
- -e: extension (mpf, flv, 3gpp, etc)
- -r: resolution (360p, 144p, 720p, 1440p)
- -x: proxy list
Finish reading Beginning Node.JS
Like the title indicates, this publication targets beginning coders who are in search of the first language to develop server applications.
After reading 12 out of 13 chapters, I am still unable to develop a web application using Node.js as backend.
Conclusion: Go look for second text to learn to develop back-end using Node.js
Poly U Msc of Computing – IT 2014-2015 Semester 3
1) COMP5121 – Data Mining and Data Warehousing Applications: A
- In-Class Exercises
- Written Assignment/Quiz
- Group Project
- Classify whether a person will invest in term deposit in a bank
- Data source: data set of bank customers from a Portugal bank.
Poly U Msc of Computing – IT 2014-2015 Semester 2 completed on 2015-05-08
Results released on 2015-05-18
1) COMP5527 – Mobile Data Management: A
- Midterm – 72/100
- Individual Study Report – Mobile Crowsourcing (No grade)
- Group Project – MiniBlog (No grade)
- Written in Android and Spring Boot
- Create new user account
- Create, Delete, Edit and View online and offline posts
- Create, Delete, Edit and View online and offline comments
- Edit and View user profile in online or offline mode
- Search other users by name in online or offline mode
- View posts created by other users
- Open source libraries used:
- Butterknife for Android UI dependency injection
- Roboletric for Android Unit Testing
- Spring DBUnit for DBUnit Testing
- Sprint Boot
- Embedded Tomcat 8 to host Spring Boot application
2) COMP5323 – Web Database:
- Assignment 1 – 104/100
- Midterm – 29/50 (Already the highest mark)
- Group Project – Study paper “Cloud Service Placement”
- Solve dynamic subgraph matching problem using Gradin framework
- PowerPoint Presentation
- Group report summarizes the paper, its weakness and potential improvements, and answer 5 questions.
Poly U Msc of Computing – IT 2014-2015 Semester 1 completed on 2014-12-20
1) COMP5111 – Database Management:
- Midterm – 14.5/15
- Individual Study Report – JSON and XML Support in relational database – 9/10
- Group Project – Simple Course Enrollment System – 30/30
- Written in PHP, JQuery and Bootstrap backed by MySQL 5.5
- Change student password
- Show Academic history of logged in student
- Course Enrollment
- Drop Course
2) COMP5122 – E-Commerce fundamental and development:
- Assignment 2 – B+
- Assignment 2 – B+
- Project – E-Commerce website that sells luxury goods imported from Japan – B
- Spring MVC, Spring Security, Spring JDBC, JSP, JSTL, JQuery, Bootstrap 3 backed by MySQL 5.5
- Customer Login
- Register customer
- Shopping Cart
- Checkout Shopping Cart
- Search Products
- Browse Products
- Order Tracking
- View Customer Profile
- Edit Customer Profile
1) Programming Cloud Services for Android Handheld Systems: Verified Certificated issued with final grade 99.5. Verified Certificate
2) Usable Security: Watched week 3 video lectures and submitted Week 3 quiz.
3) Mining Massive Datasets: Enrolled into the course late. I have downloaded week 1 and 2 videos but too busy with Poly U homework projects to begin watching them.
4) COMP5111 – Database Management:
- Set up structure of PHP project
- Implement student login and logout functionality
- Implement change password function to fulfill update requirement
- Add skeleton PHP code to return dummy student history and render the results student page using JQuery Ajax call
5) COMP5122 – E-Commerce fundamental and development:
- Use Maven 3 to create a Spring MVC project
- Deploy the project to tomcat 6 server in Poly U and it can run successfully
6) Order Mama Demo in collaboration with Roger Tang
- Can retrieve Facebook posts and show them in endless list adapter
- Can display number of likes and comment count for a specific post
- Can retrieve Facebook comments and show them in endless list adapter
1) Programming Cloud Services for Android Handheld Systems: Submitted Quiz 6 and Assignment 2 in the past Sunday. The new assignment looked challenging at first after reading the README file and going through the source codes. Fortunately, code examples provided oAuth2 package that could directly use in the Gradle project. Furthermore, no effort to write CRUD methods to retrieve records from database because Spring Framework’s CRUDRespository class generates them automatically. My solution was create a Spring Controller to expose methods to receive HTTP requests from users. Then, the requests were delegated to CRUDRespository subclass to retrieve data and return it to users. Very simple!!!!
2) Start my third AngularJS project that adds photo albums to store pictures taken in Open source Workshops and local meetup groups. This time, the project is bootstrap by Yeoman and Gulp because Matthew told me Gulp is better build system than Grunt. After using angular-gulp-generator to generate the skeleton project, I have to agree with his assessment.