-
Notifications
You must be signed in to change notification settings - Fork 152
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
drift on non-backpropagation based algorithms #634
Comments
It seems that you have done it correctly from looking at your code, just in general the drift time should be given as float not as int. I would think that the issue in your case is that the out_bound setting is much too restrictive (around 5). That would mean that only 5 inputs can be active with weights at gmax before it gets clipped. That is very restrictive. Note that the weights are rescaled to gmax when mapped, as a digital output scale is used in your setting |
Thank you for the remark, I converted the times into floats, I increased the out_bound value but it didn't change the result, I tried other rpu_configs from the tutorials available on the aihwkit documentation and the drift is still not being applied to the weights so the issue should be coming from somewhere else |
Can you try to use the rpu config that we have in the tutorial to check if the issue persists? link |
@imanehmz, did you make the suggested changes to your hw-aware training configuration? |
@kaoutar55 Hello, I've used many rpu_configs from the tutorials including that one, but the issue persists |
@imanehmz can you please tell us how to reproduced this error. Please share your code or a notebook you tried. |
Yes, here's the link to the notebook |
It seems you are using an older version of the aihwkit release. can you use the latest? Look at this example to get the right command: https://github.com/IBM/aihwkit/blob/master/notebooks/tutorial/hw_aware_training.ipynb |
@imanehmz looking at your code, it did not follow the proper way of applying the drift. Please loo at the latest examples we have. I will close this issue. |
Description and motivation
I'm trying to make inference with different timesteps on a neural network that's trained with Feedback Alignment from biotorch, however it is showing the same accuracy for all timesteps.
Here's the pseudo-code I'm using :
I'm getting an equal accuracy after the drift for all timesteps, the feedback alignment training method doesn't involve the usage of gradients in the backward pass and uses a random feedback matrix, however, when evaluating the drift, we're in eval mode so it shouldn't be a problem and the noise is going to be applied on the weights of the model and not the gradients to my understanding, why is there no loss in accuracy with the drift?
Proposed solution
It would be great to add support for other types of training methods other than backpropagation drift on analog hardware
Here's the link to a notebook on colab to execute the code of an example
The text was updated successfully, but these errors were encountered: