Dyalog '22 was held in Olhão, Portugal, from 9-13 October 2022
Programme (PDF) Materials Presentation Videos
D01: Welcome to Dyalog '22 summary | slides (PPTX) | slides (PDF) | video (18 mins)
Gitte Christensen, Managing Director (CEO) and Stine Kromberg
Dyalog Ltd's CEO opens the user meeting.
D02: The Road Ahead summary | slides (PPTX) | slides (PDF) | video (36 mins)
Morten Kromberg, Technical Director (CTO)
How might Dyalog evolve in the years to come, and which technologies should you be trying to keep an eye on yourself? Morten attempts to answer these questions, and sets the scene for the technical presentations being given at Dyalog '22.
D03: 2022 Conference Edition Part 1 – Past summary | slides (PPSX) | video (29 mins)
John Daintree
John has been noodling with some interesting things. In the first part of this series, he demonstrates some improvements to Dyalog's Session log.
D04: 2022 Conference Edition Part 2 – Present summary | video (32 mins)
John Daintree
Frustrated by function trains? Stymied by single line dfns? In the second part of this series, John demonstrates some new features that will take away some of your pain.
D05: The P words…Projects and Packages summary | slides (PPTX) | slides (PDF) | video (24 mins)
Morten Kromberg
Morten expressed his opinion that the growth of APL is hampered by a lack of widely-used libraries in an article he wrote for Vector in July 2003 (vol 20 issue 1), and his opinion has not changed since then. Has the tooling finally reached a point where off-the-shelf sample projects and shared libraries have become viable?
D06: APL9 from Outer Space summary | slides (PPTX) | slides (PDF) | video (24 mins)
Peter Mikkelsen
Peter is the most recent addition to the Dyalog interpreter development team. While he was still at Aalborg University, Peter implemented his own APL interpreter for the Plan9 operating system, a UNIX-like "distributed operating system" developed at Bell Labs in the 1980s. In this presentation, Peter demonstrates some of the more interesting features of APL9 and explains the presentation title...he might also mention a couple of the things he has been working on since joining Dyalog Ltd.
D07: Test Your Code! summary | slides (PPTX) | slides (PDF) | materials (ZIP) | video (27 mins)
Michael Baas
Testing APL Functions is sometimes seen as optional, as the functions are so small and self describing. Michael challenges that view, demonstrating some essential tools that are used internally within Dyalog Ltd (and are available to all users) to enhance the level of testing and, therefore, improve the quality of delivered code.
D08: Implementing the Convolutional Neural Network U-Net in APL summary | slides (PDF) | paper(PDF) | Research (GitHub repository) | video (23 mins)
Rodrigo Girão Serrão
The U-Net is an architecture of a convolutional neural network that is well-known in the machine learning literature. Rodrigo worked with Aaron Hsu on a paper about using APL to implement this architecture and experiment with it; in this presentation he explores the code base that they used.
D09: Performance Improvements in Set Operations summary | slides (PDF) | video (25 mins)
Karta Kooner
Dyalog version 18.0 introduced many useful performance enhancements, including some within the set-related primitives. Karta outlines the ongoing work that is being performed to understand what the performance profile of key primitives look like (beginning with the set-related primitives), discusses where performance gains can still be made, and describes how future evaluation of performance enhancements will be conducted by examining some of the shortcomings of the v18.0 performance work.
D10: 2022 Conference Edition Part 3 – Future(s) summary | slides (PPSX) | video part 1 (30 mins) | video part 2 (32 mins)
John Daintree
In the final part of this series, John explores some ideas for asynchronous programming in Dyalog.
D11: Report on Co-dfns summary | slides (PPTX) | slides (PDF) | video (20 mins)
Aaron Hsu
Aaron reviews the current state of Co-dfns (a high performance compiler for a parallel extension of the dfns language), developments since the last update (at Dyalog '19), and what the future might look like. He also explores how the Co-dfns compiler has been received in the broader computing communities and its impact on other projects.
D12: Simplifying Secure, Scalable Web Services summary | slides (PPTX) | slides (PDF) | video (30 mins)
Brian Becker
Jarvis is Dyalog's framework for the easy development of APL-based Web Services. Once your APL code running as a Web Service you might need to address additional considerations:
Brian introduces Jarvis, and discusses some options for running a secure, high-availability, scalable Web Service.
D13: How I Won the APL Problem Solving Competition – Introduction and Prize Ceremony summary | slides (PPTX) | slides (PDF) | video (12 mins)
Brian Becker
The 14th annual International APL Problem Solving Competition took place earlier this year. Brian summarises this year's contest and introduces the grand prize winner, culminating in the award ceremony.
D14: Text Processing in APL summary | slides (PPTX) | slides (PDF) | video (25 mins)
Aaron Hsu
APL has a reputation for being very good at numerical and financial types of calculations, but much of what modern data processing entails requires working with textual data of various sorts. Aaron discusses APL in the context of text processing, with an emphasis on parsing, architecture, and handling text-oriented applications.
D15: Filling the Core Language Gaps summary | slides (PPTX) | slides (PDF) | video (44 mins)
Adám Brudzewsky
Adám presents three proposed new primitives, and explains how their addition makes the language more complete. One complements the existing set of function composition operators, one generalises each in a manner similar to the powerful rank operator, and one supplies a functional form of the last remaining uses for square bracket indexing.
D16: Growing APLers summary | slides (PPTX) | slides (PDF) | video (21 mins)
Rich Park
Rich describes the need for (and ways to achieve) increasing and improving the resources that are available to help new users learn the basics of the language, utilise the many features of Dyalog, and develop their skills. He also discusses some of his experiences over the last year in training new and existing APLers.
U01: One-Time Pure Mathematician Corrupted by Exposure to APL Loses Moral Compass and Discovers, after Several Mis-Steps, a Useful Numerical Integration Method summary | slides (PPTX) | slides (PDF) | video (31 mins)
Charles Brenner, DNA-View (U.S.A.)
Numerical integration is a computer task that arises in many practical problems. It is a key step in the evaluation of forensic DNA evidence that requires integrating a function likely of two to five variables corresponding to the number of people whose DNA comprises the evidential sample. Integrating a function of one variable1 by computer is familiar ground. For several variables2 there is some deep and technical literature, based on a superficially obvious extrapolation of one-variable integration. Charles will discuss an evidently elusive though simple and natural alternative extrapolation that overcomes multiple shortcomings of the published methods.
Referenced equations:
1:  and 2: 
U02: Lift-Off from APL2 Mainframe to Dyalog in the Cloud summary | slides (PPTX) | slides (PDF) | video (25 mins)
Gilgamesh Athoraya, Tiamatica AB (Sweden)
This is the story of an ongoing project to move a large APL2 mainframe system to Dyalog on a modern platform. Gilgamesh presents the obstacles encountered and the milestones achieved in this ambitious endeavour.
U03: Rebuilding a Production APL Environment using Dyalog summary | slides (PPTX) | slides (PDF) | video (30 mins)
Mark Wolfson, BIG (U.S.A.)
BIG is a company in the jewellery industry that integrates with dozens of systems to import data from 1,000 retailers. The data is used to provide inventory analysis and merchandising consulting for the retailers, to provide sell-through data to manufacturers, and to integrate to several industry service companies. The end-user tools, and the integration applet, are written in C#, ASP.Net, JavaScript, MSSQL, and KendoUI.
APL was chosen to handle all data-related tasks, from processing the incoming data to infinite customisations of the data for customer use. Using the data manipulation capabilities, modular design, and rapid development capabilities of APL, BIG can respond quickly to user requests and changing data streams and configurations. The data comes in to BIG's servers in dozens of configurations, different numbers of files, different file formats, and inconsistent content. APL is used to transform this data to a standard upload into the production MSSQL database, normalising the formats and often converting the jumble of information into usable data.
For 15 years, BIG have used an organically-grown IBM APL2 environment that uses Microsoft Windows scheduled tasks to call .bat files to invoke APL2 to process the data at the time it is expected to come in. Over the past year, Mark has created an entirely new production environment using Dyalog that uses:
All code for the new environment is stored in text files (.aplf) and is brought into the running workspace as needed, and source control is used to share code within the team.
U04: A Modern APL Workbench summary | workbench materials (GitHub repository) | WSL2-Ubuntu materials (GitHub repository) | DuckDB (GitHub repository)
Kimmo Linna, Finnair (Finland)
In addition to being an Airbus Captain at FinnAir, Kimmo prepares analyses that are used for operational optimisation and negotiation between the airline and staff. He has constructed his own workbench for data analytics, with Dyalog at the centre of a collection of modern tools: DuckDB for data storage and queries, Vega-lite for graphics, Jupyter Notebook for presentations, and Visual Studio Code and GitHub Copilot for managing the code. In this presentation, Kimmo demonstrates the workflow that he has been able to achieve with this collection of tools. All his interfaces are available as GitHub projects.
U05: An APL to Vega-lite Interface summary | Vega-lite materials (GitHub repository) | Jupyter/Vega-lite materials (GitHub repository)
Kimmo Linna, Finnair (Finland)
For many years, Kimmo has been searching for a modern replacement for Adrian Smith's RainPro graphics package, which is oriented towards printed output and cannot easily produce interactive web-oriented graphics. His current choice is Vega-lite, which is a "high-level grammar of interactive graphics" that can easily be driven from APL using JSON input. Kimmo describes his search for a new graphics library, and explores the mechanics of the interface.
U06: From "I Developed and Tested It" to "I Developed, and My CI Tested It" summary | slides (PDF) | all materials (GitHub repository) | video (25 mins)
Lars Stampe Villadsen, SimCorp A/S (Denmark)
All developers test their solutions and, if they are seasoned, they build functions that test those solutions for them – if they are "modern" they automatically run their test functions using Continuous Integration (CI). Lars demonstrates how everyone can move from the initial step to the last step using standard (free) tools for APL where the code is maintained in files.
U07: Automating Application Builds with AWS summary | slides (PPTX) | slides (PDF) | video (26 mins)
Norbert Jurkiewicz, The Carlisle Group (U.S.A.)
The application build process should be automated and always use a consistently clean environment. In this high-level overview about using Amazon AWS resources for on-demand releases, Norbert covers:
U08: Semi-Globals and Multi-Threading are Like Chalk and Cheese summary | slides (PPTX) | slides (PDF) | video (24 mins)
Elena Paviotti, SimCorp Italiana (Italy)
30 years ago, SimCorp Sofia started as a single-threaded application, (ab)using lots of global and semi-global variables. As new technologies emerged, Sofia evolved into a multi-threaded client-server application. Adapting old code often proved difficult; Elena describes some of the issues encountered over the years, and how they approached – and (hopefully) solved – them.
U09: APL on the Side summary | slides (PDF)
Justin Dowdy, Semantic Arts (U.S.A.)
Dyalog users are fortunate to be able to use APL for an entire project when it is a good fit. Traditional software engineers that are interested in APL often have to find ways to use APL on the side or incorporate APL thinking into their professional work. April* and May are two projects that allow APL to be evaluated from Common Lisp and Clojure, respectively. These projects allow APL to be incrementally employed in projects that don't currently use APL. Justin describes these projects and the ways that he uses them.
* For more on the April compiler, see APL Seeds '22 presentation U02.
U10: Scheduling Array Operations summary | slides (PDF) | video (22 mins)
Juuso Haavisto, University of Oxford (U.K.)
Scheduling array operations has been a topical theme in the research of tensor computation. With the help of type theory, array operations are parallelised for graphics processing units and distributed computing. Juuso shares his findings in static scheduling, and how it can be used to optimise execution over different hardware and compute infrastructure settings.
U11: Performance of Dyalog APL – A Historical Perspective summary | slides (PDF) | video (20 mins)
Veli-Matti Jantunen, Statistics Finland (Finland)
Veli-Matti has been using Dyalog since 1995, and has always been interested in the performance of his APL code. In this presentation, he examines how the performance of operations that are important to his applications have evolved over almost three decades.
U12: TAMPA – Taming Mathematical Programming in APL summary | slides (PPTX) | slides (PDF) | video (24 mins)
Stephen Mansour, Misericordia University (U.S.A.)
Mathematical programming is a technique that can be used to optimise resources. The typical mathematical notation for linear optimisation is:
max c'x subject to Ax ≤ b
where x is a vector of decision variables, b is a vector of constraints, c is a vector of unit profits, and A is a matrix of resource usage. We can create similar-looking expressions using standard APL syntax, that is:
NS ← max c x subjectTo A x ≤ b
Stephen demonstrates this using TAMPA, a linear programming system written in Dyalog. A user interface for TAMPA has been written in Abacus, an HTML framework for Dyalog.
U13: Integrating HTMLRenderer Into Existing Applications summary | slides (PPTX) | slides (PDF) | video (31 mins)
Norbert Jurkiewicz, The Carlisle Group (U.S.A.)
HTMLRenderer is the most powerful addition to Dyalog in the last 10 years – there's never been greater ability to create modern interactive user interfaces. Norbert describes how The Carlisle Group are upgrading parts of their legacy Microsoft Windows application to take advantage of these new UI abilities while retaining a uniform theme. Integrating these complex environments comes with new challenges that require learning new programming environments (JS) and new ways to design application architecture… Async anyone?
U14: How I Won the APL Problem Solving Competition (Professional Entrant) summary | slides (ODP) | slides (PDF) | video (24 mins)
Michael Higginson, independent (Canada)
Michael is the winning professional entrant of the 14th annual APL Problem Solving Competition. A newcomer to APL, he describes what led him to the competition and his experiences using it as a vehicle to learn APL/Dyalog, and explores some of the approaches and solutions behind his successful entry.
U15: How I Won the APL Problem Solving Competition summary | slides (PDF) | video (41 mins)
Tzu-Ching Lee, National Tsing Hua University (Taiwan)
Lee is the grand prize winner of the 14th annual APL Problem Solving Competition. Following the award ceremony, he describes his experiences of APL/Dyalog and tells us how he managed to master enough of it to win the competition.
U16: Dyalog and Academia summary | slides (PDF) | video (20 mins)
Jesús Galán López, Delft University of Technology (The Netherlands)
Jesús and Gitte introduce the plan for bringing Dyalog back into academia. The final objective is to position Dyalog as a useful tool for scientific research and education, and make the academic world aware of the power of APL. This work will be done in collaboration with the Materials Science department at Ghent University (in Belgium), which will serve as a real example of an academic research environment with programming problems that can be better solved with APL.
U17: What – Another APL Book? summary | slides (PPTX) | slides (PDF) | video (15 mins)
Ray Polivka, Polivka Associates (U.S.A.)
Ray is working on another APL textbook and is at the point where he needs feedback!
There exists an important group of people who should be exposed to APL – students aged 14-18 years old. Ray's book is intended for this audience. It also could benefit college students who need to be exposed to computer languages, but do not want to study computer science.
The text does not cover all aspects of APL; instead, it focuses on introducing students to the APL language. It accomplishes this through many illustrations and exercises. Ray has been working on this for several years and the text is now at a point where he believes it could benefit greatly from your views and comments.
SA1: Idiomatic Expressions and Array-Oriented Solutions in APL summary | goals and problem sets (webpage) | all materials (GitHub repository)
Rich Park and Rodrigo Girão Serrão
APL is famous for being used to tackle problems in a "different" way compared to more conventional programming languages. Although it is possible to convert code written in Python/Java/C#/etc. into APL by merely substituting keywords with symbols, there are better ways to take advantage of a notational, executable tool of thought. In this hands-on workshop, you will learn how to use array-oriented techniques to solve some problems "the APL way". Only a basic knowledge of APL is needed.
Keywords: problem solving, array-oriented programming, rank operator, leading axis theory
SA2: Building Web Services with Jarvis summary | slides (PPTX) | slides (PDF) | all materials (GitHub repository)
Brian Becker
Almost all programming languages and application frameworks, on all platforms (including phones and IoT devices), include utilities tools that make it easy for them to call Web Services. This means that, if you embed your APL code in a Web Service, you can integrate your functions into almost any software system. Dyalog's framework for easily developing APL-based web services is Jarvis.
In this workshop you will:Keywords: Web Service, Jarvis, HTTP, JSON, REST
SA3: Link, Text-Based Sources, and Source Code Management summary | slides (PDF) | all materials (GitHub repository)
Morten Kromberg and Josh David
Hopefully you are already convinced of the benefits of storing your source code in text files. In this workshop, we will show you how to make the shift from workspace to text files using Link. We will also cover source code management tools (for example, Git) that you can use to collaborate and share your code with other team members. This workshop involves extensive hands-on practice.
Keywords: Link, Git, GitHub, VS Code, Acre
SP1: Recent Language Features in Dyalog summary | slides (PPTX) | slides (PDF) | all materials (GitHub repository)
Rich Park and Rodrigo Girão Serrão
This workshop focuses on features introduced in Dyalog v18.0 and v18.2 – new functions and operators as well as extensions to primitives and system functions – and includes hands-on exercises designed to show their use cases. You might find elegant solutions to problems that you are currently using workarounds for, improved ways to express algorithms, or just generally useful tools.
Keywords: function composition, primitive extensions, trains, tacit, operators, text, datetime, formatting, meta information
SP2: Deploying Services summary | slides (PPTX) | slides (PDF) | all materials (GitHub repository)
Morten Kromberg and Brian Becker
You've built a Jarvis web service (or some other APL-based service), now you need a way to make sure that it is up and running all the time, and able to scale to meet demand if it should grow suddenly? In this workshop we will cover some of the ways by which you can "deploy" your web service, either on your own hardware or "hosted" using one of the most widely-used systems, Amazon Web Services (AWS).
This workshop will cover:
Keywords: Web Service, scalability, security, load balancing, hosting, Docker, AWS, deployment, Jarvis
SP3: Working with Non-APL Data Sources summary | slides (PDF)
Richard Smith and Bjørn Christensen (asst. Andy Shiers)
Dyalog has a rich set of tools to import, export, and process data from external sources such as files, databases, and exchanges with other applications. This workshop explores some of these, including:
Keywords: filesystem, text files, CSV, JSON, Microsoft Excel, databases, OData
TP1: Understanding APL Performance summary | slides (PPTX) | slides (PDF)
Aaron Hsu and Karta Kooner
This workshop takes a thorough, first principles, approach to understanding APL performance, with the goal of equipping you with the tools and thought processes that you need to take a piece of APL code and understand how it is likely to perform, why it performs this way, and strategies for potentially improving the speed of the expression. We will also cover not only tricks and one-off performance considerations, but the tools that will allow you to feel confident that you have written "fast APL" and haven't missed something critical. Finally (time permitting), we will discuss the use of Accelerators for GPU-based APL programming using the Co-dfns compiler and how this impacts our performance analysis.
Keywords: performance, analysis
TP2: Futures and Isolates summary | slides (PDF) | all materials (GitHub repository)
Morten Kromberg (asst. John Daintree)
Futures and isolates are APL language features designed to make it straightforward to harness all the cores that your computer (or cluster of computers) has available, whether you are writing a new application or need to speed up legacy code. Following a theoretical overview of Futures and Isolates and a description of how they are implemented, the workshop will consist of exercises showing you how to:
Keywords: parallel, asynchronous, multicore, performance, futures, isolates
TP3: Creating, Maintaining, and Publishing APL Packages summary | slides (PPTX) | slides (PDF)
Josh David and Brian Becker
A package is a versioned APL module that has been wrapped up in such a way that it can easily be installed and managed using a Package Manager such as Tatin. A package manager makes it easy to know when new versions become available, and to upgrade the packages that your application depends on. In this workshop, we demonstrate how to create APL packages either from existing code or a new project. We also look at how to load and use packages as dependencies in your application, and give an overview of the different frameworks that exist and their use cases.
Keywords: project management, package management, dependency management, DevOps, Git, GitHub, semantic versioning
UNIX® is a registered trademark in the United States and other countries, licensed exclusively through X/Open Company Limited.
Windows® is a registered trademark of Microsoft Corporation in the United States and other countries.
Oracle® and Java™ are registered trademarks of Oracle and/or its affiliates.
macOS® and OS X® (operating system software) are trademarks of Apple Inc., registered in the U.S. and other countries.
All other trademarks are the property of their respective owners.