-
Notifications
You must be signed in to change notification settings - Fork 7
/
20120111-ICERMGroup2.tex
164 lines (139 loc) · 4.71 KB
/
20120111-ICERMGroup2.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
% \documentclass[handout]{beamer}
\documentclass{beamer}
\mode<presentation>
{
\usetheme{default}
\usefonttheme[onlymath]{serif}
% \usetheme{Singapore}
% \usetheme{Warsaw}
% \usetheme{Malmoe}
% \useinnertheme{circles}
% \useoutertheme{infolines}
% \useinnertheme{rounded}
\setbeamercovered{transparent=5}
}
\usepackage[english]{babel}
\usepackage[latin1]{inputenc}
\usepackage{textpos,alltt,listings,multirow,ulem,siunitx}
\usepackage{pdfpages}
\newcommand\hmmax{0}
\newcommand\bmmax{0}
\usepackage{bm}
% font definitions, try \usepackage{ae} instead of the following
% three lines if you don't like this look
\usepackage{mathptmx}
\usepackage[scaled=.90]{helvet}
% \usepackage{courier}
\usepackage[T1]{fontenc}
\usepackage{tikz}
\usetikzlibrary[shapes,shapes.arrows,arrows,shapes.misc,fit,positioning]
% \usepackage{pgfpages}
% \pgfpagesuselayout{4 on 1}[a4paper,landscape,border shrink=5mm]
\usepackage{JedMacros}
\title{Library considerations}
\author{Jed Brown, Felipe Cruz, Matt Knepley, Richard Mills, John Owens, Jack Poulson, Ulrike Meier Yang}
% - Use the \inst command only if there are several affiliations.
% - Keep it simple, no one is interested in your street address.
\date{2012-01-11}
% This is only inserted into the PDF information catalog. Can be left
% out.
\subject{Talks}
% If you have a file called "university-logo-filename.xxx", where xxx
% is a graphic format that can be processed by latex or pdflatex,
% resp., then you can add a logo as follows:
% \pgfdeclareimage[height=0.5cm]{university-logo}{university-logo-filename}
% \logo{\pgfuseimage{university-logo}}
% Delete this, if you do not want the table of contents to pop up at
% the beginning of each subsection:
% \AtBeginSubsection[]
% {
% \begin{frame}<beamer>
% \frametitle{Outline}
% \tableofcontents[currentsection,currentsubsection]
% \end{frame}
% }
\AtBeginSection[]
{
\begin{frame}<beamer>
\frametitle{Outline}
\tableofcontents[currentsection]
\end{frame}
}
% If you wish to uncover everything in a step-wise fashion, uncomment
% the following command:
% \beamerdefaultoverlayspecification{<+->}
\begin{document}
\lstset{language=C}
\normalem
\begin{frame}
\titlepage
\end{frame}
\begin{frame}{Desired library features}
\begin{itemize}
\item Distribution control
\begin{itemize}
\item dense vs sparse
\item direct vs iterative solvers
\item hierarchical memory
\item different communicators for different physics/multigrid levels
\end{itemize}
\item Scheduling control
\begin{itemize}
\item when and where to do which computation?
\item how does user give advice?
\item how to degrade gracefully when resources are unavailable?
\end{itemize}
\item Asynchronous interfaces
\begin{itemize}
\item crossing module/library boundaries
\item how to ensure progress for operations that need user involvement
\item manage dependencies to prevent resource starvation causing long chains
\end{itemize}
\item Hierarchical interfaces/levels of abstraction
\item Composability and extensibility
\begin{itemize}
\item experimentation requires decoupling algorithms from problem specification
\item plugin-style extensibility often necessary for multiphysics coupling
\end{itemize}
\end{itemize}
\end{frame}
\begin{frame}{Concerns for library implementers}
\begin{itemize}
\item user/library interfaces
\item is ``performance portable'' dead?
\begin{itemize}
\item what can be dynamic?
\item specialization technology (c++ templates, light DSLs, Python codegen)
\end{itemize}
\item {\bf \large F}rameworks and runtimes
\item type sizes: 32 and 64-bit indices; single, double, quad precision
\item data structure conversion vs independence
\item loop and communication fusion
\begin{itemize}
\item compile-time versus run-time
\item BLAS-1 operations, $s$-step methods
\item aggregating parallel communication
\end{itemize}
\item Tool support
\begin{itemize}
\item functionality needed for adoption
\item adoption needed for hardening and funding
\end{itemize}
\item Derivatives: current solutions are quite intrusive
\end{itemize}
\end{frame}
\begin{frame}{Common themes and challenges}
\begin{itemize}
\item Configuration problem is getting harder
\item Run-time versus compile-time choices
\item Interfaces for extensibility are necessary, but delicate
\item Libraries need to be good citizens
\begin{itemize}
\item portable configuration systems
\item namespacing, restrictions to communicators, error handlers
\item algorithmic and performance diagnostics
\end{itemize}
\item Fine-grained parallelism, interoperability between threading models
\end{itemize}
\end{frame}
\end{document}