/Fruitify

Fruitify is a charming fruit recognition project that harnesses the power of TensorFlow, an advanced machine learning framework.

Primary LanguagePythonCreative Commons Zero v1.0 UniversalCC0-1.0

Fruitify

Fruitify is a simple fruit recognition project implemented in Python using the TensorFlow framework and Keras library. It allows you to predict the type of fruit present in an image. CodeFactor Hits moz

sib ghermez

Translate:

#Apple (red) : sib (ghermez) #Apple (yellow) : sib (zard) #Banana : moz #Apricot : zardaloo #Avocado : Avocado #Tangerine : narengi #Dates : khorma #Kiwi : kiwi #Lemon : limoo #Mulberry : toot #Peach fig : hooloo anjiri #pear : golabi #Orange : porteghal #Pineapple : ananas #tomato : goje

Setup

To run this project, you need to follow these steps:

  1. Install the required dependencies by running the following command: pip install tensorflow keras pillow

  2. Download the trained model file (mive-doost-dari?.h5) and class labels file (labels.txt) to the same directory as your Python script.

  3. Replace the placeholder image path ("moz.png") in the code with the path to your fruit photo that you want to classify.

  4. Execute the Python script to see the predictions.

Usage

After setting up the project, you can use the following code snippet to classify a fruit image:

from keras.models import load_model
from PIL import Image, ImageOps
import numpy as np

# Load the pre-trained model
model = load_model("mive-doost-dari?.h5", compile=True)

# Read the class names from the labels file
class_names = open("labels.txt", "r").readlines()

# Prepare the input image
data = np.ndarray(shape=(1, 224, 224, 3), dtype=np.float32)
image = Image.open("moz.png").convert("RGB")  # Replace "moz.png" with your fruit photo address
size = (224, 224)
image = ImageOps.fit(image, size, Image.Resampling.LANCZOS)
image_array = np.asarray(image)
normalized_image_array = (image_array.astype(np.float32) / 127.5) - 1
data[0] = normalized_image_array

# Perform the prediction
prediction = model.predict(data)
top_indices = np.argsort(-prediction[0])[:3]

# Print the top predictions
print("Top Predictions:")
for i in top_indices:
 class_name = class_names[i]
 confidence_score = prediction[0][i]
 print("Class:", class_name[2:], "Confidence Score:", confidence_score)

Make sure to replace "moz.png" with the actual path to your fruit photo.

Training Details

The dataset for this project has been pre-trained using the following configurations:

  • Epochs: 100
  • Batch Size: 32
  • Learning Rate: 0.001 I utilized the provided code below to train my model.
import tensorflow as tf
from tensorflow.keras.preprocessing.image import ImageDataGenerator

image_directory = '/path/to/images'
labels_file = '/path/to/labels.txt'

with open(labels_file, 'r') as f:
    labels = f.read().splitlines()

datagen = ImageDataGenerator(
    rescale=1.0 / 255.0,
    rotation_range=20,
    width_shift_range=0.1,
    height_shift_range=0.1,
    shear_range=0.2,
    zoom_range=0.2,
    horizontal_flip=True,
    validation_split=0.2  
)

train_generator = datagen.flow_from_directory(
    image_directory,
    target_size=(224, 224),  
    batch_size=32,
    class_mode='categorical',
    subset='training'
)

val_generator = datagen.flow_from_directory(
    image_directory,
    target_size=(224, 224),
    batch_size=32,
    class_mode='categorical',
    subset='validation'
)

model = tf.keras.models.Sequential([
    tf.keras.applications.MobileNetV2(input_shape=(224, 224, 3), include_top=False, weights='imagenet'),
    tf.keras.layers.GlobalAveragePooling2D(),
    tf.keras.layers.Dense(len(labels), activation='softmax')
])

optimizer = tf.keras.optimizers.Adam(learning_rate=0.001)
model.compile(optimizer=optimizer, loss='categorical_crossentropy', metrics=['accuracy'])

model.fit(
    train_generator,
    steps_per_epoch=train_generator.samples // train_generator.batch_size,
    validation_data=val_generator,
    validation_steps=val_generator.samples // val_generator.batch_size,
    epochs=100
)

model.save('mive-doost-dari?.h5')
with open('labels.txt', 'w') as f:
    f.write('\n'.join(labels))

These parameters were used during the training process to optimize the model's performance in recognizing various fruit types. The dataset used for training in this project consists of 9,478 photos. For the training of the dataset, approximately half of the photos were sourced from open data and publicly available datasets. The remaining photos were captured and collected specifically for this project, ensuring a diverse and comprehensive collection of fruit images. Additionally, new photos were created from the existing images to further augment the dataset and enhance the training process. conf-matrix