this post was submitted on 01 Jul 2023
3 points (80.0% liked)

Machine Learning | Artificial Intelligence

963 readers
5 users here now

Welcome to Machine Learning – a versatile digital hub where Artificial Intelligence enthusiasts unite. From news flashes and coding tutorials to ML-themed humor, our community covers the gamut of machine learning topics. Regardless of whether you're an AI expert, a budding programmer, or simply curious about the field, this is your space to share, learn, and connect over all things machine learning. Let's weave algorithms and spark innovation together.

founded 2 years ago
MODERATORS
 

In the hidden layer, the activation function will decide what is being determined by the neural network, is it possible for an AI to generate activation function for itself so it can improve upon itself?

top 4 comments
sorted by: hot top controversial new old
[–] 80085 5 points 2 years ago* (last edited 2 years ago)

I just looked it up, and apparently someone implemented dynamic activation functions in a CNN: https://www.nature.com/articles/s41598-022-19020-y . I've never seen something like this elsewhere. I have included various activation functions in hyperparameter searches before full training to find the "best" one on datasets. I haven't really seen much of a difference in validation performance between activation functions.

Found another paper using dynamic activation functions with transformers: https://arxiv.org/pdf/2208.14111.pdf

[–] [email protected] 4 points 2 years ago

There are activation functions with some learnable parameters (search Google for learnable activation functions and you'll find some papers). But it's not particularly common to use them. Instead, the weights of the layer are learned, and that can (together with the activation function) represent very complicated functions.

I will note that it is quite common to use AutoML techniques, which try a variety of architectures (including different activation functions) to see which works best.

[–] model_tar_gz 4 points 2 years ago

The ‘swish’ activation function is f(x) = x.sigmoid(B.x).

B is typically set to 1, but it doesn’t have to be. You can use it as a parameter for the model to learn if you want. I’ve played with it and not really seen any significant benefit though; I’ve found that allowing the learning rate and/or batch size to vary are more impactful than a learned activation function. Also you can end up with vanishing or exploding gradients if you don’t constrain B; and even then B might saturate depending on what happens during training.

The choice of activation function itself is more impactful than allowing it to be dynamic/learned.

Happy learning!

[–] Hopps 3 points 2 years ago

Based on my research, there is an emerging interest in the field of meta-learning, or "learning to learn." Some researchers are exploring the concept of allowing neural networks to learn their own hyperparameters, which could include parameters of activation functions. However, it's my understanding that this approach could lead to more complex training processes and risks such as unstable gradients, and it might not always result in significantly better performance.

While activation functions with learnable parameters aren't commonly used, there is ongoing research that explores them. One such example is the Parametric ReLU (PReLU) function - a variant of the ReLU activation function that allows the negative slope to be learned during training, as opposed to being a predetermined hyperparameter.

In my opinion, if you're new to this field, it's essential to grasp the basics of neural networks, including understanding how common activation functions like ReLU, sigmoid, tanh, etc., operate. These advanced concepts are undoubtedly fascinating and might offer incremental improvements, but even most of today's state-of-the-art models primarily use these "standard" activation functions. So, starting with a solid foundation is key.