Introducing Plasmo.jl

Size: px
Start display at page:

Download "Introducing Plasmo.jl"

Transcription

1 Introducing Plasmo.jl A Package for Graph-Based Modeling using JuMP Jordan Jalving and Victor Zavala Department of Chemical and Biological Engineering University of Wisconsin-Madison JuMP Developers Meetup June 13 th, 2017 Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

2 Plasmo.jl - What is it? Platform for Scalable Modeling and Optimization A Graph-based modeling and optimization framework Key Features: Component models associated with nodes and edges Facilitates construction of hierarchical graphs (uses subgraphs) Modularization of component models Manipulate graph structure for solver interface Ease of modeling complex systems Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

3 Overview Motivation - Complex systems Modeling Systems with Components (Graphs) Applications Design considerations Goals right now Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

4 Group Research Theme:Complex Systems x2 x1 x3 Multi-stage stochastic programs Asynchronous systems Multi-scale systems Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

5 Types of Problems Nonlinear (nonconvex) optimization Stochastic programming Model predictive control Some Applications Enery storage systems Connected infrastructure Microgrids Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

6 Hierarchical Networks Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

7 Technology Landscapes Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

8 Challenges with complex physical systems Millions of constraints and variables can make the computation intractable I Generally apply ad-hoc methods to perform some model reduction Millions of system connections makes model instantiation non-trivial I I Multiple scenarios Solution inspection Modeling asynchronicity in large communicating systems is non trivial I Jalving (UW-Madison) Plasmo.jl Decentralized control JuMP Meetup June / 25

9 Some existing modeling frameworks Modelica Components, hierarchies, architectures (highly abstracted) Designed for simulation (Optimica extension does some optimization) Write connectors for coupling (I always found this difficult) gproms Equation oriented chemical flowsheeting software Custom modeling language Commercial Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

10 Revisiting our Goals Model encapsulation Modularity and reuse Navigate solutions to complex optimization problems Facilitate modeling of communicating systems Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

11 The Power of Abstraction - Graphs Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

12 Relevant Graph Concepts Graph Definition A graph (G) is a finite set V(G) of vertices (nodes) and a finite family E(G) of pairs of elements of V(G) called edges Vertex Edge A A is a subgraph of B B The degree of a node is specific to its graph Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

13 Graph Based Modeling Plasmo associates model components with nodes and edges Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

14 Plasmo.jl - Key Features Key Features (some in progress): Associates models (JuMP Models) and linking information (constraints) with nodes and edges within a graph Exploits a subgraph abstraction to enable hierarchies of models (multiple graphs defined on a set of nodes) Uses LightGraphs.jl as the graph backend Accesses model information on nodes and edges Provides interfaces with structured solvers (PIPS, etc...) Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

15 Plasmo - Old syntax (still supported) using Plasmo graph = PlasmoGraph ( ) # Create a graph n1 = add_node! ( graph ) n2 = add_node! ( graph ) n3 = add_node! ( graph ) edge1 = add_edge! ( graph, n1, n2 ) edge2 = add_edge! ( graph, n1, n3 ) #Set component models setmodel! ( n1, simple_model ( ) ) setmodel! ( n2, simple_model ( ) ) setmodel! ( n3, simple_model ( ) ) # provide l i n k i n g i n f o r m a t i o n setcouplingfunction! ( graph, edge1, couplenodes ) setcouplingfunction! ( graph, edge2, couplenodes ) model = generate_model ( graph ) s e t s o l v e r ( model, I p o p t S o l v e r ( ) ) solve ( model ) function couplenodes (m: : Model, graph, edge (m, getconnectedfrom ( graph, edge ) [ : x ] == getconnectedto ( graph, edge [ : x ] ) ) end Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

16 New Syntax - In Progress using Plasmo # Create a graph m = GraphModel ( s o l v e r = I p o p t S o l v e r ( ) ) n1 = add_node! (m) n2 = add_node! (m) n3 = add_node! (m) edge1 = add_edge! (m, n1, n2 ) edge2 = add_edge! (m, n1, n3 ) #Set component models setmodel! ( n1, simple_model ( ) ) setmodel! ( n2, simple_model ( ) ) setmodel! ( n3, simple_model ( ) ) # l i n k the two ( edge1, getconnectedfrom (m, edge1 ) [ : x ] == getconnectedto ( edge1 ) [ : x ] ( edge2, getconnectedfrom (m, edge2 ) [ : x ] == getconnectedto ( edge2 ) [ : x ] ) solve (m) # solve w ith I p o p t # solve_pips (m, n1, [ n2, n3 ] ) # solve with PIPS NLP Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

17 Gas Networks θ l2 p l2 (L l2 ) = θ n3 θ l3 θ l11 f l1 (0) = f in l11 d θ n1 n 1 n 2 n 3 n 11 n 12 n 13 l 2 s l 1 θ n2 p l2 (0) = θ n2 + θ l2 l 11 f l1 (L l1 ) = f out l11 l 12 θ n13 N : Set of nodes in the gas network (junctions) L: Set of links (pipelines) S N : Set of gas supplies D N : Set of gas demands L a L: Set of active links (pipelines with compressors) L p L: Set of passive links (pipelines without compressors) Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

