Building Payments Recommendation System for Google Pay, RazorPay, NuBank, Chime, Revolut and PhonePe | Think Data in Fintech World - Part Two
Shaurya Uppal
Data Scientist | MS CS, Georgia Tech | AI, Python, SQL, GenAI | Inventor of Ads Personalization RecSys Patent | Makro | InMobi (Glance) | 1mg | Fi
I am back with Part Two of my previous Newsletter Edition, continuing on how to build a recommendation system for payments. Do refer to Part One Link
Short Recap of Part One
In my previous newsletter, I discussed the objective of building a payments recommendation system i.e. Make the pay experience smoother and faster by helping users not inputting contact/payee manually. We further segmented our Google pay million user base into three segments:
We strategies payee recommendation for Power users (in part 1), now let's continue for Middling and Laggards segment.
Approach / Strategy
The payee recommendation is to make the payment experience smoother and faster by helping users not inputting contact/payee manually.
Think of this problem as a Page Replacement Caching problem where the objective is to maximize hit count; page fault or miss count happens when a payee is not in the People section or the user has to input the contact manually.?
The simplest way of achieving maximum hits to some extent is by the LRU algorithm (with sorting) that Gpay has adopted, there are 12 slots (4x3) in those rank Payee based on recency. The least recently used payee is pushed out of the People section and the recent payee is shown in the 1st slot position.
Let's Understand and Reason
Oftentimes LRU just makes the most sense. However, it's not hard to think of a workload where an LRU cache becomes polluted and LFU would be the more useful. LRU evicts objects not recently accessed and LFU evicts objects which are less popular in the long term.
Let's understand with an example: With LRU (the approach that Gpay has adopted), we may see a payee bubble/slot that we don't often transact with but with LFU we can have our regular payee arranged like newspaper-delivery payment, chai-walle bhaiya, tiffin service payment, landlord rent, etc.
For middling or second-rated user base LFU is better as they transact more on the App while for the Laggards user base same old LRU with the sorting approach will work best.
LRU: Priority to recency or age of interaction with payee
LFU: Priority to Frequency of interactions with payee
领英推荐
LFU Approach has a Flaw - doesnot solve our problem fully
Why LFU with Dynamic Aging?
So LFU is great for some workloads, but everything comes with tradeoffs and LFU is no different. LFU runs into problems when an object is so initially hyped, that it manages to make its way towards the top of the LFU list but is not as useful again. If this pattern is such that the hype is a one-time spurt, the cache has now become polluted; that is, the hyped object was useful for some period, but then not needed. The hyped object is now taking up room in the cache; a room that could be better used by some other item that is now more susceptible to being evicted even though it may be more useful over the longer term. This also poses a problem with any new items entering the cache; they’re subject to being evicted very soon since they start with a low counter.
Example: There was a chai stall near my office where I use to go daily (referring to the pre-pandemic era) that was my most frequently transacted payee (let's say 200 times transacted). Post-Pandemic, I haven't been to that stall but as per our LFU approach, it will still show in the Payee recommendation section which makes our payee slots polluted. Hence, we introduce LFU with dynamic aging which can handle this flaw with the introduction of the time+frequency factor.
Now the priority key of a payee under LFUDA:
Priority Key = Frequency + Cache Age
This will solve the issue of a previously very popular object that now becomes unpopular. Now through Dynamic Aging, the priority key of such payee is reduced relative to the rest of the payees eventually making it eligible for eviction.
To implement LFU refer to O(1) Algorithm implementation paper here .
Python Implementation of LFU with Dynamic Aging: Refer to this
Conclusion
For middling or second-rated user base, we shall implement Least Frequent Used with Dynamic Aging Algorithm and for Laggards user base we shall go with the current Gpay approach LRU with sorting. There is always so much more to it than we can cover but do spend some time racking your Brain on it..! Open to interesting approaches and ideas do comment.
Many readers must be thinking this is not a data science solution "No Fit and Predict". The core role of a data scientist is to solve the business objective, you become wise when you understand when a model is required or not.
Wishing everyone a very Happy New Year this is my first write of 2022, I hope you learned something new from this?post. If you liked it, do subscribe, hit ?? or ??, and share this with others. Stay tuned for the next one and a very Happy New Year everyone.
Connect, Follow or Endorse me on?LinkedIn ?if you found this read useful. To learn more about me visit:?Here
Disclaimer:?I don’t endorse any brand Google Pay, RazorPay, NuBank, Chime, Revolut, PhonePe, etc. names in the newsletter are used to make the article more relatable to the audience and know in which business this approach can be used. This approach can be used at any Fintech B2C company.
Data Scientist | MS CS, Georgia Tech | AI, Python, SQL, GenAI | Inventor of Ads Personalization RecSys Patent | Makro | InMobi (Glance) | 1mg | Fi
2 年Part 1 link: Building Payments Recommendation for Google Pay, Paytm, Razorpay, Gojek, Cred, PhonePe, Monzo, and NuBank | Think Data in Fintech World - Part 1 https://www.dhirubhai.net/pulse/building-payments-recommendation-google-pay-paytm-razorpay-uppal
Research @ISB | Data Scientist | Data Science Trainer | ML & Business Intelligence | Generative AI | AI Trainer - Corporate | Generative AI + Market Research
2 年Amazing job