Skip to content

Latest commit

 

History

History
85 lines (58 loc) · 2.91 KB

Readme.md

File metadata and controls

85 lines (58 loc) · 2.91 KB

Intro

Given different versions of a company name from bank tranactions, etc this normalizes their names. Also handles unknown names, by having a job run every 1 hour to automatically scrape relevant data from the internet by using unfound names from a postgres database (that the queries are saved to in that 1 hour) and adding relevant new vectors to the VectorDB. Tech used was fastapi, Qdrant (also tried pinecone), postgres, Docker, Pytorch, cicd pipelines to create an API endpoint, and automate processess around it.

You may still be able to test it as given in the instructions below, if not then I have probably taken it down due to other constraints, try local :)

How to test API endpoint

Pass you alternative company name to http://44.203.139.218:8888/pm/{unnormalized_company_name}

ex - http://44.203.139.218:8888/pm/deepmind

It should return something like

{
  "query": "deepmind",
  "output": "{'normalized company name': 'Google', 'eucledian distance': 0.24236941, 'vector_text': 'DeepMind'}"
}

Troubleshooting:

Check if the service is up at http://44.203.139.218:8888/. It should return hello world followed by a random integer everytime.

How to run Locally

Pre-setup

  1. create a .env file and copy the following enviroment variables into it.

    OPENAI_API_KEY = "xxx"
    QDRANT_API_KEY = "xxx"
    QDRANT_CLOUD = "xxx.cloud.qdrant.io"
    
  2. create a folder postgresdata in the main working directory

How to (actually) run it locally:

  1. To spin up all things simply type make deploy in your terminal. (Docker needed)

    (Optional - to see logs run make logs)

  2. Visit http://0.0.0.0:8888 and test endpoints.

    1. The api endpoint for normalizing merchant names is http://0.0.0.0:8888/pm/{alternative_merchant_name}. This will return the closest normalized company name, along with other details.
  3. To stop make all_down

Testing

  1. To test run tests.py. If no exceptions arise, everything is working.

    p.s. Didnt get time to write better tests. TODO.

Misc

  1. I've added vectors for 20 merchants right now. Here is the list. (2476 vectors in DB)

    ["Google", "Facebook", "Adobe", "Amazon", "Apple", "Microsoft", "Tesla", "Netflix", "Uber", "Airbnb", "Twitter", "Intel", "IBM", "Cisco", "Oracle", "Samsung", "Sony", "Disney", "Nike", "McDonald's"]

Output samples

{"query":"msft","output":"{'normalized company name': 'Microsoft Corporation', 'eucledian distance': 0.21803427, 'vector_text': 'MSFT'}"}

{"query":"amazon","output":"{'normalized company name': 'Amazon.com', 'eucledian distance': 0.24691217, 'vector_text': 'Amazon'}"}

{"query":"amzn","output":"{'normalized company name': 'Amazon.com', 'eucledian distance': 0.3204673, 'vector_text': 'AMzon'}"}

{"query":"sony","output":"{'normalized company name': 'Sony Corporation', 'eucledian distance': 0.2994943, 'vector_text': 'Sonys'}"}