GRILLIX: a 3D Turbulence Code for Magnetic Fusion Devices Based on a Field Line

Total Page:16

File Type:pdf, Size:1020Kb

GRILLIX: a 3D Turbulence Code for Magnetic Fusion Devices Based on a Field Line GRILLIX: A 3D turbulence code for magnetic fusion devices based on a field line map Andreas Korbinian Stegmeir TECHNISCHE UNIVERSITAT¨ MUNCHEN¨ Max-Planck-Institut f¨urPlasmaphysik GRILLIX: A 3D turbulence code for magnetic fusion devices based on a field line map Andreas Korbinian Stegmeir Vollst¨andigerAbdruck der von der Fakult¨atf¨urPhysik der Technischen Universit¨atM¨unchen zur Erlangung des akademischen Grades eines Doktors der Naturwissenschaften (Dr. rer. nat.) genehmigten Dissertation. Vorsitzender: Univ.-Prof. Dr. Stephan Paul Pr¨uferder Dissertation: 1. Hon.-Prof. Dr. Sibylle G¨unter 2. Univ.-Prof. Dr. Katharina Krischer 3. Univ.-Prof. Dr. Karl-Heinz Spatschek (i.R.) Heinrich-Heine-Universit¨atD¨usseldorf Die Dissertation wurde am 13.10.2014 bei der Technischen Universit¨atM¨unchen eingereicht und durch die Fakult¨atf¨urPhysik am 13.01.2015 angenommen. Abstract The main contribution to the (anomalous) cross field transport in tokamaks is known to be due to turbulence and numerical codes are essential tools in order to predict transport levels and understand physical mechanisms. Whereas for the interior closed field line region sophisticated turbulence codes are already quite advanced, the outer region of a tokamak, i.e. the edge and scrape-off layer (SOL), still lacks such tools to a large extent. The presence of many spatio- temporal scales and the complex geometry in diverted machines pose a huge challenge for the modelling of the edge/SOL. In this work the newly developed code GRILLIX is presented, which is aimed to set a first milestone in the development of a 3D turbulence code for the edge/SOL. GRILLIX uses a simpli- fied physical model (Hasegawa-Wakatani), but is capable to treat the complex geometry across the separatrix. The usually employed field aligned coordinate systems are avoided by using a cylindrical grid (R; Z; ') which is Cartesian within poloidal planes. The discretisation of per- pendicular (w.r.t. the magnetic field) operators is straight forward and parallel operators are discretised with a field line map procedure, i.e. field line tracing from plane to plane and in- terpolation. Via a grid-sparsification in the toroidal direction the flute mode character of the solutions can be exploited computationally. Ultimately, tokamak geometries with an arbitrary poloidal cross section, including a separatrix, can be treated with GRILLIX. In non-field-aligned grids numerical diffusion, i.e. a spurious perpendicular coupling depending on parallel dynamics, arises unavoidably. This numerical diffusion can be fatal for codes, since the parallel dynamics is usually orders of magnitude faster than perpendicular dynamics in tokamaks. A new numerical scheme is developed and applied in GRILLIX which maintains the self-adjointness property of the parallel diffusion operator on the discrete level and reduces numerical diffusion drastically. Many benchmarks in several geometries are presented to validate the field line map approach in general and GRILLIX in special. First effects of the geometry in diverted machines on drift wave turbulence were studied with GRILLIX. Field aligned structures get strongly distorted as they enter the X-point region. Their perpendicular spatial extent decreases thereby drastically towards the X-point and are thus subject to enhanced dissipation. Since ultimately close to the X-point fluctuations die out, the X-point constitutes a kind of barrier for fluctuations. This mechanism is similar to the previously found resistive X-point mode. i Zusammenfassung Radialer (anormaler) Transport in Tokamaks wird haupts¨achlich durch turbulente Prozesse getra- gen und numerische Simulationsprogramme sind heutzutage ein unverzichtbares Werkzeug, um Vorhersagen ¨uber das Transportlevel zu treffen und um physikalische Mechanismen zu verstehen. W¨ahrendf¨urden inneren Bereich geschlossener Feldlinien, hochentwickelte Programme bereits zur Verf¨ugungstehen, gibt es f¨urden ¨außerenBereich (Rand und Absch¨alschicht) von Tokamaks kaum Ans¨atze.Das Vorhandensein vieler raumzeitlicher Skalen und eine komplexe Geometrie in Divertormaschinen stellen eine grosse Herausforderung beim Modellieren des Randbereiches dar. In dieser Arbeit wurde das Simulationsprogramm GRILLIX entwickelt, welches einen er- sten Meilenstein bei der Entwicklung eines 3D Turbulenzprogrammes f¨urden Rand und die Absch¨alschicht setzt. GRILLIX basiert noch auf einem vereinfachten physikalischen Model (Hasegawa-Wakatani), aber kann daf¨urauf die komplexe Geometrie angewandt werden, z.B. sind Simulationen ¨uber die Separatrix hinweg m¨oglich. Durch das Verwenden eines zylindrischen numerischen Gitters (R; Z; '), welches kartesisch innerhalb poloidaler Ebenen ist, werden die ¨ublicherweise verwendeten Feldlinien-angepassten Koordinaten umgangen. Zur Diskretisierung senkrechter (im Bezug auf die Magnetfeldlinien) Operatoren k¨onnendamit Standardmethoden herangezogen werden. Die Diskretisierung paralleler Operatoren erfolgt mittels Feldlinienabbil- dung, d.h. Feldlinien werden von Ebene zu Ebene verfolgt und Werte an den entsprechenden Stellen interpoliert. Strukturen sind ¨ublicherweise stark elongiert entlang Magnetfeldlinien und diese Eigenschaft wird ausgenutzt durch eine Ausd¨unnung des Rechengitters in toroidaler Rich- tung. Tokamak Geometrien mit beliebigem poloidalen Querschnitt, einschließlich einer Separa- trix, k¨onnenmit GRILLIX behandelt werden. In Rechengittern, die nicht Feldlinien angepasst sind, tritt numerische Diffusion auf, d.h. eine f¨alschliche numerische senkrechte Kopplung, die von der parallelen Dynamik abh¨angt.Diese nu- merische Diffusion kann fatal sein f¨urSimulationsprogramme, da die parallele Dynamik ¨ublicher- weise Gr¨oßenordnungen schneller ist als die senkrechte. Ein neues numerisches Schema wurde daher entwickelt und in GRILLIX angewendet, welches die Selbstadjungiertheit das paralle- len Diffusionsoperators auf der diskreten Ebene erh¨altund die numerische Diffusion drastisch reduziert. Viele Tests in verschiedenen Geometrien werden pr¨asentiert, um das Konzept der Feldlinienabbildung im Allgemeinen und GRILLIX im Speziellen zu verifizieren. Erste Geometrieeffekte in Maschinen mit Divertor auf Drift-Wellen Turbulenz wurden mit GRILLIX untersucht. Feldlininen ausgerichtete Strukturen werden stark deformiert in der N¨ahe des X-Punktes. Deren senkrechte Ausdehnung nimmt zum X-Punkt hin stark ab und Dissipation wird dominant. Der X-Punkt stellt letztlich eine Art Barriere f¨urFluktuation dar, da diese in der N¨ahedes X-Punktes praktisch verenden. Der Mechanismus ¨ahneltdamit der bereits zuvor gefundenen resistiven X-Punkt Mode. iii Acknowledgments Many ideas and most strategic decisions for this work were performed in meetings among David Coster, Karl Lackner, Klaus Hallatschek and me. Hence, I want to cordially thank all three of them equally for supervising me. Karl Lackner motivated not only this work but also myself during some difficult phases. With his overview and belief in the whole project we were always able to make the right strategic decisions. I want to thank David Coster for always having an open door for me and keeping me motivated at any time with many good words (and cookies on Friday). At many problems he could help with his often pragmatic view on things from distance. As well, I was also always able to discuss the smallest details with him. I want to thank Klaus Hallatschek for his brilliant ideas contributing to this work. His detailed and critical view on results was often very helpful for the next steps and I enjoyed working with him very much. Furthermore, Omar Maj helped me a lot at the development of the numerical scheme and his door was still open on many Fridays late. I also want to thank Matthias H¨olzlfor some help with the numerical scheme and his advice with the solver, Hans-Joachim Klingshirn, who helped me several times with computational issues, Michele Martone for his advice with the LIBRSB library, Andreas Kammel for exchanging his experience about the Hasegawa-Wakatani model with me and Emanuele Poli for his advice during the final stage of this work. A very special thanks goes to my office mate and good friend Johannes Grießhammer. Not only he helped me several times with frustrating bugs in the code and other computational issues, but also we were able to answer most questions and solve most problems in our discussions. Working with him was a perfect symbiosis (Maybe, I was even slightly parasitic). Finally, I thank my significant other Daniela Gl¨aserfor supporting me in every aspect. Not only once, she encouraged me during difficult phases. I want to thank my family for supporting and ultimately making all this possible for me. v Contents Abstract i Zusammenfassung iii Acknowledgments v 1. Introduction 1 1.1. Tokamaks . 2 1.2. Stability and transport . 3 1.3. Turbulence basics . 4 1.4. Edge and SOL . 6 1.5. Motivation and outline . 7 2. The Hasegawa-Wakatani model 11 2.1. Braginskii equations . 11 2.2. Derivation . 13 2.2.1. Robust simplifications . 13 2.2.2. Drift approximation . 13 2.2.3. Strong approximations . 16 2.2.4. The equations . 16 2.3. Linear dynamics . 19 2.3.1. Drift waves . 19 2.3.2. Ideal interchange instability . 21 2.4. Fluctuation free energy theorem . 22 2.5. Turbulence in a box . 23 3. Field line map 29 3.1. Field and flux aligned coordinates . 29 3.2. Field line map approach . 31 3.3. Field line tracing . 33 3.4. Parallel gradient . 35 3.4.1. Finite difference method . 35 3.4.2. Coordinate free representation . 35 3.5. Parallel diffusion . 36 3.5.1. Naive discretisation . 36 3.5.2. Support operator method . 36 3.6. A simple model problem . 39 3.6.1. Stencil . 39 3.6.2. Numerical analysis . 40 3.7. Benchmarks in 3D . 42 3.7.1. Basic test q = ................................ 43 3.7.2. q = ......................................1 43 6 1 vii Contents 3.8. Map distortion . 46 3.8.1. Remedy 1 . 47 3.8.2. Remedy 2 . 48 3.9. Conclusions . 50 4. GRILLIX: A field line map based 3D turbulence code 51 4.1. Environment and data flow . 51 4.2. main@GRILLIX . 53 4.2.1. Paralellisation scheme . 53 4.2.2. Initialisation phase . 53 4.2.3. Time stepping phase . 56 4.3. Computational resources and efficiency . 58 4.3.1. MPI scaling . 58 4.3.2.
Recommended publications
  • Easybuild Documentation Release 20210907.0
    EasyBuild Documentation Release 20210907.0 Ghent University Tue, 07 Sep 2021 08:55:41 Contents 1 What is EasyBuild? 3 2 Concepts and terminology 5 2.1 EasyBuild framework..........................................5 2.2 Easyblocks................................................6 2.3 Toolchains................................................7 2.3.1 system toolchain.......................................7 2.3.2 dummy toolchain (DEPRECATED) ..............................7 2.3.3 Common toolchains.......................................7 2.4 Easyconfig files..............................................7 2.5 Extensions................................................8 3 Typical workflow example: building and installing WRF9 3.1 Searching for available easyconfigs files.................................9 3.2 Getting an overview of planned installations.............................. 10 3.3 Installing a software stack........................................ 11 4 Getting started 13 4.1 Installing EasyBuild........................................... 13 4.1.1 Requirements.......................................... 14 4.1.2 Using pip to Install EasyBuild................................. 14 4.1.3 Installing EasyBuild with EasyBuild.............................. 17 4.1.4 Dependencies.......................................... 19 4.1.5 Sources............................................. 21 4.1.6 In case of installation issues. .................................. 22 4.2 Configuring EasyBuild.......................................... 22 4.2.1 Supported configuration
    [Show full text]
  • Interfacing Epetra to the RSB Sparse Matrix Format for Shared-Memory Performance
    Interfacing Epetra to the RSB sparse matrix format for shared-memory performance Michele Martone High Level Support Team Max Planck Institute for Plasma Physics Garching bei M¨unchen,Germany 5th European Trilinos User Group Meeting Garching bei M¨unchen, Germany April 19, 2016 1 / 18 Background: sparse kernels can be performance critical Sparse kernel Operation definition1 SpMV: Matrix-Vector Multiply \y β y + α A x" SpMV-T: (Transposed) \y β y + α AT x" SpSV : Triangular Solve \x α L−1 x" SpSV-T : (Transposed) \x α L−T x" Epetra_... Epetra_CrsMatrix I CRS (Compressed Row Storage) versatile and straightforward I class Epetra CrsMatrix can rely on Intel MKL 1A is a sparse matrix, L sparse triangular, x; y vectors or multi-vectors, α; β scalars. 2 / 18 Background: optimized sparse matrix classes Epetra_... Epetra_CrsMatrix Epetra_OskiMatrix I OSKI (Optimized Sparse Kernels Interface) library, by R.Vuduc I kernels for iterative methods, e.g. SpMV, SpSV I autotuning framework I OSKI + Epetra = class Epetra OskiMatrix, by I.Karlin 3 / 18 Background: librsb I a stable \Sparse BLAS"-like kernels library: I Sparse BLAS API (blas sparse.h) I own API (rsb.h) I LGPLv3 licensed I librsb-1.2 at http://librsb.sourceforge.net/ I OpenMP threaded 2 I C/C++/FORTRAN interface 2ISO-C-BINDING for own and F90 for Sparse BLAS 4 / 18 What can librsb do 3 I can be multiple times faster than Intel MKL's CRS in I symmetric/transposed sparse matrix multiply (SpMV) I multi-RHS (SpMM) I large matrices I threaded SpSV/SpSM (sparse triangular solve) I iterative methods ops: scaling, extraction, update, ..
    [Show full text]
  • Using Machine Learning to Improve Dense and Sparse Matrix Multiplication Kernels
    Iowa State University Capstones, Theses and Graduate Theses and Dissertations Dissertations 2019 Using machine learning to improve dense and sparse matrix multiplication kernels Brandon Groth Iowa State University Follow this and additional works at: https://lib.dr.iastate.edu/etd Part of the Applied Mathematics Commons, and the Computer Sciences Commons Recommended Citation Groth, Brandon, "Using machine learning to improve dense and sparse matrix multiplication kernels" (2019). Graduate Theses and Dissertations. 17688. https://lib.dr.iastate.edu/etd/17688 This Dissertation is brought to you for free and open access by the Iowa State University Capstones, Theses and Dissertations at Iowa State University Digital Repository. It has been accepted for inclusion in Graduate Theses and Dissertations by an authorized administrator of Iowa State University Digital Repository. For more information, please contact [email protected]. Using machine learning to improve dense and sparse matrix multiplication kernels by Brandon Micheal Groth A dissertation submitted to the graduate faculty in partial fulfillment of the requirements for the degree of DOCTOR OF PHILOSOPHY Major: Applied Mathematics Program of Study Committee: Glenn R. Luecke, Major Professor James Rossmanith Zhijun Wu Jin Tian Kris De Brabanter The student author, whose presentation of the scholarship herein was approved by the program of study committee, is solely responsible for the content of this dissertation. The Graduate College will ensure this dissertation is globally accessible and will not permit alterations after a degree is conferred. Iowa State University Ames, Iowa 2019 Copyright c Brandon Micheal Groth, 2019. All rights reserved. ii DEDICATION I would like to dedicate this thesis to my wife Maria and our puppy Tiger.
    [Show full text]
  • Best Practice Guide
    Best Practice Guide - Application porting and code-optimization activities for European HPC systems Sebastian Lührs, JSC, Forschungszentrum Jülich GmbH, Germany Björn Dick, HLRS, Germany Chris Johnson, EPCC, United Kingdom Luca Marsella, CSCS, Switzerland Gerald Mathias, LRZ, Germany Cristian Morales, BSC, Spain Lilit Axner, KTH, Sweden Anastasiia Shamakina, HLRS, Germany Hayk Shoukourian, LRZ, Germany 30-04-2020 1 Best Practice Guide - Application porting and code-optimization ac- tivities for European HPC systems Table of Contents 1. Introduction .............................................................................................................................. 3 2. EuroHPC Joint Undertaking ........................................................................................................ 3 3. Application porting and optimization activities in PRACE ................................................................ 4 3.1. Preparatory Access .......................................................................................................... 4 3.1.1. Overview ............................................................................................................ 4 3.1.2. Application and review processes ............................................................................ 4 3.1.3. Project white papers .............................................................................................. 4 3.2. SHAPE ........................................................................................................................
    [Show full text]
  • Efficient Multithreaded Untransposed, Transposed Or Symmetric Sparse
    Efficient Multithreaded Untransposed, Transposed or Symmetric Sparse Matrix-Vector Multiplication with the Recursive Sparse Blocks Format Michele Martonea,1,∗ aMax Planck Society Institute for Plasma Physics, Boltzmannstrasse 2, D-85748 Garching bei M¨unchen,Germany Abstract In earlier work we have introduced the \Recursive Sparse Blocks" (RSB) sparse matrix storage scheme oriented towards cache efficient matrix-vector multiplication (SpMV ) and triangular solution (SpSV ) on cache based shared memory parallel computers. Both the transposed (SpMV T ) and symmetric (SymSpMV ) matrix-vector multiply variants are supported. RSB stands for a meta-format: it recursively partitions a rectangular sparse matrix in quadrants; leaf submatrices are stored in an appropriate traditional format | either Compressed Sparse Rows (CSR) or Coordinate (COO). In this work, we compare the performance of our RSB implementation of SpMV, SpMV T, SymSpMV to that of the state-of-the-art Intel Math Kernel Library (MKL) CSR implementation on the recent Intel's Sandy Bridge processor. Our results with a few dozens of real world large matrices suggest the efficiency of the approach: in all of the cases, RSB's SymSpMV (and in most cases, SpMV T as well) took less than half of MKL CSR's time; SpMV 's advantage was smaller. Furthermore, RSB's SpMV T is more scalable than MKL's CSR, in that it performs almost as well as SpMV. Additionally, we include comparisons to the state-of-the art format Compressed Sparse Blocks (CSB) implementation. We observed RSB to be slightly superior to CSB in SpMV T, slightly inferior in SpMV, and better (in most cases by a factor of two or more) in SymSpMV.
    [Show full text]
  • Auto-Tuning Shared Memory Parallel Sparse BLAS Operations In
    View metadata, citation and similar papers at core.ac.uk brought to you by CORE Auto-tuning shared memory parallel Sparse BLAS provided by MPG.PuRe operations in librsb-1.2 Michele MARTONE ([email protected]) Max Planck Institute for Plasma Physics, Garching bei Munchen,¨ Germany Intro 2/9 HCSR 1.5e+04 Sparse BLAS (Basic Linear Algebra Subroutines) [2] speci- • 1/9 HCOO 2.0e+03 fies main kernels for iterative methods: – sparseMultiply byMatrix:“MM” 3/9 HCSR 1.3e+04 4/9 HCOO 2.0e+03 – sparse triangularSolve byMatrix:“SM” Untuned. Tuned for NRHS=1. Tuned for NRHS=3. Tuning example on symmetric matrix audikw 1. • Focus on MM:C C+αop(A) B , with Here only lower triangle, ca.1M 1M, 39M nonzeroes. • ← × • × 5/9 HCOO 9.8e+02 6/9 HCSR 1.0e+04 –A has dimensionsm k and is sparse(nnz nonzeroes) On a machine with 256 KB sized L2 cache. × • T H Left one (625 blocks, avg 491 KB) is before tuning. – op(A) can be either of A, A ,A (parameter transA) 9/9 HCOO 5.0e+03 • { } Middle one (271 blocks, avg 1133 KB) after tuning (1.057x – left hand side(LHS)B isk n, • × speedup, 6436.6 ops to amortize) forMV(MM with NRHS=1). right hand side(RHS)C isn m( n=NRHS), × 7/9 HCSR 8.5e+03 8/9 HCSR 7.0e+03 Right one (1319 blocks, avg 233 KB) after tuning (1.050x both dense (eventually with strided access incB, incC, ...) • speedup, 3996.2 ops to amortize) forMM with NRHS=3.
    [Show full text]
  • HLST Core Team Report 2013
    EUROFUSION WPISA-REP(16) 16107 R Hatzky et al. HLST Core Team Report 2013 REPORT This work has been carried out within the framework of the EUROfusion Con- sortium and has received funding from the Euratom research and training pro- gramme 2014-2018 under grant agreement No 633053. The views and opinions expressed herein do not necessarily reflect those of the European Commission. This document is intended for publication in the open literature. It is made available on the clear under- standing that it may not be further circulated and extracts or references may not be published prior to publication of the original when applicable, or without the consent of the Publications Officer, EUROfu- sion Programme Management Unit, Culham Science Centre, Abingdon, Oxon, OX14 3DB, UK or e-mail Publications.Offi[email protected] Enquiries about Copyright and reproduction should be addressed to the Publications Officer, EUROfu- sion Programme Management Unit, Culham Science Centre, Abingdon, Oxon, OX14 3DB, UK or e-mail Publications.Offi[email protected] The contents of this preprint and all other EUROfusion Preprints, Reports and Conference Papers are available to view online free at http://www.euro-fusionscipub.org. This site has full search facilities and e-mail alert options. In the JET specific papers the diagrams contained within the PDFs on this site are hyperlinked HLST Core Team Report 2013 Contents 1. Executive Summary ..............................................................................................4 1.1. Progress made by each core team member on allocated projects ................ 4 1.2. Further tasks and activities of the core team .................................................9 1.2.1. Dissemination .........................................................................................9 1.3.
    [Show full text]
  • PRIMME SVDS: a High-Performance Preconditioned SVD Solver For
    PRIMME SVDS: A HIGH-PERFORMANCE PRECONDITIONED SVD SOLVER FOR ACCURATE LARGE-SCALE COMPUTATIONS LINGFEI WU,∗ ELOY ROMERO,∗ ANDREAS STATHOPOULOS∗ Abstract. The increasing number of applications requiring the solution of large scale singular value problems has rekindled an interest in iterative methods for the SVD. Some promising recent ad- vances in large scale iterative methods are still plagued by slow convergence and accuracy limitations for computing smallest singular triplets. Furthermore, their current implementations in MATLAB cannot address the required large problems. Recently, we presented a preconditioned, two-stage method to effectively and accurately compute a small number of extreme singular triplets. In this re- search, we present a high-performance library, PRIMME SVDS, that implements our hybrid method based on the state-of-the-art eigensolver package PRIMME for both largest and smallest singular values. PRIMME SVDS fills a gap in production level software for computing the partial SVD, especially with preconditioning. The numerical experiments demonstrate its superior performance compared to other state-of-the-art software and its good parallel performance under strong and weak scaling. 1. Introduction. We consider the problem of finding a small number, k n, of extreme singular values and corresponding left and right singular vectors of a≪ large m n sparse matrix A R × (m n). These singular values and vectors satisfy, ∈ ≥ (1.1) Avi = σiui, where the singular values are labeled in ascending order, σ1 σ2 ... σn. The m n ≤n n ≤ ≤ matrices U = [u ,...,un] R × and V = [v ,...,vn] R × have orthonormal 1 ∈ 1 ∈ columns. (σi,ui, vi) is called a singular triplet of A.
    [Show full text]
  • WP 8 Project Presentations - 28 September 2020
    Linear Algebra, Krylov-subspace methods, and multigrid solvers for the discovery of New Physics (LyNcs): WP 8 Project Presentations - 28 September 2020 Jacob Finkenrath CaSToRC, The Cyprus Institute 1 PRACE 6IP – WP8 – LyNcs – CaSToRC www.prace-ri.eu PRACE 6IP WP8 LyNcs: People ▶ Constantia Alexandrou, CaSToRC – PI ▶ Emmanuel Agullo, Inria ▶ Simone Bacchio, CaSToRC ▶ Olivier Coulaud, Inria ▶ Jacob Finkenrath, CaSToRC ▶ Luc Giraud, Inria ▶ Kyriakos Hadjiyiannakou, CaSToRC ▶ Giannis Koutsou, CaSToRC ▶ Stéphane Lanteri, Inria ▶ Gilles Marait, Inria ▶ Michele Martone, LRZ ▶ Shuhei Yamamoto, CaSToRC 2 PRACE 6IP – WP8 – LyNcs – CaSToRC www.prace-ri.eu Project Objectives LyNcs: Linear Algebra, Krylov-subspace methods, and multigrid solvers for the discovery of New Physics Address the Exascale challenge for sparse linear systems & iterative solvers ▶ Targeting all level of software stack ● on lowest level: sparse Matrix vector kernels: librsb ● on intermediate level: iterative linear solver libraries: fabulous, DDalphaAMG, QUDA ● on highest level : community codes: LyNcs API, tmLQCD, openQCD Applications in: ▶ Fundamental Physics - lattice QCD ▶ Electrodynamics ▶ Computational Chemistry 3 PRACE 6IP – WP8 – LyNcs – CaSToRC www.prace-ri.eu Talk Outline ▶ Motivation ▶ LyNcs within 6IP Prace WP8 ● Project structure ● Tasks and Deliverables ▶ Overview on software developments ● Lyncs API - New community-driven software ● Fabulous - Iterative Block Krylov Solvers library ● librsb - a Sparse BLAS format library ● DDalphaAMG - Multigrid library for lattice
    [Show full text]
  • Matrix:“MM” 3/9 HCSR 1.3E+04 4/9 HCOO 2.0E+03 – Sparse Triangular Solve by Matrix:“SM” Untuned
    Auto-tuning shared memory parallel Sparse BLAS operations in librsb-1.2 Michele MARTONE ([email protected]) Max Planck Institute for Plasma Physics, Garching bei Munchen,¨ Germany Intro 2/9 HCSR 1.5e+04 Sparse BLAS (Basic Linear Algebra Subroutines) [2] speci- • 1/9 HCOO 2.0e+03 fies main kernels for iterative methods: – sparse Multiply by Matrix:“MM” 3/9 HCSR 1.3e+04 4/9 HCOO 2.0e+03 – sparse triangular Solve by Matrix:“SM” Untuned. Tuned for NRHS=1. Tuned for NRHS=3. Tuning example on symmetric matrix audikw 1. • Focus on MM: C C + αop(A) B , with Here only lower triangle, ca. 1M 1M, 39M nonzeroes. • ← × • × 5/9 HCOO 9.8e+02 6/9 HCSR 1.0e+04 – A has dimensions m k and is sparse (nnz nonzeroes) On a machine with 256 KB sized L2 cache. × • T H Left one (625 blocks, avg 491 KB) is before tuning. – op(A) can be either of A, A ,A (parameter transA) 9/9 HCOO 5.0e+03 • { } Middle one (271 blocks, avg 1133 KB) after tuning (1.057x – left hand side (LHS) B is k n, • × speedup, 6436.6 ops to amortize) for MV (MM with NRHS=1). right hand side (RHS) C is n m (n=NRHS), × 7/9 HCSR 8.5e+03 8/9 HCSR 7.0e+03 Right one (1319 blocks, avg 233 KB) after tuning (1.050x both dense (eventually with strided access incB, incC, ...) • speedup, 3996.2 ops to amortize) for MM with NRHS=3. – α is scalar Finer subdivision at NRHS=3 consequence of increased • – either single or double precision, either real or complex Instance of matrix bayer02 (ca.
    [Show full text]
  • Fast Matrix-Vector Multiplications for Large-Scale Logistic Regression on Shared-Memory Systems
    Fast Matrix-vector Multiplications for Large-scale Logistic Regression on Shared-memory Systems Mu-Chu Lee Wei-Lin Chiang Chih-Jen Lin Department of Computer Science Department of Computer Science Department of Computer Science National Taiwan Univ., Taiwan National Taiwan Univ., Taiwan National Taiwan Univ., Taiwan Email: [email protected] Email: [email protected] Email: [email protected] Abstract—Shared-memory systems such as regular desktops modules. The core computational tasks of some popular now possess enough memory to store large data. However, the machine learning algorithms are sparse matrix operations. training process for data classification can still be slow if we do For example, if Newton methods are used to train logistic not fully utilize the power of multi-core CPUs. Many existing works proposed parallel machine learning algorithms by modi- regression for large-scale document data, the data matrix is fying serial ones, but convergence analysis may be complicated. sparse and sparse matrix-vector multiplications are the main Instead, we do not modify machine learning algorithms, but computational bottleneck [10], [11]. If we can apply fast consider those that can take the advantage of parallel matrix implementations of matrix operations, then machine learning operations. We particularly investigate the use of parallel sparse algorithms can be parallelized without any modification. Such matrix-vector multiplications in a Newton method for large- scale logistic regression. Various implementations from easy to an approach possesses the following advantages. sophisticated ones are analyzed and compared. Results indicate 1) Because the machine learning algorithm is not modified, the that under suitable settings excellent speedup can be achieved.
    [Show full text]
  • Librsb: a Shared Memory Parallel Sparse BLAS Implementation Using the Recursive Sparse Blocks Format
    librsb: A Shared Memory Parallel Sparse BLAS Implementation using the Recursive Sparse Blocks format Michele Martone High Level Support Team Max Planck Institute for Plasma Physics Garching bei Muenchen, Germany Sparse Days'13 Toulouse, France June 17{18, 2013 presentation outline Intro librsb: a Sparse BLAS implementation A recursive layout Performance measurements SpMV , SpMV-T SymSpMV performance COO to RSB conversion cost Auto-tuning RSB for SpMV /SpMV-T /SymSpMV Conclusions Summing up References Extra: RSB vs MKL plots Focus of the Sparse BLAS operations The numerical solution of linear systems of the form Ax = b (with A a sparse matrix, x; y dense vectors) using iterative methods requires repeated (and thus, fast) computation of (variants of) Sparse Matrix-Vector Multiplication and Sparse Matrix-Vector Triangular Solve: I SpMV :\y β y + α A x" T I SpMV-T :\y β y + α A x" T T I SymSpMV:\y βy + α A x; A = A " −1 I SpSV :\x α L x" −T I SpSV-T :\x α L x" librsb: a high performance Sparse BLAS implementation I uses the Recursive Sparse Blocks (RSB) matrix layout I provides (for true) a Sparse BLAS standard API I most of its numerical kernels are generated (from GNU M4 templates) I extensible to any integral C type I pseudo-randomly generated testing suite I get/set/extract/convert/... functions I 47 KLOC of C (C99), 20 KLOC of M4, 2 KLOC of GNU≈ Octave ≈ ≈ I bindings to C and Fortran (ISO C Binding), as OCT module for GNU Octave I LGPLv3 licensed design constraints of the Recursive Sparse Blocks (RSB) format I parallel, efficient SpMV /SpSV /COO RSB ! I in-place COO RSB COO conversion ! ! I no oversized COO arrays / no fillin (e.g.: in contrast to BCSR) 1 I no need to pad x; y vectors arrays I architecture independent (only C code, POSIX) I developed on/for shared memory cache based CPUs: I locality of memory references I coarse-grained workload partitioning 1e.g.
    [Show full text]