18 Gas Networks Mass and Momentum Balances on a Network p l (t, x) t f l (t, x) t + c2 f l (t, x) = 0, l L A l x + 2c2 f l (t, x) f l (t, x) c2 f l (t, x) 2 p l (t, x) p l (t, x) A l p l (t, x) x A l p l (t, x) 2 + A l x x = 8c2 λa l π 2 D 5 l f l (t, x) p l (t, x) f l(t, x), l L Compressor Power P l (t) = c p T f in,l ( (pin,l (t) + p l (t) p in,l (t) ) γ 1 γ Node Conservation f out,l (t) f in,l (t) + g i (t) l L rec n i Sn j Dn l L snd n Supply and Demand f deliver,n (t) f demand,n (t), n D 1 ), l L a d gas j (t) = 0, n N Boundary Conditions p l (0, t) = p in,l (t) + p l (t), l L a p l (0, t) = p in,l (t), l L p p l (L l, t) = p out,l (t), l L Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

19 Graph Based Modeling - Gas Networks The subgraph abstraction allows multiple couplings on the same node This can be used to build modular systems and couple them at higher levels Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

20 Graph Based Modeling - Coupled Networks m = GraphModel ( ) graph = getgraph (m) add_subgraph! ( graph, power_network ) add_subgraph! ( graph, gas_network ) generator = getnode ( power_network, : gen ) demand = getnode ( gas_network, : demand ) l i n k = add_edge! ( graph, generator, demand ( l i n k, getconnectedfrom ( graph, l i n k ) [ : Pgend ] <= getconnectedto ( graph, l i n k ) [ : f d e l i v e r ] ) Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

21 Graph Based Modeling - Coupled Networks Key Findings: Infrastructure models (graphs) can be developed independently and coupled within larger systems (graphs) Illinois Case Study: 7% more gas delivered to generators; 27% revenue increase versus uncoordinated case Uncoordinated case simulated by solving successive optimization problems Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

22 Multistage Stochastic Programming Our graph abstraction corresponds to the node-based abstraction in multistage stochastic programming Component models associated within nodes (scenarios) Link constraints propogate transition from stage to stage Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

23 Embedding Graph Models Graph models can themselves be embedded as models in nodes or edges Simplifies construction of multiple layers in systems Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

24 Future Direction Generalize the model interface if possible (strictly uses JuMP) Find suitable abstraction for computational workflows Decentralized control Algorithmic strategies (e.g. scheduling and operations) Graph partitioning and model reduction Initialization strategies Simulation interfaces Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

25 Goals right now Finalize physical model abstraction Push first version to github Figure out a suitable graph communication abstraction Jalving (UW-Madison) Plasmo.jl JuMP Meetup June / 25

An Introduction to Software Architecture By David Garlan & Mary Shaw 94

An Introduction to Software Architecture By David Garlan & Mary Shaw 94 IMPORTANT NOTICE TO STUDENTS These slides are NOT to be used as a replacement for student notes. These slides are sometimes vague and incomplete on purpose to spark a class discussion An Introduction to

More information

An Introduction to Software Architecture. David Garlan & Mary Shaw 94

An Introduction to Software Architecture. David Garlan & Mary Shaw 94 An Introduction to Software Architecture David Garlan & Mary Shaw 94 Motivation Motivation An increase in (system) size and complexity structural issues communication (type, protocol) synchronization data

More information

"Dynamic Distribution System, a new Architecture for the Integrated Grid"

Dynamic Distribution System, a new Architecture for the Integrated Grid 1 "Dynamic Distribution System, a new Architecture for the Integrated Grid" Bruce Beihoff Tom Jahns Bob Lasseter University of Wisconsin Madison IEEE PES 2015 - Panel July 29,2015 2 Panel Presentation

More information

Software Architecture

Software Architecture Software Architecture Lecture 6 Event Systems Rob Pettit George Mason University SWE 443 Software Architecture Event Systems 1 previously data flow and call-return styles data flow batch sequential dataflow

More information

User Interface Design. Slide Set to accompany. Software Engineering: A Practitioner s Approach, 7/e by Roger S. Pressman

User Interface Design. Slide Set to accompany. Software Engineering: A Practitioner s Approach, 7/e by Roger S. Pressman Chapter 11 User Interface Design Slide Set to accompany Software Engineering: A Practitioner s Approach, 7/e by Roger S. Pressman Slides copyright 1996, 2001, 2005, 2009 by Roger S. Pressman For non-profit

More information

pyomo.dae: A Modeling and Automatic Discretization Framework for Optimization with Differential and Algebraic Equations

pyomo.dae: A Modeling and Automatic Discretization Framework for Optimization with Differential and Algebraic Equations Noname manuscript No. (will be inserted by the editor) pyomo.dae: A Modeling and Automatic Discretization Framework for Optimization with Differential and Algebraic Equations Bethany Nicholson John D.

More information

NUMERICAL VISCOSITY. Convergent Science White Paper. COPYRIGHT 2017 CONVERGENT SCIENCE. All rights reserved.

NUMERICAL VISCOSITY. Convergent Science White Paper. COPYRIGHT 2017 CONVERGENT SCIENCE. All rights reserved. Convergent Science White Paper COPYRIGHT 2017 CONVERGENT SCIENCE. All rights reserved. This document contains information that is proprietary to Convergent Science. Public dissemination of this document

More information

Partner Presentation Faster and Smarter Data Warehouses with Oracle OLAP 11g

Partner Presentation Faster and Smarter Data Warehouses with Oracle OLAP 11g Partner Presentation Faster and Smarter Data Warehouses with Oracle OLAP 11g Vlamis Software Solutions, Inc. Founded in 1992 in Kansas City, Missouri Oracle Partner and reseller since 1995 Specializes

More information

Part I: Preliminaries 24

Part I: Preliminaries 24 Contents Preface......................................... 15 Acknowledgements................................... 22 Part I: Preliminaries 24 1. Basics of Software Testing 25 1.1. Humans, errors, and testing.............................

More information

Motivation Thermal Modeling

Motivation Thermal Modeling Motivation Thermal Modeling First approach (Physical Buildings) Second Approach (Simulation Models) Model-Based Optimal Control Design Robust MPC Comparing Different Control Strategies Co-design of Control

More information

CHAPTER 5 GENERAL OOP CONCEPTS

CHAPTER 5 GENERAL OOP CONCEPTS CHAPTER 5 GENERAL OOP CONCEPTS EVOLUTION OF SOFTWARE A PROGRAMMING LANGUAGE SHOULD SERVE 2 RELATED PURPOSES : 1. It should provide a vehicle for programmer to specify actions to be executed. 2. It should

More information

Development of an Integrated Computational Simulation Method for Fluid Driven Structure Movement and Acoustics

Development of an Integrated Computational Simulation Method for Fluid Driven Structure Movement and Acoustics Development of an Integrated Computational Simulation Method for Fluid Driven Structure Movement and Acoustics I. Pantle Fachgebiet Strömungsmaschinen Karlsruher Institut für Technologie KIT Motivation

More information

Object Oriented Simulation of Multiphase Flow

Object Oriented Simulation of Multiphase Flow Object Oriented Simulation of Multiphase Flow P.Klebert and O.J.Nydal Norwegian University of Science and Technology (NTNU) 7491 Trondheim Norway Abstract Pipelines in offshore oil and gas production systems

More information

Stochastic Separable Mixed-Integer Nonlinear Programming via Nonconvex Generalized Benders Decomposition

Stochastic Separable Mixed-Integer Nonlinear Programming via Nonconvex Generalized Benders Decomposition Stochastic Separable Mixed-Integer Nonlinear Programming via Nonconvex Generalized Benders Decomposition Xiang Li Process Systems Engineering Laboratory Department of Chemical Engineering Massachusetts

More information

Model based soft-sensors based on OPC Unified Architecture

Model based soft-sensors based on OPC Unified Architecture Model based soft-sensors based on OPC Unified Architecture Paolo Greppi, consultant, 3iP, Italy POWER-GEN Europe 2010 Conference June 10th, 2010 Amsterdam Presentation outline The problem Old solution

More information

Modeling, Simulation and Analysis of Integrated Building Energy and Control Systems. Michael Wetter. October 8, 2009

Modeling, Simulation and Analysis of Integrated Building Energy and Control Systems. Michael Wetter. October 8, 2009 Modeling, Simulation and Analysis of Integrated Building Energy and Control Systems Michael Wetter Simulation Research Group Building Technologies Department Energy and Environmental Technologies Division

More information

AC : USING A SCRIPTING LANGUAGE FOR DYNAMIC PROGRAMMING

AC : USING A SCRIPTING LANGUAGE FOR DYNAMIC PROGRAMMING AC 2008-2623: USING A SCRIPTING LANGUAGE FOR DYNAMIC PROGRAMMING Louis Plebani, Lehigh University American Society for Engineering Education, 2008 Page 13.1325.1 Using a Scripting Language for Dynamic

More information

Generalized and Bounded Policy Iteration for Interactive POMDPs

Generalized and Bounded Policy Iteration for Interactive POMDPs Generalized and Bounded Policy Iteration for Interactive POMDPs Ekhlas Sonu and Prashant Doshi THINC Lab, Dept. of Computer Science University Of Georgia Athens, GA 30602 esonu@uga.edu, pdoshi@cs.uga.edu

More information

R. Franke, PSP-A24, OpenModelica Annual Workshop 2015 Mathematical Optimization of Dynamic Systems with OpenModelica. ABB February 2, 2015

R. Franke, PSP-A24, OpenModelica Annual Workshop 2015 Mathematical Optimization of Dynamic Systems with OpenModelica. ABB February 2, 2015 R. Frane, PSP-A24, 02.02.2015 OpenModelica Annual Worshop 2015 Mathematical Optimization of Dynamic Systems with OpenModelica Slide 1 Overview Introduction to ABB OPTIMAX DrumBoiler example 1. Setpoint

More information

Balancing Transport and Physical Layers in Wireless Ad Hoc Networks: Jointly Optimal Congestion Control and Power Control

Balancing Transport and Physical Layers in Wireless Ad Hoc Networks: Jointly Optimal Congestion Control and Power Control Balancing Transport and Physical Layers in Wireless Ad Hoc Networks: Jointly Optimal Congestion Control and Power Control Mung Chiang Electrical Engineering Department, Princeton University NRL/NATO Workshop

More information

Using IP Addressing in the Network Design

Using IP Addressing in the Network Design Using IP Addressing in the Network Design Designing and Supporting Computer Networks Chapter 6 Version 4.0 2006 Cisco Systems, Inc. All rights reserved. Cisco Public 1 Objectives Describe the use of a

More information

Introduction to Linear Programming. Algorithmic and Geometric Foundations of Optimization

Introduction to Linear Programming. Algorithmic and Geometric Foundations of Optimization Introduction to Linear Programming Algorithmic and Geometric Foundations of Optimization Optimization and Linear Programming Mathematical programming is a class of methods for solving problems which ask

More information

Where is ML type inference headed?

Where is ML type inference headed? 1 Constraint solving meets local shape inference September 2005 2 Types are good A type is a concise description of the behavior of a program fragment. Typechecking provides safety or security guarantees.

More information

Cisco SAN Analytics and SAN Telemetry Streaming

Cisco SAN Analytics and SAN Telemetry Streaming Cisco SAN Analytics and SAN Telemetry Streaming A deeper look at enterprise storage infrastructure The enterprise storage industry is going through a historic transformation. On one end, deep adoption

More information

DAE Tools: An equation-oriented process modelling and optimization software

DAE Tools: An equation-oriented process modelling and optimization software DAE Tools: An equation-oriented process modelling and optimization software Introduction DAE Tools Project, http://www.daetools.com 1 December 2013 Outline 1 Intro 2 3 4 General Info Motivation Main features

More information

Fluent User Services Center

Fluent User Services Center Solver Settings 5-1 Using the Solver Setting Solver Parameters Convergence Definition Monitoring Stability Accelerating Convergence Accuracy Grid Independence Adaption Appendix: Background Finite Volume

More information

Free Surface Flow Simulations

Free Surface Flow Simulations Free Surface Flow Simulations Hrvoje Jasak h.jasak@wikki.co.uk Wikki Ltd. United Kingdom 11/Jan/2005 Free Surface Flow Simulations p.1/26 Outline Objective Present two numerical modelling approaches for

More information

System Identification Algorithms and Techniques for Systems Biology

System Identification Algorithms and Techniques for Systems Biology System Identification Algorithms and Techniques for Systems Biology by c Choujun Zhan A Thesis submitted to the School of Graduate Studies in partial fulfillment of the requirements for the degree of Doctor

More information

One-Shot DRC within a Fine-Grain Physical Verification Platform for advanced process nodes

One-Shot DRC within a Fine-Grain Physical Verification Platform for advanced process nodes One-Shot DRC within a Fine-Grain Physical Verification Platform for advanced process nodes Last updated: May, 2017 To meet the challenge of nano-scale, deep sub-wavelength processes, innovative One -Shot

More information

ACCELERATING STRUCTURAL ANALYSIS WITH THE RB-FEA WORKFLOW. Application Note

ACCELERATING STRUCTURAL ANALYSIS WITH THE RB-FEA WORKFLOW. Application Note ACCELERATING STRUCTURAL ANALYSIS WITH THE RB-FEA WORKFLOW Application Note Accelerating Structural Analysis with the RB-FEA Workflow OVERVIEW Akselos Integra streamlines simulation through its parametrized

More information

CLOSING THE DESIGN CYCLE LOOP WITH EXECUTABLE REQUIREMENTS AND OSLC

CLOSING THE DESIGN CYCLE LOOP WITH EXECUTABLE REQUIREMENTS AND OSLC CLOSING THE DESIGN CYCLE LOOP WITH EXECUTABLE REQUIREMENTS AND OSLC Hubertus Tummescheit, Modelon Bob Sherman, Procter & Gamble Juan Llorens, The Reuse Company INCOSE IW 2017 MBSE Workshop 2017-01-27 1

More information

Hybrid Agent-Landscape Model Composition

Hybrid Agent-Landscape Model Composition Hybrid Agent-Landscape Model Composition Gary Mayer, Hessam Sarjoughian, Eowyn Allen Presented at the 1 st CSE Student Research Expo Hybrid Agent-Landscape Models Hybrid : both the human and environmental

More information

DISTRIBUTED SYSTEMS Principles and Paradigms Second Edition ANDREW S. TANENBAUM MAARTEN VAN STEEN. Chapter 1. Introduction

DISTRIBUTED SYSTEMS Principles and Paradigms Second Edition ANDREW S. TANENBAUM MAARTEN VAN STEEN. Chapter 1. Introduction DISTRIBUTED SYSTEMS Principles and Paradigms Second Edition ANDREW S. TANENBAUM MAARTEN VAN STEEN Chapter 1 Introduction Definition of a Distributed System (1) A distributed system is: A collection of

More information

Regression Solver. User Manual. Process Design and Gas Processing Laboratory Illinois Institute of Technology Chicago, IL,

Regression Solver. User Manual. Process Design and Gas Processing Laboratory Illinois Institute of Technology Chicago, IL, Regression Solver User Manual Process Design and Gas Processing Laboratory Illinois Institute of Technology Chicago, IL, 60616. Copyright 2012-2016. All rights reserved. Introduction Regression Solver

More information

Parallel Adaptive Tsunami Modelling with Triangular Discontinuous Galerkin Schemes

Parallel Adaptive Tsunami Modelling with Triangular Discontinuous Galerkin Schemes Parallel Adaptive Tsunami Modelling with Triangular Discontinuous Galerkin Schemes Stefan Vater 1 Kaveh Rahnema 2 Jörn Behrens 1 Michael Bader 2 1 Universität Hamburg 2014 PDES Workshop 2 TU München Partial

More information

Generic Topology Mapping Strategies for Large-scale Parallel Architectures

Generic Topology Mapping Strategies for Large-scale Parallel Architectures Generic Topology Mapping Strategies for Large-scale Parallel Architectures Torsten Hoefler and Marc Snir Scientific talk at ICS 11, Tucson, AZ, USA, June 1 st 2011, Hierarchical Sparse Networks are Ubiquitous

More information

OPEN CHANNEL FLOW. An Introduction. -

OPEN CHANNEL FLOW. An Introduction.   - OPEN CHANNEL FLOW An Introduction http://tsaad.utsi.edu - tsaad@utsi.edu OUTLINE General characteristics Surface Waves & Froude Number Effects Types of Channel flows The Hydraulic Jump Conclusion General

More information

RESTORE: REUSING RESULTS OF MAPREDUCE JOBS. Presented by: Ahmed Elbagoury

RESTORE: REUSING RESULTS OF MAPREDUCE JOBS. Presented by: Ahmed Elbagoury RESTORE: REUSING RESULTS OF MAPREDUCE JOBS Presented by: Ahmed Elbagoury Outline Background & Motivation What is Restore? Types of Result Reuse System Architecture Experiments Conclusion Discussion Background

More information

Modular Platform Architecture for Small Satellites

Modular Platform Architecture for Small Satellites Modular Platform Architecture for Small Satellites Quinn Young Space Dynamics Laboratory Utah State University Research Foundation 1695 North Research Park Way, North Logan, UT 84341; (435) 797-4120 quinn.young@sdl.usu.edu

More information

PoS(eIeS2013)008. From Large Scale to Cloud Computing. Speaker. Pooyan Dadvand 1. Sònia Sagristà. Eugenio Oñate

PoS(eIeS2013)008. From Large Scale to Cloud Computing. Speaker. Pooyan Dadvand 1. Sònia Sagristà. Eugenio Oñate 1 International Center for Numerical Methods in Engineering (CIMNE) Edificio C1, Campus Norte UPC, Gran Capitán s/n, 08034 Barcelona, Spain E-mail: pooyan@cimne.upc.edu Sònia Sagristà International Center

More information

06. Analysis Modeling

06. Analysis Modeling 06. Analysis Modeling Division of Computer Science, College of Computing Hanyang University ERICA Campus 1 st Semester 2017 Overview of Analysis Modeling 1 Requirement Analysis 2 Analysis Modeling Approaches

More information

Abstract Fortran in NIMROD Discussion. NIMROD team meeting Sherwood, April 21st 2018 Auburn, AL

Abstract Fortran in NIMROD Discussion. NIMROD team meeting Sherwood, April 21st 2018 Auburn, AL Abstract Fortran in NIMROD Discussion NIMROD team meeting Sherwood, April 21st 2018 Auburn, AL What is abstraction? Why should we do it? With abstraction we can rewrite hard-coded blocks loop from this:

More information

Grid Computing Systems: A Survey and Taxonomy

Grid Computing Systems: A Survey and Taxonomy Grid Computing Systems: A Survey and Taxonomy Material for this lecture from: A Survey and Taxonomy of Resource Management Systems for Grid Computing Systems, K. Krauter, R. Buyya, M. Maheswaran, CS Technical

More information

Part 7 - Object Oriented Concepts Classes, Objects, Properties and Methods

Part 7 - Object Oriented Concepts Classes, Objects, Properties and Methods Part 7 - Object Oriented Concepts Classes, Objects, Properties and Methods Object Orientated Paradigm... 2 Abstract Data Types (ADT) & Encapsulation... 3 Encapsulation... 5 Classes and Objects... 6 Methods

More information

ICS 52: Introduction to Software Engineering

ICS 52: Introduction to Software Engineering ICS 52: Introduction to Software Engineering Fall Quarter 2004 Professor Richard N. Taylor Lecture Notes Week 3: Architectures http://www.ics.uci.edu/~taylor/ics_52_fq04/syllabus.html Copyright 2004, Richard

More information

Chapter 12 (revised by JAS)

Chapter 12 (revised by JAS) Chapter 12 (revised by JAS) Pattern-Based Design Slide Set to accompany Software Engineering: A Practitionerʼs Approach, 7/e by Roger S. Pressman Slides copyright 1996, 2001, 2005, 2009 by Roger S. Pressman

More information

Top-Down Network Design

Top-Down Network Design Top-Down Network Design Chapter Five Designing a Network Topology Original slides copyright by Cisco Press & Priscilla Oppenheimer Network Topology Design Issues Hierarchy Redundancy Modularity Well-defined

More information

Lattice Semiconductor Design Floorplanning

Lattice Semiconductor Design Floorplanning September 2012 Introduction Technical Note TN1010 Lattice Semiconductor s isplever software, together with Lattice Semiconductor s catalog of programmable devices, provides options to help meet design

More information

A Grid Web Portal for Aerospace

A Grid Web Portal for Aerospace A Grid Web Portal for Aerospace Sang Boem Lim*, Joobum Kim*, Nam Gyu Kim*, June H. Lee*, Chongam Kim, Yoonhee Kim * Supercomputing Application Technology Department, Korea Institute of Science and Technology

More information

Chapter 1 Introduction

Chapter 1 Introduction Chapter 1 Introduction DISTRIBUTED SYSTEMS (ddist) 2007 Plan Definition Characteristics of distributed systems Main types of distributed systems Definition of a Distributed System (1) A distributed system

More information

MOSAIC: an Online Platform for Combined Process Model and Measurement Data Management

MOSAIC: an Online Platform for Combined Process Model and Measurement Data Management MOSAIC: an Online Platform for Combined Process Model and Measurement Data Management Erik Esche*, David Müller**, Robert Kraus***, Sandra Fillinger ****, Victor Alejandro Merchan Restrepo*****, Günter

More information

Minimal Equation Sets for Output Computation in Object-Oriented Models

Minimal Equation Sets for Output Computation in Object-Oriented Models Minimal Equation Sets for Output Computation in Object-Oriented Models Vincenzo Manzoni Francesco Casella Dipartimento di Elettronica e Informazione, Politecnico di Milano Piazza Leonardo da Vinci 3, 033

More information

Shape of Things to Come: Next-Gen Physics Deep Dive

Shape of Things to Come: Next-Gen Physics Deep Dive Shape of Things to Come: Next-Gen Physics Deep Dive Jean Pierre Bordes NVIDIA Corporation Free PhysX on CUDA PhysX by NVIDIA since March 2008 PhysX on CUDA available: August 2008 GPU PhysX in Games Physical

More information

From Think Like a Vertex to Think Like a Graph. Yuanyuan Tian, Andrey Balmin, Severin Andreas Corsten, Shirish Tatikonda, John McPherson

From Think Like a Vertex to Think Like a Graph. Yuanyuan Tian, Andrey Balmin, Severin Andreas Corsten, Shirish Tatikonda, John McPherson From Think Like a Vertex to Think Like a Graph Yuanyuan Tian, Andrey Balmin, Severin Andreas Corsten, Shirish Tatikonda, John McPherson Large Scale Graph Processing Graph data is everywhere and growing

More information

An Introduction to Software Architecture By David Garlan & Mary Shaw 94

An Introduction to Software Architecture By David Garlan & Mary Shaw 94 IMPORTANT NOTICE TO STUDENTS These slides are NOT to be used as a replacement for student notes. These slides are sometimes vague and incomplete on purpose to spark a class discussion An Introduction to

More information

Learning Motor Behaviors: Past & Present Work

Learning Motor Behaviors: Past & Present Work Stefan Schaal Computer Science & Neuroscience University of Southern California, Los Angeles & ATR Computational Neuroscience Laboratory Kyoto, Japan sschaal@usc.edu http://www-clmc.usc.edu Learning Motor

More information

WHITEPAPER. Pipelining Machine Learning Models Together

WHITEPAPER. Pipelining Machine Learning Models Together WHITEPAPER Pipelining Machine Learning Models Together Table of Contents Introduction 2 Performance and Organizational Benefits of Pipelining 4 Practical Use Case: Twitter Sentiment Analysis 5 Practical

More information

Diffusion and Clustering on Large Graphs

Diffusion and Clustering on Large Graphs Diffusion and Clustering on Large Graphs Alexander Tsiatas Thesis Proposal / Advancement Exam 8 December 2011 Introduction Graphs are omnipresent in the real world both natural and man-made Examples of

More information

Network-on-chip (NOC) Topologies

Network-on-chip (NOC) Topologies Network-on-chip (NOC) Topologies 1 Network Topology Static arrangement of channels and nodes in an interconnection network The roads over which packets travel Topology chosen based on cost and performance

More information

Cisco Prime Cable Provisioning 5.1

Cisco Prime Cable Provisioning 5.1 Data Sheet Cisco Prime Cable Provisioning 5.1 Cable service providers face tremendous challenges in keeping pace with the rapid evolution of residential subscriber services. In light of intense market

More information

Actor-eUML for Concurrent Programming

Actor-eUML for Concurrent Programming Actor-eUML for Concurrent Programming Kevin Marth and Shangping Ren Illinois Institute of Technology Department of Computer Science Chicago, IL USA martkev@iit.edu Abstract. The advent of multi-core processors

More information

Computer Simulation And Modeling

Computer Simulation And Modeling Computer Simulation And Modeling The key to increased productivity in Scientific and Engineering analysis Professor Ralph C. Huntsinger California State University, Chico USA Bialystok Technical University

More information

University of Toronto Department of Mathematics

University of Toronto Department of Mathematics University of Toronto Department of Mathematics MAT332H1F, Graph Theory Midterm, October 21, 2014 Instructor: Kasra Rafi First Last Student Number Instructions: No aids allowed. Write solutions on the

More information

Junction Trees and Chordal Graphs

Junction Trees and Chordal Graphs Graphical Models, Lecture 6, Michaelmas Term 2011 October 24, 2011 Decomposability Factorization of Markov distributions Explicit formula for MLE Consider an undirected graph G = (V, E). A partitioning

More information

Finding and Visualizing Graph Clusters Using PageRank Optimization. Fan Chung and Alexander Tsiatas, UCSD WAW 2010

Finding and Visualizing Graph Clusters Using PageRank Optimization. Fan Chung and Alexander Tsiatas, UCSD WAW 2010 Finding and Visualizing Graph Clusters Using PageRank Optimization Fan Chung and Alexander Tsiatas, UCSD WAW 2010 What is graph clustering? The division of a graph into several partitions. Clusters should

More information

Introduction to Programmable Controllers D R. TAREK TUTUNJI P H I L A D E L P H I A U N I V E R S I T Y, J O R D A N

Introduction to Programmable Controllers D R. TAREK TUTUNJI P H I L A D E L P H I A U N I V E R S I T Y, J O R D A N Introduction to Programmable Controllers D R. TAREK TUTUNJI P H I L A D E L P H I A U N I V E R S I T Y, J O R D A N Definition Programmable logic controllers, also called programmable controllers or

More information

Chapter 8: Class and Method Design

Chapter 8: Class and Method Design Chapter 8: Class and Method Design Objectives Become familiar with coupling, cohesion, and connascence. Be able to specify, restructure, and optimize object designs. Be able to identify the reuse of predefined

More information

Topology Optimization and JuMP

Topology Optimization and JuMP Immense Potential and Challenges School of Engineering and Information Technology UNSW Canberra June 28, 2018 Introduction About Me First year PhD student at UNSW Canberra Multidisciplinary design optimization

More information

Chapter Outline. Chapter 2 Distributed Information Systems Architecture. Distributed transactions (quick refresh) Layers of an information system

Chapter Outline. Chapter 2 Distributed Information Systems Architecture. Distributed transactions (quick refresh) Layers of an information system Prof. Dr.-Ing. Stefan Deßloch AG Heterogene Informationssysteme Geb. 36, Raum 329 Tel. 0631/205 3275 dessloch@informatik.uni-kl.de Chapter 2 Distributed Information Systems Architecture Chapter Outline

More information

Product Engineering Optimizer

Product Engineering Optimizer CATIA V5 Training Foils Product Engineering Optimizer Version 5 Release 19 January 2009 EDU_CAT_EN_PEO_FI_V5R19 1 About this course Objectives of the course Upon completion of this course, you will learn

More information

Cache Controller with Enhanced Features using Verilog HDL

Cache Controller with Enhanced Features using Verilog HDL Cache Controller with Enhanced Features using Verilog HDL Prof. V. B. Baru 1, Sweety Pinjani 2 Assistant Professor, Dept. of ECE, Sinhgad College of Engineering, Vadgaon (BK), Pune, India 1 PG Student

More information

Functional Design of Web Applications. (partially, Chapter 7)

Functional Design of Web Applications. (partially, Chapter 7) Functional Design of Web Applications (partially, Chapter 7) Functional Design: An Overview Users of modern WebApps expect that robust content will be coupled with sophisticated functionality The advanced

More information

System Design. Design: HOW to implement a system

System Design. Design: HOW to implement a system System Design Design: HOW to implement a system Goals: Satisfy the requirements Satisfy the customer Reduce development costs Provide reliability Support maintainability Plan for future modifications 1

More information

1.2 Numerical Solutions of Flow Problems

1.2 Numerical Solutions of Flow Problems 1.2 Numerical Solutions of Flow Problems DIFFERENTIAL EQUATIONS OF MOTION FOR A SIMPLIFIED FLOW PROBLEM Continuity equation for incompressible flow: 0 Momentum (Navier-Stokes) equations for a Newtonian

More information

An HPC Implementation of the Finite Element Method

An HPC Implementation of the Finite Element Method An HPC Implementation of the Finite Element Method John Rugis Interdisciplinary research group: David Yule Physiology James Sneyd, Shawn Means, Di Zhu Mathematics John Rugis Computer Science Project funding:

More information

An Overview to Compiler Design. 2008/2/14 \course\cpeg421-08s\topic-1a.ppt 1

An Overview to Compiler Design. 2008/2/14 \course\cpeg421-08s\topic-1a.ppt 1 An Overview to Compiler Design 2008/2/14 \course\cpeg421-08s\topic-1a.ppt 1 Outline An Overview of Compiler Structure Front End Middle End Back End 2008/2/14 \course\cpeg421-08s\topic-1a.ppt 2 Reading

More information

ECE 4750 Computer Architecture, Fall 2017 Lab 1: Iterative Integer Multiplier

ECE 4750 Computer Architecture, Fall 2017 Lab 1: Iterative Integer Multiplier School of Electrical and Computer Engineering Cornell University revision: 2017-08-31-12-21 The first lab assignment is a warmup lab where you will design two implementations of an integer iterative multiplier:

More information

Design Patterns. Gunnar Gotshalks A4-1

Design Patterns. Gunnar Gotshalks A4-1 Design Patterns A4-1 On Design Patterns A design pattern systematically names, explains and evaluates an important and recurring design problem and its solution Good designers know not to solve every problem

More information

Design and Construction of Relational Database for Structural Modeling Verification and Validation. Weiju Ren, Ph. D.

Design and Construction of Relational Database for Structural Modeling Verification and Validation. Weiju Ren, Ph. D. Design and Construction of Relational Database for Structural Modeling Verification and Validation Weiju Ren, Ph. D. Oak Ridge National Laboratory renw@ornl.gov ASME Verification and Validation Symposium

More information

Transfinite Interpolation Based Analysis

Transfinite Interpolation Based Analysis Transfinite Interpolation Based Analysis Nathan Collier 1 V.M. Calo 1 Javier Principe 2 1 King Abdullah University of Science and Technology 2 International Center for Numerical Methods in Engineering

More information

Optimal motion trajectories. Physically based motion transformation. Realistic character animation with control. Highly dynamic motion

Optimal motion trajectories. Physically based motion transformation. Realistic character animation with control. Highly dynamic motion Realistic character animation with control Optimal motion trajectories Physically based motion transformation, Popovi! and Witkin Synthesis of complex dynamic character motion from simple animation, Liu

More information

IN5050: Programming heterogeneous multi-core processors Thinking Parallel

IN5050: Programming heterogeneous multi-core processors Thinking Parallel IN5050: Programming heterogeneous multi-core processors Thinking Parallel 28/8-2018 Designing and Building Parallel Programs Ian Foster s framework proposal develop intuition as to what constitutes a good

More information

Design Patterns for Net- Centric Applications

Design Patterns for Net- Centric Applications Design Patterns for Net- Centric Applications Seth Landsman, Ph.D. Sandeep Mulgund, Ph.D. The MITRE Corporation Bedford, MA 01730 Overview Introduction Design Patterns Data Interaction Patterns Core System

More information

The Weisfeiler-Lehman Kernel

The Weisfeiler-Lehman Kernel The Weisfeiler-Lehman Kernel Karsten Borgwardt and Nino Shervashidze Machine Learning and Computational Biology Research Group, Max Planck Institute for Biological Cybernetics and Max Planck Institute

More information

Software Architecture

Software Architecture Software Architecture Architectural Design and Patterns. Standard Architectures. Dr. Philipp Leitner @xleitix University of Zurich, Switzerland software evolution & architecture lab Architecting, the planning

More information

Open Software Standards for Next- Generation Community Satellite Software Packages June 2017

Open Software Standards for Next- Generation Community Satellite Software Packages June 2017 Atmospheric and Environmental Research www.aer.com Lexington, MA 2017 IMAP/ CSPP Users Group Meeting Open Software Standards for Next- Generation Community Satellite Software Packages June 2017 David Hogan

More information

Best Practices Workshop: Overset Meshing

Best Practices Workshop: Overset Meshing Best Practices Workshop: Overset Meshing Overview Introduction to Overset Meshes Range of Application Workflow Demonstrations and Best Practices What are Overset Meshes? Overset meshes are also known as

More information

Lect 7: DEVS Model Reuse and Schedule Conflict

Lect 7: DEVS Model Reuse and Schedule Conflict Lect 7: DEVS Model Reuse and Schedule Conflict Simulation Enge: Independent of Model 2 of 20 Model Execution Algorithm = Execution Enge = Simulation Enge Model and Simulation Enge should be dependent A

More information

A Fully Automated Faulttolerant. Distributed Video Processing and Off site Replication

A Fully Automated Faulttolerant. Distributed Video Processing and Off site Replication A Fully Automated Faulttolerant System for Distributed Video Processing and Off site Replication George Kola, Tevfik Kosar and Miron Livny University of Wisconsin-Madison June 2004 What is the talk about?

More information

COURSE 10962B: ADVANCED AUTOMATED ADMINISTRATION WITH WINDOWS POWERSHELL

COURSE 10962B: ADVANCED AUTOMATED ADMINISTRATION WITH WINDOWS POWERSHELL ABOUT THIS COURSE This three-day course is a follow on course from the 10961B: Automating Administration with Windows PowerShell course. It is built on Windows Server 2012 R2 and Windows 8.1 and while

More information

Keywords: TDC, Submarine, Torpedo, World War II

Keywords: TDC, Submarine, Torpedo, World War II Self Position Keeper Modeling Abstract During World War II, all the submarines of all warring nations used analog computers to assist submarine commanders with aiming straight-running torpedoes (e.g. UK

More information

Automated Refinement Checking of Asynchronous Processes. Rajeev Alur. University of Pennsylvania

Automated Refinement Checking of Asynchronous Processes. Rajeev Alur. University of Pennsylvania Automated Refinement Checking of Asynchronous Processes Rajeev Alur University of Pennsylvania www.cis.upenn.edu/~alur/ Intel Formal Verification Seminar, July 2001 Problem Refinement Checking Given two

More information

On Covering a Graph Optimally with Induced Subgraphs

On Covering a Graph Optimally with Induced Subgraphs On Covering a Graph Optimally with Induced Subgraphs Shripad Thite April 1, 006 Abstract We consider the problem of covering a graph with a given number of induced subgraphs so that the maximum number

More information

PorePy: A Python Simulation Tool for Fractured and Deformable Porous Media. Eirik Keilegavlen, Alessio Fumagalli, Runar Berge, Ivar Stefansson

PorePy: A Python Simulation Tool for Fractured and Deformable Porous Media. Eirik Keilegavlen, Alessio Fumagalli, Runar Berge, Ivar Stefansson PorePy: A Python Simulation Tool for Fractured and Deformable Porous Media Eirik Keilegavlen, Alessio Fumagalli, Runar Berge, Ivar Stefansson Summary Meshing and discretization of dynamics in fractured

More information

Math 443/543 Graph Theory Notes 11: Graph minors and Kuratowski s Theorem

Math 443/543 Graph Theory Notes 11: Graph minors and Kuratowski s Theorem Math 443/543 Graph Theory Notes 11: Graph minors and Kuratowski s Theorem David Glickenstein November 26, 2008 1 Graph minors Let s revisit some de nitions. Let G = (V; E) be a graph. De nition 1 Removing

More information

Dynamic Optimization in JModelica.org

Dynamic Optimization in JModelica.org Dynamic Optimization in JModelica.org Magnusson, Fredrik; Åkesson, Johan Published in: Processes DOI: 10.3390/pr3020471 2015 Document Version: Publisher's PDF, also known as Version of record Link to publication

More information

A Multifaceted Dependency Map of MySQL

A Multifaceted Dependency Map of MySQL Lattix White Paper A Multifaceted Dependency Map of MySQL Lattix White Paper April 2016 Copyright 2016 Lattix, Inc. All rights reserved Analyzing MySQL Introduction MySQL is one of the most popular open

More information

Picture This: Creating Controls on the Fly

Picture This: Creating Controls on the Fly Picture This: Creating Controls on the Fly by Benjamin A. Rayner Architect, Measurement & Automation Data Science Automation, Inc. USA Category: Prototype/Test Products Used: LabVIEW 8.2.1 The Challenge:

More information

Directions: 1) Delete this text box 2) Insert desired picture here

Directions: 1) Delete this text box 2) Insert desired picture here Directions: 1) Delete this text box 2) Insert desired picture here Multi-Disciplinary Applications using Overset Grid Technology in STAR-CCM+ CD-adapco Dmitry Pinaev, Frank Schäfer, Eberhard Schreck Outline

More information

OOFEM.ORG - PROJECT STATUS, CHALLENGES AND NEEDS

OOFEM.ORG - PROJECT STATUS, CHALLENGES AND NEEDS 6th European Conference on Computational Mechanics (ECCM 6) 7th European Conference on Computational Fluid Dynamics (ECFD 7) 1115 June 2018, Glasgow, UK OOFEM.ORG - PROJECT STATUS, CHALLENGES AND NEEDS

More information