Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added Readme & Input Pipe Line & Data PreProcessing #84

Closed
wants to merge 20 commits into from
Closed
Show file tree
Hide file tree
Changes from 13 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
19 changes: 19 additions & 0 deletions ReadME.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# Health Learning: ML and Deep Learning for Healthcare 🩺🧠

Health Learning is an open-source project aimed at leveraging machine learning (ML) and deep learning techniques to address various healthcare challenges. By harnessing the power of data-driven approaches, our goal is to develop predictive models, diagnostic tools, and decision support systems to improve patient outcomes, optimize healthcare delivery, and advance medical research.

## Motivation 🚀

The field of healthcare is ripe for innovation, with vast amounts of data available from diverse sources such as electronic health records, medical imaging, wearable devices, and genetic sequencing. Health Learning seeks to harness this wealth of data to tackle a wide range of healthcare issues, including disease prediction, diagnosis, treatment optimization, and personalized medicine. By democratizing access to healthcare data and cutting-edge machine learning algorithms, we aim to empower researchers, clinicians, and healthcare professionals to make data-driven decisions and drive innovation in healthcare.

## Datasets 📊

Health Learning provides access to a curated collection of healthcare datasets sourced from various sources, including public repositories like Kaggle. These datasets cover a broad spectrum of health-related topics, including maternal health, diabetes classification, cardiovascular disease risk factors, stroke prediction, cancer imaging, and more. Researchers and developers can explore these datasets to develop and validate machine learning models for a wide range of healthcare applications. Individual projects have their datasets mentioned in respective README.md files.

## Contributing 🤝

Health Learning welcomes contributions from researchers, developers, healthcare professionals, and enthusiasts passionate about using machine learning and deep learning for healthcare. Whether you're interested in developing new models, improving existing algorithms, or curating datasets, there are plenty of opportunities to get involved. Check out our [Contribution Guidelines](CONTRIBUTING.md) to learn how you can contribute to the project.

---

