Skip to content
@PharmaML

Team 6 - PharmaAIOptimizer


Logo

PAPO

Pharmacy Procurement Optimizer

View Demo . Report Bug . Request Feature

PAPO.Video.Demo.mp4

Table of Contents

About The Project

Screenshot

What is PAPO?

The nature of the problem at hand revolves around the client's manual and time-consuming drug procurement processes, characterized by the need for constant evaluation of alternatives based on price, quantity, and packaging. Additionally, the criticality of specific drugs necessitates a precise and timely restocking strategy. Our final deliverable aims to address these challenges comprehensively through an AI-driven procurement solution.

This solution comprises a three-tiered technical approach: continuous stock monitoring and replenishment based on live feed analysis, intelligent recommendations for alternative drug replacements drawn from the pharmacy's database, and the development of a user-friendly interface based on client feedback. The proposed model offers innovative features such as dynamic stock monitoring, intelligent alternative recommendations prioritized by cost, dosage preference, and packaging, and a user-centric interface tailored to streamline the buyer's decision-making process. This solution is poised to significantly optimize the client's drug procurement workflow, ensuring efficiency, accuracy, and responsiveness to critical drug restocking requirements.

Built With

This project was built with the following technologies:

Front End:

Back End

Server Side

  • AWS
    • EC2
    • RDS
    • S3
    • Route53

Screenshot

Getting Started

This is an example of how you may give instructions on setting up your project locally. To get a local copy up and running follow these simple example steps.

Prerequisites

This project requires node.js & npm, react, next.js, python, and fastapi, to be installed in your system. If you don't have it installed, you can follow these steps:

For MacOS users: Use Homebrew

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"        

node.js & npm

  • Recommended Method: Using Homebrew (for MacOS users) | Others OS can download it from here.

  • Install Yarn globally using npm (Node Package Manager). Open your terminal and run:

    brew install node

    This command will install both Node.js and npm on your system.

  • Verify that Node and npm has been installed on your machine by running the following command in your terminal:

    node --version
    npm --version

    If has been installed correctly, your terminal should display the version of Node and npm installed on your machine.

react

next.js

python

  • Install python using homebrew:

    brew install python

fastapi

  • Open your terminal and run:

    pip install "fastapi[all]"

Installation

Please follow the following steps for successful installation:

  1. Clone the Repository: Get started by cloning the frontend and backend repositories to your local machine.

    git clone https://github.com/BU-EC463/frontend.git # [Front End Repository]
    git clone https://github.com/BU-EC463/API.git # [Back End Repository]
  2. Install Frontend Packages: Navigate to the "/frontend" directory and install the required npm packages by executing the following command in your terminal:

    cd frontend
    npm install
  3. Install Backend Packages: Similarly, navigate to the "/API" directory and install the required yarn packages by executing the following command in your terminal:

    cd API
    virtualenv venv
    source venv/bin/activate
    pip install -r requirements.txt
  4. Set Up Environment:

    • In the "API" repository, copy the content of ".env.example" file and create a new file named ".env". Adjust the environment variables according to your requirements or you can leave them as it is.

    • Navigate to "frontend/.env.example" and create a new file named ".env". In the new .env set the BASE parameter to your backend API route. For instance, if you are running backend on your local server at port 8080, you should set:

      BASE: "http://localhost:8080/api";
  5. Run the Backend: Navigate to "/backend" directory and type the following command in your terminal to run your backend server:

    uvicorn main:app --reload
  6. Run the Frontend: Finally, navigate to "/frontend" directory and type the following command in your terminal to run your frontend server:

    npm start

    The server should be running on http://localhost:3000/

    Now, your application should be successfully up and running!

Contributing

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

License

MIT License

Copyright (c) 2024 PAPO

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

Contact

If you have any questions or suggestions, feel free to reach out to us:

Raise an issue on the repository: GitHub Repository

Pinned Loading

  1. frontend frontend Public

    PAPO Front End

    JavaScript 1

  2. API API Public

    ML software to help pharmacies optimize their inventory and automate drug procurements

    Python 1

Repositories

Showing 7 of 7 repositories
  • frontend Public

    PAPO Front End

    PharmaML/frontend’s past year of commit activity
    JavaScript 1 MIT 0 0 0 Updated Dec 19, 2024
  • API Public

    ML software to help pharmacies optimize their inventory and automate drug procurements

    PharmaML/API’s past year of commit activity
    Python 1 MIT 0 0 0 Updated Dec 19, 2024
  • .github Public
    PharmaML/.github’s past year of commit activity
    0 0 0 0 Updated May 4, 2024
  • Cost-Analysis Public archive
    PharmaML/Cost-Analysis’s past year of commit activity
    Jupyter Notebook 0 MIT 0 0 0 Updated Apr 2, 2024
  • Package-Analysis Public archive
    PharmaML/Package-Analysis’s past year of commit activity
    Jupyter Notebook 0 MIT 0 0 0 Updated Mar 28, 2024
  • PharmaML/Drug-Similarity-Calculator’s past year of commit activity
    Jupyter Notebook 0 MIT 0 0 1 Updated Feb 18, 2024
  • Data-Analysis Public archive
    PharmaML/Data-Analysis’s past year of commit activity
    Jupyter Notebook 0 MIT 0 0 0 Updated Dec 3, 2023

Top languages

Loading…

Most used topics

Loading…