Type 2 Diabetes Prediction Using Machine Learning Algorithms

Total Page:16

File Type:pdf, Size:1020Kb

Type 2 Diabetes Prediction Using Machine Learning Algorithms Type 2 Diabetes Prediction Using Machine Learning Algorithms Parisa Karimi Darabi*, Mohammad Jafar Tarokh Department of Industrial Engineering, K. N. Toosi University of Technology, Tehran, Iran Abstract Article Type: Background and Objective: Currently, diabetes is one of the leading causes of Original article death in the world. According to several factors diagnosis of this disease is Article History: complex and prone to human error. This study aimed to analyze the risk of Received: 15 Jul 2020 having diabetes based on laboratory information, life style and, family history Revised: 1 Aug 2020 with the help of machine learning algorithms. When the model is trained Accepted: 5 Aug 2020 properly, people can examine their risk of having diabetes. *Correspondence: Material and Methods: To classify patients, by using Python, eight different machine learning algorithms (Logistic Regression, Nearest Neighbor, Decision Parisa Karimi Darabi, Tree, Random Forest, Support Vector Machine, Naive Bayesian, Neural Department of Industrial Network and Gradient Boosting) were analyzed. Were evaluated by accuracy, Engineering, K. N. Toosi University sensitivity, specificity and ROC curve parameters. of Technology, Tehran, Iran Results: The model based on the gradient boosting algorithm showed the best [email protected] performance with a prediction accuracy of %95.50. Conclusion: In the future, this model can be used for diagnosis diabete. The basis of this study is to do more research and develop models such as other learning machine algorithms. Keywords: Prediction, diabetes, machine learning, gradient boosting, ROC curve DOI : 10.29252/jorjanibiomedj.8.3.4 people die every year from diabetes disease. Introduction By 2045, it will reach 629 million (1). According to the world health organization, This epidemic disease tends to grow. It was diabetes is a chronic disease. This disease is estimated that approximately 642 million due to either the pancreas not producing people will have diabetes by 2040. However, enough insulin or the body not responding the number of studies estimated that the properly to the insulin produced. annual cost of the disease from US$673 Diabetes has a serious global economic billion in 2015 reaches US$827 billion in impact. In 2012, this disease with 1.5 million 2016, which currently exceed the 2030 deaths, made the 8th leading cause of death. prediction (2). Based on statistics of 2017, nearly 425 Moreover, the economic burden of diabetes in million people had diabetes, about 2-5 million China has risen over time. In 2015, the total Copyright© 2018, Jorjani Biomedicine Journal has published this work as an open access article under the terms of the Creative Commons Attribution License (http://creativecommons.org/licenses/by-nc/4.0/) which permits non- commercial uses of the work while it is properly cited. Type 2 Diabetes Prediction Using Machine Learning Algorithms Karimi Darabi P. et al. annual expenditure was between US$51.1 and Despite human error probability, different US$88.4 billion (3). types of machine learning algorithms, Type 1 diabetes is also called “insulin- analytical and statistical methods, that use the dependent diabetes”. Type 1 diabetes results previous and current data for finding from the body’s inability to produce insulin. information and predicting future events, can Therefore, the injection of insulin is essential be used for solving this problem. for the patient. Type 2 diabetes occurs when The artificial intelligence field is growing the body’s cells do not react to insulin rapidly. Its functions in the field of diabetes properly. This type of diabetes appears most are diagnosis and management of this chronic often in middle-aged, and sometimes older disease. The techniques of machine learning people. Gestational diabetes is high blood are used for making models of diabetes sugar that develops during pregnancy in a diagnosis and its side effects (6). woman who has not been diagnosed with Results of empirical research articles, reflect diabetes before. the ability of analytical techniques to Today, the disease is also occurring in diagnose diabetes. Recent research shows that children. There are several causes of diabetes, machine learning techniques can describe the including allergy, genetics, body weight, diet, characteristics of patients and identify patients physical activity, and, lifestyle (4). at risk for type 2 diabetes (7, 8). Machine Since diabetes is a multifactorial disease, it is Learning is one of the most important features diagnosis is complicated. Therefore, for of artificial intelligence that supports the accurate diagnosis, the physician should development of computer systems with the examine the test results of a patient, compare ability to learn and improve from experiences, and the need to plan for every case (9). the test results with those of patients under the same condition, and analyze previous The purpose of this study is to use learning decisions. To care for a person, doctors are machine algorithms for making models of well prepared to identify people at risk for type 2 diabetes diagnosis. type 2 diabetes. Related work However, as we try to screen thousands of More than half of all adults worldwide are patients at high risk, the challenges that suffering from diabetes disease. Hence, early physicians face become apparent (5). and detection of the disease greatly improves Analysis of the factors influencing the patient quality of life. For the diagnosis of diagnosis may be influenced by human error. diabetes, a lot of researchers used learning Because it is subject to the physician’s machine methods and data analysis (10). interpretation. Many articles by using statistical analysis A Blood test is not discriminatory enough, methods explored connections and samples and it is not enough for an accurate diagnosis between Chinese patients’ data (11-14). of diabetes. Because among different characteristics of people it may be interpreted Gao et al. in (11) used statistical analysis and differently (4). Therefore, apart from multivariate Cox Regression algorithm to laboratory information, lifestyle, physical study the relationship between ALT and condition, and family history of patients diabetes. They concluded that people between should be examined. the age group 30-40 with elevated ALT are at 5| Jorjani Biomedicine Journal. 2020; 8(3): P 4-18. Type 2 Diabetes Prediction Using Machine Learning Algorithms Karimi Darabi P. et al. a greater risk compared to those with low Many researchers also by analyzing different ALT. types of machine learning algorithms, assess Chen et al. in (12) by using statistical analysis and compare their performance on a particular and multivariate Cox Regression algorithm data set, and, ultimately with particular demonstrated that ratio TG /HDL-C was evaluation methodologies, introduce the most positively associated with the incidence of appropriate predictive model for diabetes (20, diabetes in the Chinese population. 21). Qin et al. in (3) by exploring ratio TG/HDL-C Materials and Methods as an independent predictor of diabetes, found Brief description of Machine Learning that TG/HDL-C is a powerful predictor in Classification Techniques male patients compared to female patients. Logistic Regression Chen et al. in (13) investigated the relation of obesity and age with diabetes. Eventually, Logistic Regression (LR) is a sort of across all age groups, there was a linear supervised learning which estimates the association between BMI and diabetes. They connection between a binary dependent verified that BMI and age are a strong variable and at least one independent variable predictor of diabetes. by evaluating probabilities with the help of sigmoid function. In contrary to its name, LR Lin et al. in (14) designed a Nomogram based is not used for regression problems rather is a on the seven factors of diabetes in order to type of machine learning classification predict type 2 diabetes risk among people. problem where the dependent variable is Diabetes prediction should be under control. dichotomous (0/1, -1/1, true/false) and Therefore, supervised learning algorithms independent variable can binominal, ordinal, have attracted a great deal of attention from interval or ratio-level. The sigmoid/Logistic researchers. By using machine learning, many function is given as: diabetes research articles have been done on the Pima data set (15-18). (1) Wu et al. in (15) applied the Nearest Neighbor where, y is the output which is the result of and Regression Logistic algorithms to make a weighted sum of input variables x. If the diabetes prediction model with an accuracy of output is more than 0.5, the output is 1 else 95.42%. the output is 0 (21). Viloria et al. in (6) developed a diabetes K-Nearest Neighbor predictive model by applying the Support K-Nearest Neighbor (KNN) method can be Vector Machine algorithm. The algorithm used for both classification and regression was obtained with an accuracy of 99.2% with problems (19). However, it is more widely Colombian patients. used in classification problems in the Devi et al. in (19) by employing a Support industry. KNN is a simple algorithm that Vector Machine algorithm, managed to make stores all available cases and classifies new a diabetes prediction model with an accuracy cases by a majority vote of its k neighbors. of 99.4%. The case is assigned to the class is most common amongst its K nearest neighbors 6| Jorjani Biomedicine Journal. 2020; 8(3): P 4-18. Type 2 Diabetes Prediction Using Machine Learning Algorithms Karimi Darabi P. et al. measured by a distance function. These multidimensional space. A hyperplane is a distance functions can be Euclidean, decision boundary to classify data points. The Manhattan, Makowski, and Hamming hyperplane classifies the data points with the distance. maximum margin between the classes and the The first three functions are used for hyperplane (21). continuous function and the fourth one In this algorithm, we plot each data item as a (Hamming) for categorical variables. If K = 1, point in n-dimensional space (where n is the then the case is simply assigned to the class of number of features you have) with the value its nearest neighbor.
Recommended publications
  • Recursive Definitions Across the Footprint That a Straight- Line Program Manipulated, E.G
    natural proofs for verification of dynamic heaps P. MADHUSUDAN UNIV. OF ILLINOIS AT URBANA-CHAMPAIGN (VISITING MSR, BANGALORE) WORKSHOP ON MAKING FORMAL VERIFICATION SCALABLE AND USEABLE CMI, CHENNAI, INDIA JOINT WORK WITH… Xiaokang Qiu .. graduating! Gennaro Andrei Pranav Garg Parlato Stefanescu GOAL: BUILD RELIABLE SOFTWARE Build systems with proven reliability and security guarantees. (Not the same as finding bugs!) Deductive verification with automatic theorem proving • Floyd/Hoare style verification • User supplied modular annotations (pre/post cond, class invariants) and loop invariants • Resulting verification conditions are derived automatically for each linear program segment (using weakest-pre/strongest-post) Verification conditions are then proved valid using mostly automatic theorem proving (like SMT solvers) TARGET: RELIABLE SYS TEMS SOFTWARE Operating Systems Angry birds Browsers Excel VMs Mail clients … App platforms Systems Software Applications Several success stories: • Microsoft Hypervisor verification using VCC [MSR, EMIC] • A secure foundation for mobile apps [@Illinois, ASPLOS’13] A SECURE FOUNDATION FOR MOBILE APPS In collaboration with King’s systems group at Illinois First OS architecture that provides verifiable, high-level abstractions for building mobile applications. Application state is private by default. • Meta-data on files controls access by apps; only app with appropriate permissions can access files • Every page is encrypted before sending to the storage service. • Memory isolation between apps • A page fault handler serves a file- backed page for a process, the fille has to be opened by the same process. • Only the current app can write to the screen buffer. • IPC channel correctness • … VERIFICATION TOOLS ARE MATURE And works! ENOUGH TO BUILD RELIABLE S/W.
    [Show full text]
  • Scalable Fault-Tolerant Elastic Data Ingestion in Asterixdb
    UC Irvine UC Irvine Electronic Theses and Dissertations Title Scalable Fault-Tolerant Elastic Data Ingestion in AsterixDB Permalink https://escholarship.org/uc/item/9xv3435x Author Grover, Raman Publication Date 2015 License https://creativecommons.org/licenses/by-nd/4.0/ 4.0 Peer reviewed|Thesis/dissertation eScholarship.org Powered by the California Digital Library University of California UNIVERSITY OF CALIFORNIA, IRVINE Scalable Fault-Tolerant Elastic Data Ingestion in AsterixDB DISSERTATION submitted in partial satisfaction of the requirements for the degree of DOCTOR OF PHILOSOPHY in Information and Computer Science by Raman Grover Dissertation Committee: Professor Michael J. Carey, Chair Professor Chen Li Professor Sharad Mehrotra 2015 © 2015 Raman Grover DEDICATION To my wonderful parents... ii TABLE OF CONTENTS Page LIST OF FIGURES vi LIST OF TABLES viii ACKNOWLEDGMENTS ix CURRICULUM VITAE x ABSTRACT OF THE DISSERTATION xi 1 Introduction 1 1.1 Challenges in Data Feed Management . .3 1.1.1 Genericity and Extensibility . .3 1.1.2 Fetch-Once Compute-Many Model . .5 1.1.3 Scalability and Elasticity . .5 1.1.4 Fault Tolerance . .7 1.2 Contributions . .8 1.3 Organization . .9 2 Related Work 10 2.1 Stream Processing Engines . 10 2.2 Data Routing Engines . 11 2.3 Extract Transform Load (ETL) Systems . 12 2.4 Other Systems . 13 2.4.1 Flume . 14 2.4.2 Chukwa . 15 2.4.3 Kafka . 16 2.4.4 Sqoop . 17 2.5 Summary . 17 3 Background and Preliminaries 19 3.1 AsterixDB . 19 3.1.1 AsterixDB Architecture . 20 3.1.2 AsterixDB Data Model . 21 3.1.3 Querying Data .
    [Show full text]
  • Anomaly Detection and Identification Scheme for VM Live Migration in Cloud Infrastructure✩
    Future Generation Computer Systems 56 (2016) 736–745 Contents lists available at ScienceDirect Future Generation Computer Systems journal homepage: www.elsevier.com/locate/fgcs Anomaly detection and identification scheme for VM live migration in cloud infrastructureI Tian Huang a, Yongxin Zhu a,∗, Yafei Wu a, Stéphane Bressan b, Gillian Dobbie c a School of Microelectronics, Shanghai Jiao Tong University, China b School of Computing, National University of Singapore, Singapore c Department of Computer Science, University of Auckland, New Zealand h i g h l i g h t s • We extend Local Outlier Factors to detect anomalies in time series and adapt to smooth environmental changes. • We propose Dimension Reasoning LOF (DR-LOF) that can point out the ``most anomalous'' dimension of the performance profile. DR-LOF provides clues for administrators to pinpoint and clear the anomalies. • We incorporate DR-LOF and Symbolic Aggregate ApproXimation (SAX) measurement as a scheme to detect and identify the anomalies in the progress of VM live migration. • In experiments, we deploy a typical computing application on small scale clusters and evaluate our anomaly detection and identification scheme by imposing two kinds of common anomalies onto VMs. article info a b s t r a c t Article history: Virtual machines (VM) offer simple and practical mechanisms to address many of the manageability Received 3 March 2015 problems of leveraging heterogeneous computing resources. VM live migration is an important feature Received in revised form of virtualization in cloud computing: it allows administrators to transparently tune the performance 11 May 2015 of the computing infrastructure. However, VM live migration may open the door to security threats.
    [Show full text]
  • A Decidable Logic for Tree Data-Structures with Measurements
    A Decidable Logic for Tree Data-Structures with Measurements Xiaokang Qiu and Yanjun Wang Purdue University fxkqiu,[email protected] Abstract. We present Dryaddec, a decidable logic that allows reason- ing about tree data-structures with measurements. This logic supports user-defined recursive measure functions based on Max or Sum, and re- cursive predicates based on these measure functions, such as AVL trees or red-black trees. We prove that the logic's satisfiability is decidable. The crux of the decidability proof is a small model property which al- lows us to reduce the satisfiability of Dryaddec to quantifier-free lin- ear arithmetic theory which can be solved efficiently using SMT solvers. We also show that Dryaddec can encode a variety of verification and synthesis problems, including natural proof verification conditions for functional correctness of recursive tree-manipulating programs, legal- ity conditions for fusing tree traversals, synthesis conditions for con- ditional linear-integer arithmetic functions. We developed the decision procedure and successfully solved 220+ Dryaddec formulae raised from these application scenarios, including verifying functional correctness of programs manipulating AVL trees, red-black trees and treaps, check- ing the fusibility of height-based mutually recursive tree traversals, and counterexample-guided synthesis from linear integer arithmetic specifi- cations. To our knowledge, Dryaddec is the first decidable logic that can solve such a wide variety of problems requiring flexible combination of measure-related, data-related and shape-related properties for trees. 1 Introduction Logical reasoning about tree data-structures has been needed in various applica- tion scenarios such as program verification [32,24,26,42,49,4,14], compiler opti- mization [17,18,9,44] and webpage layout engines [30,31].
    [Show full text]
  • Data Intensive Computing with Linq to Hpc Technical
    DATA INTENSIVE COMPUTING WITH LINQ TO HPC TECHNICAL OVERVIEW Ade Miller, Principal Program Manager, LINQ to HPC Agenda Introduction to LINQ to HPC Using LINQ to HPC Systems Management Integrating with Other Data Technologies The Data Spectrum One extreme is analyzing raw, unstructured data. The analyst does not know exactly what the data contains, nor LINQ to HPC what cube would be justified. The analyst needs to do ad-hoc analyses that may never be run again. Another extreme is analytics targeting a traditional data warehouse. The analyst Parallel Data knows the cube he or she wants to build, Warehouse and the analyst knows the data sources. What kind of Data? Large Data Volume . 100s of TBs to 10s of PBs New Questions & Non-Traditional data Types New Technologies New Insights . Unstructured & Semi structured . How popular is my product? . Weak relational schema . Distributed Parallel Processing . What is the best ad to serve? . Text, Images, Videos, Logs Frameworks . Is this a fraudulent transaction? . Easy to Scale on commodity hardware . MapReduce-style programming models New Data Sources . Sensors & Devices . Traditional applications . Web Servers . Public data Overview MOVING THE DATA TO THE COMPUTE So how does it work? FIRST, STORE THE DATA Data Intensive Computing with HPC Server Windows HPC Server 2008 R2 Service Pack 2 So how does it work? SECOND, TAKE THE PROCESSING TO THE DATA Data Intensive Computing with HPC Server var logentries = from line in logs where !line.StartsWith("#") select new LogEntry(line); var user = from access
    [Show full text]
  • Cloud Computing Paradigms for Pleasingly Parallel Biomedical
    Cloud Computing Paradigms for Pleasingly Parallel Biomedical Applications Thilina Gunarathne, Tak-Lon Wu, Jong Youl Choi, Seung-Hee Bae, Judy Qiu School of Informatics and Computing / Pervasive Technology Institute Indiana University, Bloomington. {tgunarat, taklwu, jychoi, sebae, xqiu}@indiana.edu Abstract Cloud computing offers exciting new approaches for scientific computing that leverages the hardware and software investments on large scale data centers by major commercial players. Loosely coupled problems are very important in many scientific fields and are on the rise with the ongoing move towards data intensive computing. There exist several approaches to leverage clouds & cloud oriented data processing frameworks to perform pleasingly parallel computations. In this paper we present three pleasingly parallel biomedical applications, 1) assembly of genome fragments 2) sequence alignment and similarity search 3) dimension reduction in the analysis of chemical structures, implemented utilizing cloud infrastructure service based utility computing models of Amazon Web Services and Microsoft Windows Azure as well as utilizing MapReduce based data processing frameworks, Apache Hadoop and Microsoft DryadLINQ. We review and compare each of the frameworks and perform a comparative study among them based on performance, efficiency, cost and the usability. Cloud service based utility computing model and the managed parallelism (MapReduce) exhibited comparable performance and efficiencies for the applications we considered. We analyze the variations in cost between the different platform choices (eg: EC2 instance types), highlighting the need to select the appropriate platform based on the nature of the computation. 1. Introduction Scientists are overwhelmed with the increasing amount of data processing needs arising from the storm of data that is flowing through virtually every field of science.
    [Show full text]
  • Characterization and Prediction of Deep Learning Workloads in Large-Scale GPU Datacenters
    Characterization and Prediction of Deep Learning Workloads in Large-Scale GPU Datacenters Qinghao Hu1,2 Peng Sun3 Shengen Yan3 Yonggang Wen1 Tianwei Zhang1∗ 1School of Computer Science and Engineering, Nanyang Technological University 2S-Lab, Nanyang Technological University 3SenseTime {qinghao.hu, ygwen, tianwei.zhang}@ntu.edu.sg {sunpeng1, yanshengen}@sensetime.com ABSTRACT 1 INTRODUCTION Modern GPU datacenters are critical for delivering Deep Learn- Over the years, we have witnessed the remarkable impact of Deep ing (DL) models and services in both the research community and Learning (DL) technology and applications on every aspect of our industry. When operating a datacenter, optimization of resource daily life, e.g., face recognition [65], language translation [64], adver- scheduling and management can bring significant financial bene- tisement recommendation [21], etc. The outstanding performance fits. Achieving this goal requires a deep understanding of thejob of DL models comes from the complex neural network structures features and user behaviors. We present a comprehensive study and may contain trillions of parameters [25]. Training a production about the characteristics of DL jobs and resource management. model may require large amounts of GPU resources to support First, we perform a large-scale analysis of real-world job traces thousands of petaflops operations [15]. Hence, it is a common prac- from SenseTime. We uncover some interesting conclusions from tice for research institutes, AI companies and cloud providers to the perspectives of clusters, jobs and users, which can facilitate the build large-scale GPU clusters to facilitate DL model development. cluster system designs. Second, we introduce a general-purpose These clusters are managed in a multi-tenancy fashion, offering framework, which manages resources based on historical data.
    [Show full text]
  • Ray: a Distributed Framework for Emerging AI Applications
    Ray: A Distributed Framework for Emerging AI Applications Philipp Moritz, Robert Nishihara, Stephanie Wang, Alexey Tumanov, Richard Liaw, Eric Liang, Melih Elibol, Zongheng Yang, William Paul, Michael I. Jordan, and Ion Stoica, UC Berkeley https://www.usenix.org/conference/osdi18/presentation/nishihara This paper is included in the Proceedings of the 13th USENIX Symposium on Operating Systems Design and Implementation (OSDI ’18). October 8–10, 2018 • Carlsbad, CA, USA ISBN 978-1-939133-08-3 Open access to the Proceedings of the 13th USENIX Symposium on Operating Systems Design and Implementation is sponsored by USENIX. Ray: A Distributed Framework for Emerging AI Applications Philipp Moritz,∗ Robert Nishihara,∗ Stephanie Wang, Alexey Tumanov, Richard Liaw, Eric Liang, Melih Elibol, Zongheng Yang, William Paul, Michael I. Jordan, Ion Stoica University of California, Berkeley Abstract and their use in prediction. These frameworks often lever- age specialized hardware (e.g., GPUs and TPUs), with the The next generation of AI applications will continuously goal of reducing training time in a batch setting. Examples interact with the environment and learn from these inter- include TensorFlow [7], MXNet [18], and PyTorch [46]. actions. These applications impose new and demanding The promise of AI is, however, far broader than classi- systems requirements, both in terms of performance and cal supervised learning. Emerging AI applications must flexibility. In this paper, we consider these requirements increasingly operate in dynamic environments, react to and present Ray—a distributed system to address them. changes in the environment, and take sequences of ac- Ray implements a unified interface that can express both tions to accomplish long-term goals [8, 43].
    [Show full text]
  • Natural Proofs for Structure, Data, and Separation
    Natural Proofs for Structure, Data, and Separation XiaokangQiu PranavGarg AndreiS¸tef˘anescu P.Madhusudan University of Illinois at Urbana-Champaign, USA {qiu2, garg11, stefane1, madhu}@illinois.edu Abstract ing verification conditions has become very powerful. The latter We propose natural proofs for reasoning with programs that ma- process is often executed by automated logical decision procedures nipulate data-structures against specifications that describe the supported by SMT solvers, which have emerged as robust and pow- structure of the heap, the data stored within it, and separation and erful engines to automatically find proofs. Several techniques and framing of sub-structures. Natural proofs are a subclass of proofs tools have been developed [2, 16, 20] and there have been several that are amenable to completely automated reasoning, that pro- success stories of large software verification projects using this ap- vide sound but incomplete procedures, and that capture common proach (the Verve OS project [42], the Microsoft hypervisor veri- reasoning tactics in program verification. We develop a dialect of fication project using VCC [16], and a recent verified-for-security + separation logic over heaps, called Dryad, with recursive defini- OS browser for mobile applications [29], to name a few). tions that avoids explicit quantification. We develop ways to reason Verification conditions do not, however, always fall into decid- with heaplets using classical logic over the theory of sets, and de- able theories. In particular, the verification of properties of the dy- velop natural proofs for reasoning using proof tactics involving namically modified heap is a big challenge for logical methods. The disciplined unfoldings and formula abstractions.
    [Show full text]
  • A Lightweight, Streaming Runtime for Cloud Computing with Support for Map-Reduce
    Granules: A Lightweight, Streaming Runtime for Cloud Computing With Support for Map-Reduce Shrideep Pallickara 12 Jaliya Ekanayake 2 and Geoffrey Fox 2 Department of Computer Science1 Community Grids Lab2 Colorado State University Indiana University Fort Collins, USA Bloomington, USA [email protected] {jekanaya, gcf}@indiana.edu Abstract— Cloud computing has gained significant traction in of data. These data volumes cannot be processed by a single recent years. The Map-Reduce framework is currently the computer or a small cluster of computer. Furthermore, in most dominant programming model in cloud computing most cases, this data can be processed in a pleasingly settings. In this paper, we describe Granules, a lightweight, parallel fashion. The result has been the aggregation of a streaming-based runtime for cloud computing which large number of commodity hardware components in vast incorporates support for the Map-Reduce framework. data centers. Granules provides rich lifecycle support for developing Map-Reduce [1], introduced by Dean and Ghemawat at scientific applications with support for iterative, periodic and Google, is the most dominant programming model for data driven semantics for individual computations and developing applications in cloud settings. Here, large pipelines. We describe our support for variants of the Map- datasets are split into smaller more manageable sizes which Reduce framework. The paper presents a survey of related work in this area. Finally, this paper describes our are then processed by multiple map instances. The results performance evaluation of various aspects of the system, produced by individual map functions are then sent to including (where possible) comparisons with other comparable reducers, which collate these partial results to produce the systems.
    [Show full text]
  • SONIC: Application-Aware Data Passing for Chained Serverless Applications
    SONIC: Application-aware Data Passing for Chained Serverless Applications Ashraf Mahgoub(a), Karthick Shankar(b), Subrata Mitra(c), Ana Klimovic(d), Somali Chaterji(a), Saurabh Bagchi(a) (a) Purdue University, (b) Carnegie Mellon University, (c) Adobe Research, (d) ETH Zurich Abstract and video analytics [6,27]. Accordingly, major cloud comput- ing providers recently introduced their serverless workflow Data analytics applications are increasingly leveraging services such as AWS Step Functions [5], Azure Durable serverless execution environments for their ease-of-use and Functions [48], and Google Cloud Composer [29], which pay-as-you-go billing. Increasingly, such applications are provide easier design and orchestration for serverless work- composed of multiple functions arranged in some workflow. flow applications. Serverless workflows are composed of a However, the current approach of exchanging intermediate sequence of execution stages, which can be represented as (ephemeral) data between functions through remote storage a directed acyclic graph (DAG) [21, 56]. DAG nodes corre- (such as S3) introduces significant performance overhead. spond to serverless functions (or ls1) and edges represent the We show that there are three alternative data-passing meth- flow of data between dependent ls (e.g., our video analytics ods, which we call VM-Storage, Direct-Passing, and state-of- application DAG is shown in Fig. 1). practice Remote-Storage. Crucially, we show that no single Exchanging intermediate data between serverless functions data-passing method prevails under all scenarios and the op- has been identified as a major challenge in serverless work- timal choice depends on dynamic factors such as the size flows [39, 41, 50].
    [Show full text]
  • Grasshopper Complete Heap Verification with Mixed Specifications
    GRASShopper Complete Heap Verification with Mixed Specifications Ruzica Piskac1, Thomas Wies2‹, and Damien Zufferey3 1Yale University 2New York University 3MIT CSAIL Abstract. We present GRASShopper, a tool for compositional verification of heap-manipulating programs against user-provided specifications. What makes our tool unique is its decidable specification language, which supports mixing of assertions expressed in separation logic and first-order logic. The user of the tool can thus take advantage of the succinctness of separation logic specifications and the discipline of local reasoning. Yet, at the same time, she can revert to classi- cal logic in the cases where decidable separation logic fragments are less suited, such as reasoning about constraints on data and heap structures with complex sharing. We achieve this combination of specification languages through a trans- lation to programs whose specifications are expressed in a decidable fragment of first-order logic called GRASS. This logic is well-suited for automation using sat- isfiability modulo theory solvers. Unlike other tools that provide similar features, our decidability guarantees enable GRASShopper to produce detailed counterex- amples for incorrect or underspecified programs. We have found this feature to be invaluable when debugging specifications. We present the underlying philosophy of the tool, describe the major technical challenges, and discuss implementation details. We conclude with an evaluation that considers challenging benchmarks such as sorting algorithms and a union/find data structure. 1 Introduction We present GRASShopper, a new tool for compositional verification of heap manipu- lating programs against user-provided specifications. GRASShopper takes programs in a C-like procedural language as input. The tool checks that procedures mutually satisfy their contracts, that all memory accesses are safe, and that there are no memory leaks.
    [Show full text]