The deep learning fashion recommendation project is a web-based application that utilizes machine learning techniques to recommend fashion items to users. The project is built using the Python programming language and the Dash framework, which is based on Flask and Bootstrap.
The project allows users to search for fashion items in a database by providing various types of input, including multiple images, a CSV file containing image URLs, or text search. Users also have the option to filter the results by specifying the database to search in, the category of the product, the brand, and the image matching confidence level.
Once the user submits their input, the project sends the data to an API which processes the information and returns a JSON data containing all the results and their corresponding information. The results are displayed in a card format, with each card displaying the original image and similar results. If there are more results in the same card, the user can slide through them. The results are also divided into pages for the user's convenience, allowing them to navigate through the results using the next and previous buttons.
Each result image has two buttons, "correct" and "wrong", which allow the user to provide feedback on the matching accuracy. Once the user clicks on any of the buttons, the feedback is stored in a dataframe. After submitting feedback for all the results, the dataframe can be downloaded as a CSV file.
Overall, the project's goal is to make it easier for users to discover new fashion items that match their preferences, by providing them with a convenient and user-friendly interface. It can be used by multiple users at the same time, and it does not require any sign-up or login process.
The following packages are required for running the deep learning fashion recommendation project:
- datetime - (for working with dates and times)
- dash - (for building the front-end interface of the project)
- dash_bootstrap_components - (for adding Bootstrap components to the Dash interface)
- base64 - (for encoding and decoding binary data to and from base64 format)
- os - (for interacting with the operating system)
- pandas - (for working with dataframes)
- io - (for working with input/output operations)
- uuid - (for generating unique identifiers)
- api - and helper (local files that contain additional functions or methods used in the project)
- pickle - (for serializing and deserializing Python objects)
- math - (for mathematical operations)
- ast - (for converting string representation of lists to actual lists)
- warnings - (for handling warnings)
- requests - (for sending HTTP requests)
- json - (for working with JSON data)
- operator - (for comparing values)
Note: For more details on package versions, please check the requirements.txt file. It's important to make sure that the versions of the packages installed are compatible with the versions used in development, to avoid any conflicts.
- .idea
- assets/ - assets used in app
- dropdown_df/ - drop down menu list dfs
- input_file/ - files uploaded by users
- outputs/ - output result file
- data.csv - input csv data, for every users it will get changed as per input
- delete.svg - delete button icon image
- kb.png - title icon image
- .gitignore - gitignore file
- LICENSE - Licence file
- README.md - documentation
- api.py - send and receive data from api
- app.py - main app file
- helper.py - additional methods and fucntions
- requirements.txt - packages used in app
- resul3.json - sample result json
- result.json - sample result json
- store_user_data.csv - input data storage file
- Go to the Home Page
- Select the Search Type (default is File Search)
- Image Search: Allows selection of single or multiple images with validation applied
- File Search: Allows selection of a single CSV file with validation applied
- Catalog Search: Allows searching from an internal database with filtering based on options
- Select the Database Type
- Catalog: Searches from an internal database of their own products
- Scraped: Searches from data scraped from other ecommerce websites
- Select the Sub-Database (applicable only for Scraped database type) using multiple checkboxes
- Select the Category and Brand (optional) for additional filtering (only avaible for single sub-database)
- Set the Matching Threshold Value as a percentage (default is 80%) to determine the confidence score of the results.
- Click on the Search button to initiate the search and display the results
- Click on the Clear button to clear the page
- Click on the Delete button to delete the last feedback record (if an incorrect button was pressed by mistake and can be used immediately after the mistake)
- Click on the Download button to download the feedback data as a CSV file.