Indico Data releases industry-first large language model benchmark for document understanding tasks
Learn More
  Everest Group IDP
             PEAK Matrix® 2022  
Indico Named as Major Contender and Star Performer in Everest Group's PEAK Matrix® for Intelligent Document Processing (IDP)
Access the Report


Inspiring Hack Projects: Jobalytics

June 17, 2018 | Developers, Hackathon Spotlight, Text Data Use Case

Back to Blog

A few weeks back, we had the pleasure of supporting EngHack 2018. We caught up with the first place winners of indico’s Machine Learning API prize — Jobalytics — with Charlie Lin speaking for the team.

What is Jobalytics?

Jobalytics home
Jobalytics is a machine learning powered resume analytics tool designed to help you crack the resume screening and land the interview for your dream job. Using two server-side languages and making use of various indico machine learning APIs, Jobalytics takes a PDF resume as input from the user and provides a complete array of features to help you decide how to shape your resume into a stellar work of art. Some of our features include:

    • Job Match – Using an inputted job posting URL, we determine how effectively your resume matches a job posting, including keywords, responsibilities, and skills.
    • What Works and What Doesn’t – We provide specific comments regarding the strengths and weaknesses in your resume found in relation to a job posting.
    • Frequent Words – We detect the most common words in your resume, so you can determine if you are effectively stating your skills or being repetitious.
  • Personality Radials Classification – Based on your resume, we draw a radial chart that explains your Myers-Briggs personality type, determine your individual role in the team and how best you function with others.

What inspired you to build Jobalytics?

“Recruiters take just 6 seconds looking at your resume.”
As college freshmen on the internship job market, we realized that though many people spend countless hours preparing for interview content, they fail to perfect their resume, barring them from showcasing their hard work. We ourselves were victims of this, which led to difficulties during our first summer recruiting season. Seeking out advice was counterintuitive: the ideas were often conflicting, and not customized based on the specific skills we had in relation to the job requirements. Worsening the problem, it proved difficult to get feedback after a rejection—the rise of the Internet has led to a growing mountain of resumes that recruiters have to deal with. Furthermore, the advent of ATS (Applicant Tracking Systems) as a method of further screening has compounded the growing pressure that students have. Not only has it become necessary for us to best our peers, but now we must beat machines as well.

We wanted to make a project that could address both problems in an intelligent and user-friendly manner—providing advice for resumes tailored for a particular job, and beating machine using machine. We carefully selected the features that would be most useful, deciding not only to provide generic pros and cons but job- and personality-specific feedback for individual cases, empowering students to build the perfect job application.

How did you build it?

We built this project using Node.JS as our server side language and Express.JS as our framework. We used python-shell to connect the endpoints of indico’s API directly within Node, while using a body-parser library to scrape both the resume and job sites. The front-end design was inspired by the layout, interactivity and look of Google’s CardView template, seen in products such as Google Keep.

We also incorporated Wolfram One’s cloud computation platform; very useful in visualizing the outputs of indico’s algorithms. It was incredibly helpful to use indico’s APIs as we wouldn’t have been able to produce the same results training our own algorithms in the short span of a 24-hour hackathon.

Furthermore, indico’s variety of built-in algorithms and flexibility enabled us to stress test the variance/bias and add layers to a test neural network in Jupyter Notebook, tailoring the algorithms to our needs.

How did Jobalytics evolve throughout the hackathon?

As previously mentioned, we came into the hackathon knowing we wanted to do something to help students succeed in the competitive job market. Our team had a solid understanding of machine learning but we were always worried that we wouldn’t be able to implement and train our own algorithms under the 24-hour timeframe. Luckily, we discovered indico and decided that we would make a job match analyzer after doing some research on the rise of ATS. We made some difficult decisions about what features to implement but quickly laid out a prototype. It was difficult to incorporate the Python code we used for our algorithms within the Node server side framework but we pushed through and made sure all the routes worked. We then implemented Wolfram One for better visualizations as we saw the potential for the raw number output to be confusing for the average user. Halfway through, we decided on a card view layout, which also greatly differentiated the features.

Jobalytics Card layout

Are there any other machine learning features you’d like to add?

We would like to use indico’s Sentiment Analysis to provide further feedback on the language used in a resume, and potentially cover letters. Some companies, especially startups, have a laid back mood that is evident even in the online job descriptions, while others have a traditional, formal process. This feature could help identify the match and “culture fit” of a potential candidate.

The Facial Emotion Recognition libraries could also be potentially implemented in a “mock interview” where users speak into the screen, answering generic interview questions. An algorithm would analyze features that employers value, such as eagerness, and aggregate a score.

Finally, we want to improve our current algorithms by feature engineering and providing our student expertise on the outputs of the current implementation, using indico’s Custom Collection API. These modified values can then be retrained into a neural network, therefore increasing the accuracy of our results.

What are your plans for its future?

On the front end, we want to refactor our code using React.JS components to streamline rendering and fully implement the card view functionality once we add user accounts. Backend-wise, we want to explore the npm library and see what new handy libraries we can incorporate. We are in the midst of implementing MongoDB so users can improve their resume each time they log in and track their progress against specific job postings. We would also like to implement JWT for account invitations to form peer groups based on similar job interests so users can receive anonymous review sessions while looking at other resumes for further inspiration. This feature will not be a public forum and will allow only invited users to view one’s resume, guaranteeing privacy. With a large number of unexplored indico functions still remaining, we are looking forward to building more features.

Check out other projects from EngHack 2018 or find more inspiration in our gallery!


Increase intake capacity. Drive top line revenue growth.


Get started with Indico

1-1 Demo



Gain insights from experts in automation, data, machine learning, and digital transformation.

Unstructured Unlocked

Enterprise leaders discuss how to unlock value from unstructured data.

YouTube Channel

Check out our YouTube channel to see clips from our podcast and more.
Subscribe to our blog

Get our best content on intelligent automation sent to your inbox weekly!