Apache SINGA explained

Apache SINGA
Developer:Apache Software Foundation
Operating System:Linux, macOS, Windows
Programming Language:C++, Python
License:Apache License 2.0

Apache SINGA is an Apache top-level project for developing an open source machine learning library. It provides a flexible architecture for scalable distributed training, is extensible to run over a wide range of hardware, and has a focus on health-care applications.

Apache SINGA has won the 2024 SIGMOD Systems Award [1] for the development of a distributed, efficient, scalable, and easy-to-use deep learning platform for large scale data analytics.

History

The SINGA project was initiated by the DB System Group at National University of Singapore in 2014, in collaboration with the database group of Zhejiang University, in order to support complex analytics at scale, and make database systems more intelligent and autonomic.[2] It focused on distributed deep learning by partitioning the model and data onto nodes in a cluster and parallelize the training.[3] [4] The prototype was accepted by Apache Incubator in March 2015, and graduated as a top-level project in October 2019. The table below captures information about different types of versions, e.g., the latest version, the latest preview version, older versions which are still maintained, and old versions.

VersionOriginal release dateLatest versionRelease date
2024-09-074.3.02024-09-07
2024-03-154.2.02024-03-15
2023-11-054.1.02023-11-05
2023-04-074.0.02023-04-07
2022-06-073.3.02022-06-07
2021-08-153.2.02021-08-15
2020-10-303.1.02020-10-30
2020-04-203.0.02020-04-20
2019-04-202.0.02019-04-20
2018-06-061.2.02018-06-06
2017-02-121.1.02017-02-12
2016-09-081.0.02016-09-08
2016-04-200.1.02016-04-20
2016-01-140.2.02016-01-14
2015-10-080.1.02015-10-08

Software Stack

SINGA's software stack includes three major components, namely, core, IO and model. The following figure illustrates these components together with the hardware. The core component provides memory management and tensor operations; IO has classes for reading (and writing) data from (to) disk and network; The model component provides data structures and algorithms for machine learning models, e.g., layers for neural network models, optimizers/initializer/metric/loss for general machine learning models.

SINGA-Auto

SINGA-Auto (aka. Rafiki[5] in VLDB2018) is a subsystem of Apache SINGA to provide the training and inference service of machine learning models. SINGA-Auto frees users from constructing the machine learning models, tuning the hyper-parameters, and optimizing the prediction accuracy and speed. Users can simply upload their datasets, configure the service to conduct training, and then deploy the model for inference. As a cloud service system, SINGA-Auto manages the hardware resources, failure recovery, etc. For ease of use, it provides a model zoo, which is a set of built-in machine-learning models for popular tasks such as structured data (e.g., EMR data) analytics, image recognition, and text processing.

In the training service, a general framework for distributed hyper-parameter tuning is proposed and a collaborative tuning scheme is designed specifically for deep learning models.In the inference service, a scheduling algorithm is proposed based on reinforcement learning to optimize the overall accuracy and reduce latency. It can adapt to the changes of request rates.

SINGA-Easy

SINGA-Easy[6] (ACM Multimedia 2021) is an easy-to-use deep learning framework built as a component of Apache SINGA to facilitate the adoption of deep learning algorithms and inference services by domain-specific domain application users (e.g., multimedia, medical image analysis). It provides distributed hyper-parameter tuning at the training stage, dynamic computational cost control at the inference stage, and intuitive user interactions with multimedia content facilitated by model explanation. To improve accuracy, it supports regularization methods for image and structured data regularizations (ACM SIGMOD 2023). To support the acceptance of domain users on the training results, SINGA-Easy provides an option for users to evaluate model performance from the model explanation perspective based on LIME[7] and Grad-CAM.[8]

MLCask

MLCask[9] (IEEE ICDE 2021) is a pipeline management subsystem that manages machine learning pipelines, from data cleaning to data analytics, to ease the maintenance of evolving and versioning of machine learning pipelines for collaborative analytics. It serves to reduce the cost and facilitate adoption. MLCask supports a Git-like end-to-end ML life-cycle management. By leveraging the version history of pipeline components and workspace, MLCask can skip unchanged preprocessing steps to address the frequent retraining challenges. Its non-linear version control semantics and merge operation facilitate effective collaborative development of the pipeline.

In-Database Model Selection

Starting from version 4.1.0, Apache SINGA provides support for in-database model selection and inference in PostgreSQL. The system implements a resource-efficient two-phase model selection algorithm that incorporates both training-free and training-based model selection techniques. This model selection algorithm is integrated non-intrusively into PostgreSQL via stored procedures with optimizations on execution latency and memory consumption. The inclusion of in-database model selection empowers users to obtain high-performing models within their specified response time requirements.

Applications

Apache SINGA[10] is in use at organizations such as NetEase,[11] Carnegie Technologies, CBRE, Citigroup, JurongHealth Hospital, National University of Singapore, National University Hospital, Noblis, Shentilium Technologies, Singapore General Hospital, Tan Tock Seng Hospital, YZBigData, and others. Apache SINGA is used across applications in banking, education, finance, healthcare, real estate, software development, and other categories.

Apache SINGA and Social Good

The Ng Teng Fong General Hospital[12] collaborated with the Apache SINGA team to develop an application for people diagnosed with pre-diabetes, a condition where blood glucose levels are higher than normal, but not high enough to be classified as diabetes.

