CAFCR: a Multi-View Method for Embedded Systems Architecting; Balancing Genericity and Specificity

Total Page:16

File Type:pdf, Size:1020Kb

CAFCR: a Multi-View Method for Embedded Systems Architecting; Balancing Genericity and Specificity CAFCR: A Multi-view Method for Embedded Systems Architecting; Balancing Genericity and Specificity trecon = tfilter(nraw-x ,nraw-y) + t ) + nraw-x * ( tfft(nraw-y)+ col-overhead ny * ( tfft(nraw-x) + trow-overhead ) + tcorrections (nx ,ny) + tcontrol-overhead Gerrit Muller ii This page will not be present in the final thesis version: 2.9 status: concept date: August 21, 2020 iii CAFCR: A Multi-view Method for Embedded Systems Architecting; Balancing Genericity and Specificity Proefschrift ter verkrijging van de graad van doctor aan de Technische Universiteit Delft, op gezag van de Rector Magnificus prof.dr.ir. J.T. Fokkema, voorzitter van het College voor Promoties, in het openbaar te verdedigen op maandag 7 juni 2004 om 13:00 uur door Gerrit Jan MULLER doctorandus in de natuurkunde geboren te Amsterdam iv Dit proefschrift is goedgekeurd door de promotor: Prof.dr W.G. Vree Samenstelling promotiecommissie: Rector Magnificus voorzitter Prof.dr. W.G. Vree Technische Universiteit Delft, promotor Prof.dr. M. Rem Technische Universiteit Eindhoven Prof.dr.ir. P.A. Kroes Technische Universiteit Delft Prof.dr.ir. H.J. Sips Technische Universiteit Delft Prof.dr. R. Wagenaar Technische Universiteit Delft Prof.dr.ing. D.K. Hammer Technische Universiteit Eindhoven Prof.dr. P.H. Hartel Universiteit Twente Prof.dr. M. Rem heeft als begeleider in belangrijke mate aan de totstandkoming van het proefschrift bijgedragen. ISBN 90-5639-120-2 Keywords: Systems Architecture, System design, Systems Engineering These investigations were supported by Philips Research Laboratories, and the Embedded Systems Institute, both in Eindhoven. Cover Photograph: René Stout http://www.rwstout.com/ Copyright c 2004 by G.J. Muller. This thesis is written as part of the Gaudí project. Further distribution is allowed as long as the thesis remains complete and unchanged. Use of figures is allowed as long as a reference to the source is present. Note that the copyright of photographs resides at the original copyright owners. Preface The industrial world and the academic world have drifted far apart in the imma- ture discipline of systems architecting. The challenge in writing this thesis was to capture the industrial pragmatic experience in a way that is acceptable for the aca- demic community. Moreover, the Embedded Systems Institute has the ambition to mature and extend this discipline. This thesis is a first step in bridging the gap between industry and academics. The personal motivation for writing this thesis is best explained by looking back at my career. I have been active in the hectic product creation environment for about twenty years. More than 17 years I was responsible for several archi- tectures of medical systems. The drawing on the cover has been made in this period to visualize the system designer as a monster with twenty heads, and hence twenty viewpoints. For more than two years I have been heading the Systems En- gineering department at ASML. This period at ASML was very instructive and refreshing. I very much liked the opportunity to educate and coach future as well as senior system engineers in this young discipline. After these twenty years of industrial pressure I joined Philips Research, with as my personal goal to mature the discipline and to make it more accessible and transferable. The Gaudí site www.gaudisite.nl/ shows the ongoing results of this effort. The step from Philips Research to the Embedded Systems Institute1 creates the opportunity to link this experience based work to the academic world. One of the peculiarities of the academic world is that only people with a doc- tor’s title seem to be taken seriously. In the process of writing this thesis I have hit many more aspects of the scientific culture, such as the need to cite others for every statement being made, an extremely redundant writing style, the preference for text over figures, and a focus on the argumentation rather than on the clar- ity or didactic value. Going through this learning experience is very valuable in 1 The Embedded Systems Institute is founded by Philips, ASML, Océ, TNO and the universities of Delft, Eindhoven and Twente v vi PREFACE the interaction with the academic world. I gained a better understanding of the obsession for publication, peer review, and the noise induced by all citations and repetitions in scientific publications. Understanding the motivation and the behav- ior of the academic partners is a prerequisite to bridge the gap between industry and academics. My thinking processes make use of visualizations: diagrams, structures, mod- els, et cetera. This thesis contains over 150 figures. The advantage of figures is that they show the overview and the parts at the same time, whereas text is linear: only after reading the entire text the overview might become clear. Lots of energy has been spent to complement all visualizations with readable text. The broad and multi-disciplinary scope of systems architecting can easily re- sult in generic statements. I have attempted to cope with this danger of over- generalization by providing a very specific case study. This struggle with the balance between genericity and specificity is the daily world of every systems ar- chitect. This struggle repeated itself when writing this thesis. The academic value is in the extraction of more generally applicable knowledge. But the route towards this knowledge meanders through many highly specific details. If both academic people as well as industrial people enjoy reading this thesis then one of my goals has been achieved. So, enjoy reading! Contents Preface v Introduction xi I Introduction to CAFCR and Threads of Reasoning 1 1 What is Systems Architecting in an Industrial Context? 3 1.1 Introduction . 3 1.2 Description of the Business Context . 5 1.3 Internal Stakeholders . 5 1.4 Acknowledgements . 6 2 Overview of CAFCR and Threads of Reasoning 7 2.1 Introduction . 7 2.2 Architecting Method Overview . 7 2.3 The CAFCR Model . 8 3 Introduction to Medical Imaging Case Study 13 3.1 Market and Application . 13 3.2 Technology . 15 4 Positioning the CAFCR Method in the World 19 4.1 Introduction . 19 4.2 Related Work . 19 4.3 What is the Unique Contribution of this Work? . 22 4.4 IEEE 1471 . 24 vii viii CONTENTS 5 Research in Systems Architecting 27 5.1 Introduction . 27 5.2 Technology Management Cycle . 28 5.3 Challenges to do Research in a Scientific Way . 29 5.4 Architecting Research Method . 33 5.5 Distance between Industrial Practice and Scientific Research . 34 5.6 Research Environment . 35 6 Research Question and Hypothesis 37 6.1 Introduction . 37 6.2 Research Question . 37 6.3 Hypothesis . 39 6.4 Criteria . 41 6.5 Summary . 42 II Theory of CAFCR and Threads of Reasoning 43 7 Basic Methods 45 7.1 Introduction . 45 7.2 Viewpoint Hopping . 46 7.3 Decomposition and Integration . 49 7.4 Quantification . 49 7.5 Coping with Uncertainty . 51 7.6 Modeling . 52 7.7 WWHWWW . 53 7.8 Decision Making Approach in Specification and Design . 54 8 Submethods in the CAF Views 59 8.1 Introduction . 59 8.2 Key Drivers . 59 8.3 Customer Business Positioning . 62 8.4 Modeling in the Customer World . 64 8.5 Use Cases . 66 8.6 System Specification . 67 8.7 Overview of the Submethods in the CAF views . 74 CONTENTS ix 9 Submethods in the CR Views 75 9.1 Introduction . 75 9.2 Decomposition . 75 9.3 Quality Design Submethods . 82 9.4 Project Management Support . 89 9.5 Overview of the Submethods in the CR views . 92 10 Qualities as Integrating Needles 93 10.1 Introduction . 93 10.2 Security as Example of a Quality Needle . 94 10.3 Qualities Checklist . 96 10.4 Summary . 101 11 Story Telling 103 11.1 Introduction . 103 11.2 How to Create a Story? . 104 11.3 How to Use a Story? . 105 11.4 Criteria . 105 11.5 Summary . 107 12 Threads of Reasoning 109 12.1 Introduction . 109 12.2 Overview of Reasoning Approach . 109 12.3 Reasoning . 114 12.4 Outline of the complete method . 116 12.5 Summary . 117 III Medical Imaging Case Description 119 13 Medical Imaging in Chronological Order 121 13.1 Project Context . 121 13.2 Introduction . 122 13.3 Development of Easyvision RF . 122 13.4 Performance Problem . 124 13.5 Safety . 127 13.6 Summary . 129 x CONTENTS 14 Medical Imaging Workstation: CAF Views 131 14.1 Introduction . 131 14.2 Radiology Context . 131 14.3 Typical Case . 138 14.4 Key Driver Graph . 139 14.5 Functionality . 144 14.6 Interoperability via Information Model . 145 14.7 Conclusion . 146 15 Medical Imaging Workstation: CR Views 149 15.1 Introduction . 149 15.2 Image Quality and Presentation Pipeline . 149 15.3 Software Specific Views . 152 15.4 Memory Management . 154 15.5 CPU Usage . 160 15.6 Measurement Tools . 161 15.7 Conclusion . 165 16 Story Telling in Medical Imaging 167 16.1 Introduction . 167 16.2 The Sales Story . 168 16.3 The Radiologist at Work . 169 16.4 Towards Design . 170 16.5 Conclusion . 172 17 Threads of Reasoning in the Medical Imaging Case 173 17.1 Introduction . 173 17.2 Example Thread . 173 17.3 Exploration of Problems and Solutions . 175 17.4 Conclusion . 183 IV Evaluation, Discussion and Conclusions 185 18 Evaluation of the Architecting Method 187 18.1 Introduction . 187 18.2 Design Evaluation . ..
Recommended publications
  • Open Source Used in Influx1.8 Influx 1.9
    Open Source Used In Influx1.8 Influx 1.9 Cisco Systems, Inc. www.cisco.com Cisco has more than 200 offices worldwide. Addresses, phone numbers, and fax numbers are listed on the Cisco website at www.cisco.com/go/offices. Text Part Number: 78EE117C99-1178791953 Open Source Used In Influx1.8 Influx 1.9 1 This document contains licenses and notices for open source software used in this product. With respect to the free/open source software listed in this document, if you have any questions or wish to receive a copy of any source code to which you may be entitled under the applicable free/open source license(s) (such as the GNU Lesser/General Public License), please contact us at [email protected]. In your requests please include the following reference number 78EE117C99-1178791953 Contents 1.1 golang-protobuf-extensions v1.0.1 1.1.1 Available under license 1.2 prometheus-client v0.2.0 1.2.1 Available under license 1.3 gopkg.in-asn1-ber v1.0.0-20170511165959-379148ca0225 1.3.1 Available under license 1.4 influxdata-raft-boltdb v0.0.0-20210323121340-465fcd3eb4d8 1.4.1 Available under license 1.5 fwd v1.1.1 1.5.1 Available under license 1.6 jaeger-client-go v2.23.0+incompatible 1.6.1 Available under license 1.7 golang-genproto v0.0.0-20210122163508-8081c04a3579 1.7.1 Available under license 1.8 influxdata-roaring v0.4.13-0.20180809181101-fc520f41fab6 1.8.1 Available under license 1.9 influxdata-flux v0.113.0 1.9.1 Available under license 1.10 apache-arrow-go-arrow v0.0.0-20200923215132-ac86123a3f01 1.10.1 Available under
    [Show full text]
  • Buildbot Documentation Release 1.6.0
    Buildbot Documentation Release 1.6.0 Brian Warner Nov 17, 2018 Contents 1 Buildbot Tutorial 3 1.1 First Run.................................................3 1.2 First Buildbot run with Docker......................................6 1.3 A Quick Tour...............................................9 1.4 Further Reading............................................. 17 2 Buildbot Manual 23 2.1 Introduction............................................... 23 2.2 Installation................................................ 29 2.3 Concepts................................................. 41 2.4 Secret Management........................................... 50 2.5 Configuration............................................... 53 2.6 Customization.............................................. 251 2.7 Command-line Tool........................................... 278 2.8 Resources................................................. 289 2.9 Optimization............................................... 289 2.10 Plugin Infrastructure in Buildbot..................................... 289 2.11 Deployment............................................... 290 2.12 Upgrading................................................ 292 3 Buildbot Development 305 3.1 Development Quick-start......................................... 305 3.2 General Documents........................................... 307 3.3 APIs................................................... 391 3.4 Python3 compatibility.......................................... 484 3.5 Classes.................................................
    [Show full text]
  • Gerrit J.J. Van Den Burg, Phd London, UK | Email: [email protected] | Web: Gertjanvandenburg.Com
    Gerrit J.J. van den Burg, PhD London, UK | Email: [email protected] | Web: gertjanvandenburg.com Summary I am a research scientist with a PhD in machine learning and 8+ years of experience in academic research. I am currently looking to transition to industry to work on complex, large-scale problems that can have a positive real-world impact. I have extensive experience with machine learning modeling, algorithm design, and software engineering in Python, C, and R. My goal is to use my expertise and technical skills to address ongoing research challenges in machine learning and AI. Research Experience Postdoctoral Researcher — The Alan Turing Institute, UK 2018–2021 • Introduced a memorization score for probabilistic deep generative models and showed that neural networks can remember part of their input data, which has important implications for data privacy • Created a method for structure detection in textual data files that improved on the Python builtin method by 21%. Developed this into a Python package that has received over 600,000 downloads • Developed a robust Bayesian matrix factorization algorithm for time series modeling and forecasting that improved imputation error up to 60% while maintaining competitive runtime • Established the first benchmark dataset for change point detection on general real-world time series and determined the best performing methods, with consequences for research and practice • Collaborated with other researchers to design a unified interface for AI-powered data cleaning tools Doctoral Researcher
    [Show full text]
  • QUARTERLY CHECK-IN Technology (Services) TECH GOAL QUADRANT
    QUARTERLY CHECK-IN Technology (Services) TECH GOAL QUADRANT C Features that we build to improve our technology A Foundation level goals offering B Features we build for others D Modernization, renewal and tech debt goals The goals in each team pack are annotated using this scheme illustrate the broad trends in our priorities Agenda ● CTO Team ● Research and Data ● Design Research ● Performance ● Release Engineering ● Security ● Technical Operations Photos (left to right) Technology (Services) CTO July 2017 quarterly check-in All content is © Wikimedia Foundation & available under CC BY-SA 4.0, unless noted otherwise. CTO Team ● Victoria Coleman - Chief Technology Officer ● Joel Aufrecht - Program Manager (Technology) ● Lani Goto - Project Assistant ● Megan Neisler - Senior Project Coordinator ● Sarah Rodlund - Senior Project Coordinator ● Kevin Smith - Program Manager (Engineering) Photos (left to right) CHECK IN TEAM/DEPT PROGRAM WIKIMEDIA FOUNDATION July 2017 CTO 4.5 [LINK] ANNUAL PLAN GOAL: expand and strengthen our technical communities What is your objective / Who are you working with? What impact / deliverables are you expecting? workflow? Program 4: Technical LAST QUARTER community building (none) Outcome 5: Organize Wikimedia Developer Summit NEXT QUARTER Objective 1: Developer Technical Collaboration Decide on event location, dates, theme, deadlines, etc. Summit web page and publicize the information published four months before the event (B) STATUS: OBJECTIVE IN PROGRESS Technology (Services) Research and Data July, 2017 quarterly
    [Show full text]
  • VES Home Welcome to the VNF Event Stream (VES) Project Home
    VES Home Welcome to the VNF Event Stream (VES) Project Home This project was approved May 31, 2016 based upon the VNF Event Stream project proposal. In the meantime the project evolved and VES is not only used by VNF but also by PNF (physical network functions). However, the term "VES" is established and will be kept. Next to OPNFV and ONAP also O-RAN, O-RAN-SC and 3GPP are using VES. The term "xNF" refers to the combination of virtual network functions and physical network functions. Project description: Objective: This project will develop OPNFV platform support for VNF and PNF event streams, in a common model and format intended for use by Service Providers (SPs), e.g. in managing xNF health and lifecycle. The project’s goal is to enable a significant reduction in the effort to develop and integrate xNF telemetry-related data into automated xNF management systems, by promoting convergence toward a common event stream format and collection system. The VES doc source, code, and tests are available at: OPNFV github (generally updated with 30 minutes of merged commits) OPNFV gitweb To clone from the OPNFV repo, see the instructions at the Gerrit project page Powerpoint intro to the project: OPNVF VES.pptx. A demo of the project (vHello_VES Demo) was first presented at OpenStack Barcelona (2016), and updated for the OPNFV Summit 2017 (VES ONAP demo - see below for more info). The following diagram illustrates the concept and scope for the VES project, which includes: From ONAP a Common Event Data Model for the “VNF Event Stream”, with report "domains" covering e.g.
    [Show full text]
  • Metrics for Gerrit Code Reviews
    SPLST'15 Metrics for Gerrit code reviews Samuel Lehtonen and Timo Poranen University of Tampere, School of Information Sciences, Tampere, Finland [email protected],[email protected] Abstract. Code reviews are a widely accepted best practice in mod- ern software development. To enable easier and more agile code reviews, tools like Gerrit have been developed. Gerrit provides a framework for conducting reviews online, with no need for meetings or mailing lists. However, even with the help of tools like Gerrit, following and monitoring the review process becomes increasingly hard, when tens or even hun- dreds of code changes are uploaded daily. To make monitoring the review process easier, we propose a set of metrics to be used with Gerrit code review. The focus is on providing an insight to velocity and quality of code reviews, by measuring different review activities based on data, au- tomatically extracted from Gerrit. When automated, the measurements enable easy monitoring of code reviews, which help in establishing new best practices and improved review process. Keywords: Code quality; Code reviews; Gerrit; Metrics; 1 Introduction Code reviews are a widely used quality assurance practice in software engineer- ing, where developers read and assess each other's code before it is integrated into the codebase or deployed into production. Main motivations for reviews are to detect software defects and to improve code quality while sharing knowledge among developers. Reviews were originally introduced by Fagan [4] already in 1970's. The original, formal type of code inspections are still used in many com- panies, but has been often replaced with more modern types of reviews, where the review is not tied to place or time.
    [Show full text]
  • Fashion Terminology Today Describe Your Heritage Collections with an Eye on the Future
    Fashion Terminology Today Describe your heritage collections with an eye on the future Ykje Wildenborg MoMu – Fashion Museum of the Province of Antwerp, Belgium Europeana Fashion, Modemuze Abstract: This article was written for ‘non-techy people’, or people with a basic knowledge of information technology, interested in preparing their fashion heritage metadata for publication online. Publishing fashion heritage on the web brings about the undisputed need for a shared vocabulary, especially when merged. This is not only a question of multilingualism. Between collections and even within collections different words have been used to describe, for example, the same types of objects, materials or techniques. In professional language: the data often is “unclean”. Linked Data is the name of a development in information technology that could prove useful for fashion collecting institutions. It means that the descriptions of collections, in a computer readable format, have a structure that is extremely easy for the device to read. As alien as it may sound, Linked Data practices are already used by the data departments of larger museums, companies and governmental institutions around the world. It eliminates the need for translation or actual changing of the content of databases. It only concerns ‘labeling’ of terms in databases with an identifier. With this in mind, MoMu, the fashion museum of Antwerp, Belgium, is carrying out a termi- nology project in Flanders and the Netherlands, in order to motivate institutions to accomplish the task of labeling their terms. This article concludes with some of the experiences of this adventure, but firstly elucidates the context of the situation.
    [Show full text]
  • Full-Graph-Limited-Mvn-Deps.Pdf
    org.jboss.cl.jboss-cl-2.0.9.GA org.jboss.cl.jboss-cl-parent-2.2.1.GA org.jboss.cl.jboss-classloader-N/A org.jboss.cl.jboss-classloading-vfs-N/A org.jboss.cl.jboss-classloading-N/A org.primefaces.extensions.master-pom-1.0.0 org.sonatype.mercury.mercury-mp3-1.0-alpha-1 org.primefaces.themes.overcast-${primefaces.theme.version} org.primefaces.themes.dark-hive-${primefaces.theme.version}org.primefaces.themes.humanity-${primefaces.theme.version}org.primefaces.themes.le-frog-${primefaces.theme.version} org.primefaces.themes.south-street-${primefaces.theme.version}org.primefaces.themes.sunny-${primefaces.theme.version}org.primefaces.themes.hot-sneaks-${primefaces.theme.version}org.primefaces.themes.cupertino-${primefaces.theme.version} org.primefaces.themes.trontastic-${primefaces.theme.version}org.primefaces.themes.excite-bike-${primefaces.theme.version} org.apache.maven.mercury.mercury-external-N/A org.primefaces.themes.redmond-${primefaces.theme.version}org.primefaces.themes.afterwork-${primefaces.theme.version}org.primefaces.themes.glass-x-${primefaces.theme.version}org.primefaces.themes.home-${primefaces.theme.version} org.primefaces.themes.black-tie-${primefaces.theme.version}org.primefaces.themes.eggplant-${primefaces.theme.version} org.apache.maven.mercury.mercury-repo-remote-m2-N/Aorg.apache.maven.mercury.mercury-md-sat-N/A org.primefaces.themes.ui-lightness-${primefaces.theme.version}org.primefaces.themes.midnight-${primefaces.theme.version}org.primefaces.themes.mint-choc-${primefaces.theme.version}org.primefaces.themes.afternoon-${primefaces.theme.version}org.primefaces.themes.dot-luv-${primefaces.theme.version}org.primefaces.themes.smoothness-${primefaces.theme.version}org.primefaces.themes.swanky-purse-${primefaces.theme.version}
    [Show full text]
  • Arxiv:1910.06663V1 [Cs.PF] 15 Oct 2019
    AI Benchmark: All About Deep Learning on Smartphones in 2019 Andrey Ignatov Radu Timofte Andrei Kulik ETH Zurich ETH Zurich Google Research [email protected] [email protected] [email protected] Seungsoo Yang Ke Wang Felix Baum Max Wu Samsung, Inc. Huawei, Inc. Qualcomm, Inc. MediaTek, Inc. [email protected] [email protected] [email protected] [email protected] Lirong Xu Luc Van Gool∗ Unisoc, Inc. ETH Zurich [email protected] [email protected] Abstract compact models as they were running at best on devices with a single-core 600 MHz Arm CPU and 8-128 MB of The performance of mobile AI accelerators has been evolv- RAM. The situation changed after 2010, when mobile de- ing rapidly in the past two years, nearly doubling with each vices started to get multi-core processors, as well as power- new generation of SoCs. The current 4th generation of mo- ful GPUs, DSPs and NPUs, well suitable for machine and bile NPUs is already approaching the results of CUDA- deep learning tasks. At the same time, there was a fast de- compatible Nvidia graphics cards presented not long ago, velopment of the deep learning field, with numerous novel which together with the increased capabilities of mobile approaches and models that were achieving a fundamentally deep learning frameworks makes it possible to run com- new level of performance for many practical tasks, such as plex and deep AI models on mobile devices. In this pa- image classification, photo and speech processing, neural per, we evaluate the performance and compare the results of language understanding, etc.
    [Show full text]
  • A Dataset of Vulnerable Code Changes of the Chromium OS Project
    A Dataset of Vulnerable Code Changes of the Chromium OS project Rajshakhar Paul, Asif Kamal Turzo, Amiangshu Bosu Department of Computer Science Wayne State University Detroit, Michigan, USA fr.paul, asifkamal, [email protected] Abstract—This paper presents a an empirically built and of vulnerabilities that were escaped during code reviews, validated dataset of code reviews from the Chromium OS project we use the Monorail-based bug tracking system hosted at that either identified or missed security vulnerabilities. The https://bugs.chromium.org/. We searched in the bug tracking dataset includes total 890 vulnerable code changes categorized based on the CWE specification and is publicly available at: system to identify a list of security defects for the Chromium 1 https://zenodo.org/record/4539891 OS project . We used the following five-step approach to build Index Terms—security, code review, dataset, vulnerability this dataset. (Step I) Custom search: We used a custom search (i.e., I. INTRODUCTION (Type=Bug-Security status:Fixed OS=Chrome), Peer code review is an effective and well-recommended to filter security defects for the Chromium OS projects practice to identify security vulnerabilities during the pre- with the status as ‘Fixed’. Our search result identified total release stages [2]. However, despite practicing mandatory code 591 security defects. We exported the list of defects as a reviews, many Open Source Software (OSS) projects are still comma-separated values( i.e., CSV) file, where each issue is encountering a large number of post-release security vulner- associated with a unique ID. abilities, as some security defects remain undetected during (Step II) Identifying vulnerability fixing commit: The Mono- code reviews.
    [Show full text]
  • Git and Gerrit in Action and Lessons Learned Along the Path to Distributed Version Control
    Git and Gerrit in Action And lessons learned along the path to distributed version control Chris Aniszczyk (Red Hat) Principal Software Engineer [email protected] http://aniszczyk.org About Me I've been using and hacking open source for ~12 years - contribute{d} to Gentoo Linux, Fedora Linux, Eclipse Hack on Eclipse, Git and other things at Red Hat Member of the Eclipse Board of Directors Member in the Eclipse Architecture Council I like to run! (2 mins short of Boston qualifying ;/) Co-author of RCP Book (www.eclipsercp.org) An Introduction to Git and Gerrit | © 2011 by Chris Aniszczyk Agenda History of Version Control (VCS) The Rise of Distributed Version Control (DVCS) Code Review with Git and Gerrit Lessons Learned at Eclipse moving to a DVCS Conclusion Q&A An Introduction to Git and Gerrit | © 2011 by Chris Aniszczyk Version Control Version Control Systems manage change “The only constant is change” (Heraclitus) An Introduction to Git and Gerrit | © 2011 by Chris Aniszczyk Why Version Control? VCS became essential to software development because: They allow teams to collaborate They manage change and allow for inspection They track ownership They track evolution of changes They allow for branching They allow for continuous integration An Introduction to Git and Gerrit | © 2011 by Chris Aniszczyk Version Control: The Ancients 1972 – Source Code Control System (SCCS) Born out of Bell Labs, based on interleaved deltas No open source implementations as far as I know 1982 – Revision Control System (RCS) Released as an alternative to SCCS
    [Show full text]
  • Building Secure and Reliable Systems
    Building Secure & Reliable Systems Best Practices for Designing, Implementing and Maintaining Systems Compliments of Heather Adkins, Betsy Beyer, Paul Blankinship, Piotr Lewandowski, Ana Oprea & Adam Stubblefi eld Praise for Building Secure and Reliable Systems It is very hard to get practical advice on how to build and operate trustworthy infrastructure at the scale of billions of users. This book is the first to really capture the knowledge of some of the best security and reliability teams in the world, and while very few companies will need to operate at Google’s scale many engineers and operators can benefit from some of the hard-earned lessons on securing wide-flung distributed systems. This book is full of useful insights from cover to cover, and each example and anecdote is heavy with authenticity and the wisdom that comes from experimenting, failing and measuring real outcomes at scale. It is a must for anybody looking to build their systems the correct way from day one. —Alex Stamos, Director of the Stanford Internet Observatory and former CISO of Facebook and Yahoo This book is a rare treat for industry veterans and novices alike: instead of teaching information security as a discipline of its own, the authors offer hard-wrought and richly illustrated advice for building software and operations that actually stood the test of time. In doing so, they make a compelling case for reliability, usability, and security going hand-in-hand as the entirely inseparable underpinnings of good system design. —Michał Zalewski, VP of Security Engineering at Snap, Inc. and author of The Tangled Web and Silence on the Wire This is the “real world” that researchers talk about in their papers.
    [Show full text]