Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Co-dfns/Co-dfns

High-performance, Reliable, and Parallel APL
https://github.com/Co-dfns/Co-dfns

Last synced: 4 months ago
JSON representation

High-performance, Reliable, and Parallel APL

Awesome Lists containing this project

README

        

# Co-dfns Compiler

The Co-dfns project aims to provide a high-performance, high-reliability
compiler for a parallel extension of the Dyalog dfns programming language.
The dfns language is a functionally oriented, lexically scoped dialect of
APL. The Co-dfns language extends the dfns language to include explicit task
parallelism with implicit structures for synchronization and determinism.
The language is designed to enable rigorous formal analysis of programs
to aid in compiler optimization and programmer productivity, as well as in
the general reliability of the code itself.

Our mission is to deliver scalable APL programming to information and domain
experts across many fields, expanding the scope and capabilities of what
you can effectively accomplish with APL.

## Getting Help

Documentation on Co-dfns can be found in the [docs/](docs/) folder.

APL and Co-dfns can be a little different at first. I encourage you to contact
me ([email protected]) for any questions you may have regarding either APL or Co-dfns.

Additionally, if you have general Dyalog APL inquiries, please do not hesitate to
email Dyalog's support email: [email protected].

## Contributing and Helping

We are seeking to create an open funding model for Co-dfns research through
user and patron contributions. You can support the project by contributing code, feedback, benchmarks, and so forth, but you can also directly support the Co-dfns project by funding the author:

https://www.patreon.com/arcfide

## Related Projects

There are a number of related initiatives that are based on the Co-dfns
technology:

* [Mystika](https://github.com/Co-dfns/mystika):
a high-level, high-performance cryptographic stack
* [apixlib](https://github.com/Co-dfns/apixlib):
programmable, easy to use image processing

## Publications

The following publications are either directly related to Co-dfns or talk about Co-dfns in their presentations.

[Living The Loopless Life: Techniques For Removing Explicit Loops And Recursion, LambdaConf 2024](https://www.youtube.com/watch?v=F1q-ZxXmYbo)

[The Nano-parsing Architecture: Sane And Portable Parsing For Perverse Environments, LambdaConf 2024](https://www.youtube.com/watch?v=uInwQEMYAP8)

[Co-dfns Update 2023 // Aaron Hsu // Dyalog '23](https://www.youtube.com/watch?v=6yfBlNKw7Ug)

[U-Net CNN in APL: Exploring Zero-Framework, Zero-Library Machine Learning. ARRAY 2023.](https://dl.acm.org/doi/10.1145/3589246.3595371)

[Implementing the Convolutional Neural Network U-Net in APL, Dyalog User Meeting 2022](https://dyalog.tv/Dyalog22/?v=LQz1b14YYiI)

[Text Processing in APL, Dyalog User Meeting 2022](https://dyalog.tv/Dyalog22/?v=5I4YPkVU7mY)

[Co-dfns Report, Dyalog User Meeting 2022](https://dyalog.tv/Dyalog22/?v=HegGB0ykGlQ)

[DSLs, Architecture, & Structural Design in APL, 3 ways by Aaron W Hsu #FnConf 2022](https://youtu.be/fH4kxG5zR1Y)

[A Taste of GPU Compute, mentions Co-dfns](https://www.youtube.com/watch?v=eqkAaplKBc4)

[Modern APL in the Real World: Theory, Practice, Case Studies - λC 20 Global Edition](https://www.youtube.com/watch?v=2FMBf6A2eAA)

[Programming Obesity: A Code Health Epidemic - FnConf 2019](https://youtu.be/UDqx1afGtQc)

[Program Obesity: A Code Health Epidemic - λC 2019 Unconference](https://www.youtube.com/watch?v=Oj_xgO2uKJM)

[A Data Parallel Compiler Hosted on the GPU](https://scholar.google.com/scholar?hl=en&as_sdt=0%2C26&q=%22A+data+parallel+compiler+hosted+on+the+gpu%22+Aaron+Hsu&btnG=)

[Pragmatic Array Oriented Functional Programming @ JIO Talks](https://jiotalks.com/watch/204/home/Morten_Kromberg_&_Aaron_Hsu/Pragmatic_Array_Oriented_Functional_Programming)

[Live Reading/Writing Co-dfns, The Way of APL](https://www.youtube.com/watch?v=ABG5eSCZPrE)

Parallel-by-construction Tree Manipulation with APL - λC 2018 (Part [1](https://www.youtube.com/watch?v=lc4IjR1iJTg) [2](https://www.youtube.com/watch?v=X5_5MtOYNos))

[Does APL Need a Type System? (FnConf '18)](https://youtu.be/z8MVKianh54)

[Array-oriented Functional Programming](https://youtu.be/Gsj_7tFtODk)

[Tree Manipulation Workshop and Dyalog '18 Talk](https://www.sacrideo.us/lambdaconf-tree-manipulation-workshop-videos/)

[User Command for Co-dfns](https://youtu.be/BBaCKf7Od6I)

Functional Array Funhouse Intensive - λC 2017 (Part [1](https://www.youtube.com/watch?v=_3CkcoTqxfg) [2](https://www.youtube.com/watch?v=4-KLpGq6Aj8) [3](https://www.youtube.com/watch?v=8lw062D34N0) [4](https://www.youtube.com/watch?v=0S28dfQBUDg) [5](https://www.youtube.com/watch?v=j2Jyoel_myo))

[APL Patterns vs. Anti-Patterns @ FunctionalConf 2017](https://youtu.be/v7Mt0GYHU9A)

[Co-dfns 2017 Report](https://sway.com/mJg0M7qakrJBwP6G?ref=Link)

[APL Style: Patterns and Anti-patterns](https://sway.com/b1pRwmzuGjqB30On?ref=Link)

[Co-dfns Compiler Architecture and Design (Video)](https://youtu.be/gcUWTa16Jc0)

[The Key to a Data Parallel Compiler](http://dl.acm.org/citation.cfm?id=2935331)

[Accelerating Information Experts Through Compiler Design](http://dl.acm.org/citation.cfm?id=2774968)

[Co-dfns: Ancient Language, Modern Compiler](http://dl.acm.org/citation.cfm?id=2627384)

[U11: Using Co-dfns to Accelerate APL Code](http://dyalog.com/user-meetings/dyalog15.htm)

[U07: Co-dfns Report: Performance and Reliability Prototyping](http://dyalog.com/user-meetings/dyalog14.htm)

[I04: Co-dfns Compiler](http://dyalog.com/user-meetings/dyalog13.htm)

[Dyalog 2016 Presentation](https://sway.com/FmRyyaCSqappknRD)