**Note**: Health Learning is a community-driven initiative and is not affiliated with any specific healthcare organization or institution. We strive to promote collaboration, transparency, and open exchange of knowledge for the betterment of healthcare worldwide. Join us in our mission to revolutionize healthcare through machine learning and deep learning! 🌍💡
1 change: 1 addition & 0 deletions data-2/Input_Pipeline_PreProcessing.ipynb
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{"metadata":{"kaggle":{"accelerator":"nvidiaTeslaT4","dataSources":[{"sourceId":7547567,"sourceType":"datasetVersion","datasetId":4395695},{"sourceId":6100,"sourceType":"modelInstanceVersion","modelInstanceId":4643}],"dockerImageVersionId":30646,"isInternetEnabled":false,"language":"python","sourceType":"notebook","isGpuEnabled":true},"kernelspec":{"display_name":"Python 3","language":"python","name":"python3"},"language_info":{"codemirror_mode":{"name":"ipython","version":3},"file_extension":".py","mimetype":"text/x-python","name":"python","nbconvert_exporter":"python","pygments_lexer":"ipython3","version":"3.10.13"},"papermill":{"default_parameters":{},"duration":2123.85405,"end_time":"2024-02-04T00:06:48.395698","environment_variables":{},"exception":true,"input_path":"__notebook__.ipynb","output_path":"__notebook__.ipynb","parameters":{},"start_time":"2024-02-03T23:31:24.541648","version":"2.5.0"}},"nbformat_minor":4,"nbformat":4,"cells":[{"cell_type":"code","source":"# Importing dependencies\n\nimport os\nimport pandas as pd\nimport numpy as np\nimport matplotlib.pyplot as plt\nimport cv2\nfrom tqdm.notebook import tqdm\n\nimport tensorflow as tf\nfrom tensorflow.keras import *\nfrom tensorflow.keras.optimizers import AdamW\nfrom tensorflow.keras.callbacks import *\nimport keras_cv\n\n\nBATCH_SIZE = 16\nAUTO = tf.data.AUTOTUNE","metadata":{"_kg_hide-output":true,"papermill":{"duration":19.027459,"end_time":"2024-02-03T23:31:46.273022","exception":false,"start_time":"2024-02-03T23:31:27.245563","status":"completed"},"tags":[],"trusted":true},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":"# <span style=\"color:#e74c3c;\"> </span> Preprocessing","metadata":{"papermill":{"duration":0.005875,"end_time":"2024-02-03T23:31:46.285376","exception":false,"start_time":"2024-02-03T23:31:46.279501","status":"completed"},"tags":[]}},{"cell_type":"code","source":"# a function for converting txt file to list\ndef parse_txt_annot(img_path, txt_path):\n img = cv2.imread(img_path)\n w = int(img.shape[0])\n h = int(img.shape[1])\n\n file_label = open(txt_path, \"r\")\n lines = file_label.read().split('\\n')\n \n boxes = []\n classes = []\n \n if lines[0] == '':\n return img_path, classes, boxes\n else:\n for i in range(0, int(len(lines))):\n objbud=lines[i].split(' ')\n class_ = int(objbud[0])\n \n x1 = float(objbud[1])\n y1 = float(objbud[2])\n w1 = float(objbud[3])\n h1 = float(objbud[4])\n \n xmin = int((x1*w) - (w1*w)/2.0)\n ymin = int((y1*h) - (h1*h)/2.0)\n xmax = int((x1*w) + (w1*w)/2.0)\n ymax = int((y1*h) + (h1*h)/2.0)\n \n boxes.append([xmin ,ymin ,xmax ,ymax])\n classes.append(class_)\n \n return img_path, classes, boxes\n\n\n# a function for creating file paths list \ndef create_paths_list(path):\n full_path = []\n images = sorted(os.listdir(path))\n \n for i in images:\n full_path.append(os.path.join(path, i))\n \n return full_path\n\n\nclass_ids = ['Acne']\nclass_mapping = {0: 'Acne'}","metadata":{"papermill":{"duration":0.019684,"end_time":"2024-02-03T23:31:46.311103","exception":false,"start_time":"2024-02-03T23:31:46.291419","status":"completed"},"tags":[],"trusted":true},"execution_count":null,"outputs":[]},{"cell_type":"code","source":"# a function for creating a dict format of files\ndef creating_files(img_files_paths, annot_files_paths):\n \n img_files = create_paths_list(img_files_paths)\n annot_files = create_paths_list(annot_files_paths)\n \n image_paths = []\n bbox = []\n classes = []\n \n for i in range(0,len(img_files)):\n image_path_, classes_, bbox_ = parse_txt_annot(img_files[i], annot_files[i])\n image_paths.append(image_path_)\n bbox.append(bbox_)\n classes.append(classes_)\n \n image_paths = tf.ragged.constant(image_paths)\n bbox = tf.ragged.constant(bbox)\n classes = tf.ragged.constant(classes)\n \n return image_paths, classes, bbox","metadata":{"papermill":{"duration":0.015092,"end_time":"2024-02-03T23:31:46.332136","exception":false,"start_time":"2024-02-03T23:31:46.317044","status":"completed"},"tags":[],"trusted":true},"execution_count":null,"outputs":[]},{"cell_type":"code","source":"# applying functions\ntrain_img_paths, train_classes, train_bboxes = creating_files('/kaggle/input/acne-dataset-in-yolov8-format/data-2/train/images', \n '/kaggle/input/acne-dataset-in-yolov8-format/data-2/train/labels')\n\nvalid_img_paths, valid_classes, valid_bboxes = creating_files('/kaggle/input/acne-dataset-in-yolov8-format/data-2/valid/images',\n '/kaggle/input/acne-dataset-in-yolov8-format/data-2/valid/labels')\n\ntest_img_paths, test_classes, test_bboxes = creating_files('/kaggle/input/acne-dataset-in-yolov8-format/data-2/test/images',\n '/kaggle/input/acne-dataset-in-yolov8-format/data-2/test/labels')","metadata":{"papermill":{"duration":13.457229,"end_time":"2024-02-03T23:31:59.795419","exception":false,"start_time":"2024-02-03T23:31:46.33819","status":"completed"},"tags":[],"trusted":true},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":"# <span style=\"color:#e74c3c;\"> Creating </span> Datasets","metadata":{"papermill":{"duration":0.005826,"end_time":"2024-02-03T23:31:59.80766","exception":false,"start_time":"2024-02-03T23:31:59.801834","status":"completed"},"tags":[]}},{"cell_type":"code","source":"# reading and resizing images\ndef img_preprocessing(img_path):\n img = tf.io.read_file(img_path)\n img = tf.image.decode_jpeg(img, channels = 3)\n img = tf.cast(img, tf.float32) \n \n return img\n\n\nresizing = keras_cv.layers.JitteredResize(\n target_size=(640, 640),\n scale_factor=(0.8, 1.25),\n bounding_box_format=\"xyxy\")\n\n# loading dataset\ndef load_ds(img_paths, classes, bbox):\n img = img_preprocessing(img_paths)\n\n bounding_boxes = {\n \"classes\": tf.cast(classes, dtype=tf.float32),\n \"boxes\": bbox }\n \n return {\"images\": img, \"bounding_boxes\": bounding_boxes}\n\ndef dict_to_tuple(inputs):\n return inputs[\"images\"], inputs[\"bounding_boxes\"]","metadata":{"papermill":{"duration":0.037818,"end_time":"2024-02-03T23:31:59.851375","exception":false,"start_time":"2024-02-03T23:31:59.813557","status":"completed"},"tags":[],"trusted":true},"execution_count":null,"outputs":[]},{"cell_type":"code","source":"# Creating dataset loaders and tf.datasets\ntrain_loader = tf.data.Dataset.from_tensor_slices((train_img_paths, train_classes, train_bboxes))\ntrain_dataset = (train_loader\n .map(load_ds, num_parallel_calls = AUTO)\n .shuffle(BATCH_SIZE*10)\n .ragged_batch(BATCH_SIZE, drop_remainder = True)\n .map(resizing, num_parallel_calls = AUTO)\n .map(dict_to_tuple, num_parallel_calls = AUTO)\n .prefetch(AUTO))\n\n\nvalid_loader = tf.data.Dataset.from_tensor_slices((valid_img_paths, valid_classes, valid_bboxes))\nvalid_dataset = (valid_loader\n .map(load_ds, num_parallel_calls = AUTO)\n .ragged_batch(BATCH_SIZE, drop_remainder = True)\n .map(resizing, num_parallel_calls = AUTO)\n .map(dict_to_tuple, num_parallel_calls = AUTO)\n .prefetch(AUTO))\n\n\ntest_loader = tf.data.Dataset.from_tensor_slices((test_img_paths, test_classes, test_bboxes))\ntest_dataset = (test_loader\n .map(load_ds, num_parallel_calls = AUTO)\n .ragged_batch(BATCH_SIZE, drop_remainder = True)\n .map(resizing, num_parallel_calls = AUTO)\n .map(dict_to_tuple, num_parallel_calls = AUTO)\n .prefetch(AUTO))","metadata":{"papermill":{"duration":8.623777,"end_time":"2024-02-03T23:32:08.481113","exception":false,"start_time":"2024-02-03T23:31:59.857336","status":"completed"},"tags":[],"trusted":true},"execution_count":null,"outputs":[]},{"cell_type":"code","source":"# a function to visualize samples from a dataset\n\ndef visualize_dataset(inputs, value_range, rows, cols, bounding_box_format):\n inputs = next(iter(inputs.take(1)))\n images, bounding_boxes = inputs[0], inputs[1]\n \n keras_cv.visualization.plot_bounding_box_gallery(\n images,\n value_range=value_range,\n rows=rows,\n cols=cols,\n y_true=bounding_boxes,\n scale = 6,\n font_scale = 0.8,\n line_thickness=2,\n dpi = 100,\n bounding_box_format=bounding_box_format,\n class_mapping=class_mapping,\n true_color = (192, 57, 43))","metadata":{"papermill":{"duration":0.014839,"end_time":"2024-02-03T23:32:08.503229","exception":false,"start_time":"2024-02-03T23:32:08.48839","status":"completed"},"tags":[],"trusted":true},"execution_count":null,"outputs":[]}]}
40 changes: 40 additions & 0 deletions data-2/ReadME.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
### Acne Prediction using Deep Learning

#### Overview:
This project aims to predict the likelihood of developing acne using deep learning techniques. Acne is a common skin condition that affects millions of people worldwide, and early detection can aid in preventive measures and timely treatment.

#### Dataset:
The dataset used for training and testing consists of images of facial skin affected by acne, labeled with corresponding acne severity levels. Additionally, demographic and lifestyle factors such as age, gender, diet, skincare routine, and environmental conditions may also be incorporated into the dataset for more accurate predictions.

- **Training Dataset:** This subset of the dataset is used to train the deep learning model. It comprises a large number of labeled images along with associated non-image features.

- **Validation Dataset:** This dataset is used to fine-tune the model hyperparameters and evaluate its performance during training. It helps prevent overfitting by providing an independent set of data for validation.

- **Testing Dataset:** After training the model, it is evaluated on this dataset to assess its generalization performance. The testing dataset is not used during training or validation to ensure unbiased evaluation.

#### Model Architecture:
The deep learning model employed for acne prediction utilizes convolutional neural networks (CNNs) for image processing and feature extraction. The model may also include recurrent neural networks (RNNs) or fully connected layers to incorporate non-image features from the dataset. Transfer learning techniques can be applied using pre-trained models such as VGG, ResNet, or EfficientNet to enhance performance, especially with limited data availability.

#### Training Process:
The dataset is split into training, validation, and testing sets to train and evaluate the model. Data augmentation techniques such as rotation, scaling, and flipping may be applied to increase the diversity of training samples and improve the model's generalization. Hyperparameter tuning, including learning rate, batch size, and model architecture, is conducted to optimize performance.

#### Evaluation Metrics:
The performance of the model is evaluated using metrics such as accuracy, precision, recall, and F1 score. Additionally, receiver operating characteristic (ROC) curves and area under the curve (AUC) values may be utilized to assess the model's discriminatory power and performance across different threshold levels.

#### Deployment:
Once trained and evaluated, the model can be deployed as a web application, mobile application, or integrated into existing healthcare systems. Users can input relevant information such as age, gender, and upload facial images for real-time acne prediction. The application provides predictions along with confidence scores and recommendations for preventive measures and skincare routines based on predicted acne severity levels.

#### Future Enhancements:
- Incorporating additional data sources such as genetic predisposition, hormonal factors, and medical history to improve prediction accuracy.
- Developing a user-friendly interface with interactive features for personalized skincare recommendations and tracking acne progression over time.
- Integrating natural language processing (NLP) techniques for analyzing skincare product reviews and recommendations for acne-prone individuals.
- Collaborating with dermatologists and skincare experts to validate model predictions and ensure clinical relevance and accuracy.



#### Acknowledgments:
- Special thanks to [Kaggle](https://www.kaggle.com/) for providing the acne dataset.
- We acknowledge the contributions of the open-source deep learning community and pre-trained model developers.

#### License:
This project is licensed under the [License Name]. See the LICENSE file for details.
13 changes: 13 additions & 0 deletions data-2/data.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
train: ../train/images
val: ../valid/images
test: ../test/images

nc: 1
names: ['Acne']

roboflow:
workspace: osman-kagan-kurnaz
project: skin-detection-uvj1f
version: 8
license: CC BY 4.0
url: https://universe.roboflow.com/osman-kagan-kurnaz/skin-detection-uvj1f/dataset/8
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
0 0.6265625 0.6828125 0.06875 0.08125
0 0.64296875 0.7453125 0.04921875 0.0390625
0 0.6953125 0.4796875 0.05078125 0.03828125
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
0 0.10625 0.33828125 0.046875 0.09375
0 0.76171875 0.42578125 0.0421875 0.09453125
0 0.56015625 0.11875 0.03125 0.0609375
0 0.28203125 0.3421875 0.0453125 0.07734375
0 0.43203125 0.56328125 0.0328125 0.071875
0 0.5875 0.3609375 0.0296875 0.08125
0 0.8765625 0.37109375 0.028125 0.06875
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
0 0.07421875 0.24296875 0.08828125 0.10625
0 0.3 0.26015625 0.03828125 0.0515625
0 0.6078125 0.41796875 0.06484375 0.08828125
0 0.6625 0.15703125 0.05546875 0.08203125
0 0.70078125 0.03125 0.0359375 0.0625
0 0.82890625 0.040625 0.0375 0.06875
0 0.40078125 0.28984375 0.07265625 0.0921875
0 0.5046875 0.15703125 0.0734375 0.1296875
0 0.57734375 0.08984375 0.06875 0.09375
0 0.4640625 0.53359375 0.04296875 0.04921875
0 0.39921875 0.5359375 0.0453125 0.04921875
0 0.68515625 0.715625 0.05390625 0.06953125
0 0.66015625 0.30859375 0.0359375 0.05078125
0 0.91953125 0.10859375 0.0359375 0.06484375
0 0.9859375 0.13359375 0.02734375 0.08046875
0 0.3921875 0.1875 0.0546875 0.06484375
0 0.47578125 0.30390625 0.06328125 0.1125
0 0.05625 0.321875 0.05546875 0.07265625
0 0.09140625 0.42421875 0.03203125 0.05
0 0.4375 0.6 0.03359375 0.05234375
0 0.896875 0.6390625 0.03203125 0.1453125
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
0 0.103125 0.66875 0.04765625 0.0796875
0 0.1375 0.5984375 0.04921875 0.071875
0 0.190625 0.5390625 0.0625 0.10234375
0 0.24765625 0.346875 0.078125 0.08515625
0 0.58984375 0.39453125 0.06875 0.07421875
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
0 0.175 0.42734375 0.0578125 0.0765625
0 0.128125 0.53984375 0.0546875 0.08203125
0 0.32265625 0.54609375 0.03203125 0.0390625
0 0.27890625 0.68046875 0.053125 0.090625
0 0.365625 0.68515625 0.04609375 0.07109375
0 0.4296875 0.7 0.0625 0.059375
0 0.5109375 0.7421875 0.046875 0.06328125
0 0.64609375 0.59375 0.0515625 0.0640625
0 0.19765625 0.54453125 0.06640625 0.06875
0 0.2296875 0.46484375 0.03359375 0.04921875
0 0.4390625 0.55703125 0.0375 0.04453125
0 0.503125 0.8234375 0.034375 0.04453125
0 0.81484375 0.52109375 0.03203125 0.04765625
0 0.671875 0.415625 0.0421875 0.0640625
0 0.496875 0.55546875 0.0421875 0.046875
0 0.721875 0.57421875 0.06875 0.0921875
0 0.19375 0.63671875 0.10703125 0.09765625
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
0 0.15546875 0.26796875 0.0484375 0.0640625
0 0.19765625 0.6484375 0.03828125 0.05546875
0 0.27890625 0.675 0.034375 0.0609375
0 0.0703125 0.77265625 0.0359375 0.053125
0 0.52265625 0.73203125 0.05859375 0.09921875
0 0.5859375 0.9125 0.06484375 0.08828125
0 0.85859375 0.7078125 0.0546875 0.075
0 0.57890625 0.31484375 0.06171875 0.08125
0 0.1703125 0.36953125 0.05390625 0.09765625
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
0 0.46328125 0.58125 0.15390625 0.1125
0 0.621875 0.571875 0.09453125 0.08671875
0 0.85546875 0.409375 0.10078125 0.12578125
0 0.7828125 0.58046875 0.0765625 0.09609375
0 0.521875 0.43203125 0.10390625 0.11015625
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
0 0.11015625 0.2546875 0.0578125 0.07890625
0 0.08359375 0.52265625 0.05078125 0.1265625
0 0.19453125 0.7078125 0.05703125 0.14140625
0 0.275 0.42265625 0.03828125 0.08125
0 0.37421875 0.43046875 0.05234375 0.08125
0 0.35703125 0.74765625 0.0484375 0.078125
0 0.58671875 0.653125 0.05703125 0.0953125
0 0.8375 0.28046875 0.03515625 0.06328125
0 0.7546875 0.42890625 0.0640625 0.05625
0 0.77578125 0.60859375 0.03984375 0.0765625
0 0.82109375 0.7484375 0.053125 0.08671875
0 0.89296875 0.4953125 0.03203125 0.059375
0 0.8515625 0.50390625 0.03125 0.0578125
Loading