The application called JurongHealth Food Log (JHFoodLg) app, uses Apache SINGA to match photos of food to a database of local dishes - including nasi padang, laksa and char siew rice - and utilises nutrition data from the Health Promotion Board, JurongHealth Campus, and the Australian Food and Nutrient Database. After comprehensive data cleaning (e.g., consistent formatting, deduplication, foodness classification, human calibration), the database contains 209, 861 images, covering 13 food groups and 233 food categories.

The app allows users from the hospital's Lifestyle Intervention (Liven) programme to set weight loss and exercise goals. A six-month study shows that almost all 20 patients who used the app lost between 4 and 5 percent of their initial bodyweight.

See also

Notes and References

  1. Web site: SIGMOD Systems Award.
  2. Wei . Wang . Meihui . Zhang . Gang . Chen . H.V. . Jagadish . Beng Chin . Ooi . Kian-Lee . Tan . Database Meets Deep Learning: Challenges and Opportunities. . SIGMOD Record . June 2016 . 45 . 2 . 17–22 . 10.1145/3003665.3003669 . 1906.08986 . 6526411 .
  3. Book: Tan. Kian-Lee. Sheng. Wang. Wang. Wei. Cai. Qingchao. Chen. Gang. Gao. Jinyang. Luo. Zhaojing. Tung. Anthony K. H.. 2015 . http://www.comp.nus.edu.sg/~ooibc/singaopen-mm15.pdf . 10.1145/2733373.2807410. Ooi. Beng Chin. Wang. Yuan. Xie. Zhongle. Zhang. Meihui. Zheng. Kaiping. Proceedings of the 23rd ACM international conference on Multimedia . SINGA: A Distributed Deep Learning Platform . 685–688 . 1840240. 8 September 2016. free.
  4. Book: Chen. Gang. Anh Dinh. Tien Tuan. Gao. Jinyang. Ooi. Beng Chin. Tan. Kian-Lee. Sheng. Wang. 2015 . http://www.comp.nus.edu.sg/~ooibc/singa-mm15.pdf. 10.1145/2733373.2806232. Wei. Wang. Proceedings of the 23rd ACM international conference on Multimedia . SINGA: Putting Deep Learning in the Hands of Multimedia Users . 25–34 . 7169465. 8 September 2016.
  5. Wang. Wei. Gao. Jinyang. Zhang. Meihui. Sheng. Wang. Chen. Gang. Khim Ng. Teck. Ooi. Beng Chin. Shao. Jie. Reyad. Moaz . 2018. Rafiki: Machine Learning as an Analytics Service System. Proceedings of the VLDB Endowment. 12. 2. 128–140. 10.14778/3282495.3282499. 9 January 2019. 2018arXiv180406087W. 1804.06087. 4898729.
  6. Book: Xing. Naili. Yeung. Sai Ho. Cai. Chenghao. Ng. Teck Khim. Wang. Wei. Yang. Kaiyuan. Yang. Nan. Zhang. Meihui. Chen. Gang. Ooi. Beng Chin. 2021 . https://www.comp.nus.edu.sg/~ooibc/SINGAEasy.pdf. 10.1145/3474085.3475176. Proceedings of the 29th ACM international conference on Multimedia . SINGA-Easy: An Easy-to-Use Framework for MultiModal Analysis . 1293–1302 . 978-1-4503-8651-7 . 17 October 2021.
  7. Book: Ribeiro. Marco Tulio. Singh. Sameer. Guestrin. Carlos. Proceedings of the 22nd ACM SIGKDD international conference on knowledge discovery and data mining . "Why Should I Trust You?": Explaining the Predictions of Any Classifier . 2017 . 97–101 . https://www.kdd.org/kdd2016/papers/files/rfp0573-ribeiroA.pdf . 1 August 2016. 1602.04938 . 10.1145/2939672.2939778.
  8. Book: https://openaccess.thecvf.com/content_ICCV_2017/papers/Selvaraju_Grad-CAM_Visual_Explanations_ICCV_2017_paper.pdf. 10.1109/ICCV.2017.74. 1610.02391 . Grad-CAM: Visual Explanations from Deep Networks via Gradient-Based Localization . 2017 IEEE International Conference on Computer Vision (ICCV) . 2017 . Selvaraju . Ramprasaath R. . Cogswell . Michael . Das . Abhishek . Vedantam . Ramakrishna . Parikh . Devi . Batra . Dhruv . 618–626 . 978-1-5386-1032-9 .
  9. Book: Luo. Zhaojing. Yeung. Sai Ho. Zhang. Meihui. Zheng. Kaiping. Zhu. Lei. Chen. Gang. Fan. Feiyi. Lin. Qian. Ngiam. Kee Yuan. Ooi. Beng Chin. 2021 IEEE 37th International Conference on Data Engineering (ICDE) . MLCask: Efficient Management of Component Evolution in Collaborative Data Analytics Pipelines . 2021 . 1655–1666 . 2010.10246 . 10.1109/ICDE51399.2021.00146 . 978-1-7281-9184-3 . 224802796 .
  10. Web site: THE APACHE SOFTWARE FOUNDATION ANNOUNCES APACHE SINGA AS A TOP-LEVEL PROJECT. news.apache.org. 4 November 2019 . 4 November 2019.
  11. Web site: 网易携手Apache SINGA角逐人工智能新战场_网易科技. 网易. tech.163.com. 2 June 2017 . 2017-06-03.
  12. News: New app allows pre-diabetics to use photos of their meal to check if it is healthy. The Straits Times. 24 January 2019 . 6 April 2019.