Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/dynastes-team/dynastes

A collection of layers, ops, utilities and more for TensorFlow 2.0 high-level API Keras
https://github.com/dynastes-team/dynastes

attention-mechanisms keras keras-layer keras-tensorflow tensorflow tensorflow2

Last synced: about 15 hours ago
JSON representation

A collection of layers, ops, utilities and more for TensorFlow 2.0 high-level API Keras

Awesome Lists containing this project

README

        

# Dynastes
[![Travis](https://travis-ci.com/dynastes-team/dynastes.svg?branch=master)](https://travis-ci.com/dynastes-team/dynastes?branch=master)
[![Version](https://img.shields.io/pypi/v/dynastes.svg)](https://pypi.org/project/dynastes/)
![License](https://img.shields.io/pypi/l/dynastes.svg)

![](https://img.shields.io/badge/keras-tensorflow-blue.svg)
![](https://img.shields.io/badge/keras-tf.keras-blue.svg)

### Description

Collection of various of my custom TensorFlow-Keras 2.0+ layers, utils and such.

The focus of this library is on time-series, audio, DSP and GAN related networks

### Install

```bash
pip install dynastes
```

### Layers
- Generalized Multihead-Attention
- Works with any 1D-transform for QKV
- Works with any 1D-attention layer
- Tensor2Tensor 1D-Attention:
- Dot Product Attention*
- Dot Product Relative Self-Attention (Masked/Unmasked)*
- Sparse Attention (Truncated)
- Local Attention (Masked/Unmasked)*
- Tensor2Tensor 2D-Attention:
- Dot Product Relative Self-Attention (Unmasked)*
- Localized Attention (1D and 2D)*
- Perform attention within "kernels", a bit like convolution
- Time-Delay Neural Network Layers
- Adaptive Normalization Layers
- Adaptive Instance Normalization (StyleGAN etc)
- Adaptive Layer-Instance Normalization (U-GAT-IT)
- Adaptive Group Normalization (?)

*Supports multiquery attention

All layers support Spectral Normalization of kernels:
```
kernel_normalizer='spectral'
```
even relative attention layers:
```
key_embedding_normalizer='spectral'
value_embedding_normalizer='spectral'
```
All you need to do in a GAN training is then to call network(x/z, training=True) when training generator or discriminator, updates are automatically performed on the u-variable if training=True. This is enabled by having a "normalizers" dictionary for every weight.
If you implement a custom layer that inherits from DynastesBaseLayer you can assign spectral normalization simply by passing wname_normalizer to the creation args, where wname is the name you give your weight.
This has some caveats, if you call super.get_weight(name) you get the normalized weight, not the actual var / rvar

### Regularizers, Normalization, Constraints, Initializers
- Orthogonal Regularization
- Spectral Normalization

### Functions / ops
- nD-Attention
- Supports "Multi-Query Attention" from [Fast Transformer Decoding: One Write-Head is All You Need](https://arxiv.org/abs/1911.02150)
- Spectral ops:
- Wave <-> STFT
- STFT <-> IF-Mel-spectrogram
- Modified from GANSynth, now supports multi-channel audio and lower error using 128-bit complex representation

### Models / Architecture Scaffolding
- Progressive Growing of GANs / StyleGAN scaffolding
- Easily implement any kind of growing GAN in tf.keras by inhereting from these models:
- SimpleGrowingGanClassifer
- SimpleGrowingGanGenerator

### Roadmap:
- More attention variants (~~1D~~, 2D, ~~Relative~~, ~~Local~~, Area) from T2T
- Reimplementations of standard TF-Keras layers to support spectral normalization, etc
- GAN-scaffoldings (~~ProGAN~~, ~~StyleGAN~~, BiGAN, BiStyleGAN?)
- Graph-attention/convolutional embedding layer
- supply CSR-matrix/ces for node-connections
- if training=True then it updates, otherwise reads stored value

### Why?
Keras in TensorFlow 2.0 is nice, but sometimes you need exotic layers and functions that are cumbersome to implement, and I've found myself reimplementing or porting parts of T2T and other things for work and in private, over and over. This library aims to consolidate some of that and maintain tests for it.

### The name "Dynastes"
Dynastes is a genus of large beetles belonging to the subfamily Dynastinae, rhinoceros [ῥῑνόκερως (rhīnókerōs)] beetles and it is also the name of the son of Heracles and Erato (Thespius 49th daughter). This is a play on the word Keras [κέρας (kéras, “horn”)].

#### Notes about sources:

This repository borrows code heavily from:

[Tensor2Tensor](https://github.com/tensorflow/tensor2tensor/)

[TensorFlow 2.0 Tutorials](https://www.tensorflow.org/tutorials/)

_Code is copied for stability onto this repository and attribution available when possible_