Building Payments Recommendation System for Google Pay, RazorPay, NuBank, Chime, Revolut and PhonePe | Think Data in Fintech World - Part Two
When a gift is deserved, it is not a gift but a payment.

Building Payments Recommendation System for Google Pay, RazorPay, NuBank, Chime, Revolut and PhonePe | Think Data in Fintech World - Part Two

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:

  1. Power Users (Top 1 percentile of active user base)
  2. Middling / Second-Rate Users (Top 2 to 10 percentile)
  3. Laggards (passive users)

We strategies payee recommendation for Power users (in part 1), now let's continue for Middling and Laggards segment.

Start

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.

Argue
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
wait
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.

tea stall

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.

Reference: Enhancing Least Frequently Used Caches with Dynamic Aging

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.

Happy New Year

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.

Shaurya Uppal

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

回复
Chirantan Lonkar

Research @ISB | Data Scientist | Data Science Trainer | ML & Business Intelligence | Generative AI | AI Trainer - Corporate | Generative AI + Market Research

2 年

Amazing job

要查看或添加评论,请登录

社区洞察

其他会员也浏览了