How can I add a simple requirement "do not train Al on the source code of the program" to AGPLv3 or GPLv3 and thereby create a new license?
Don't know is it a good place for such a question but I try :).
Why did I come up with such an stupid idea? There have been reported cases where artificial intelligence such as Github Copilot has been trained on many open source and free software projects, and in some cases it can output code snippets from GPL-licensed projects without specifying it. https://www.pixelstech.net/article/1682104779-GitHub-Copilot-may-generate-code-containing-GPL-code
I am not a lawyer, and I do not know where it is better to insert such a requirement. And how to formulate it in the best and correct form.
I understand it maybe complicated to check, to comply with this requirement and it may cause other difficulties, but I still think it can be a useful addition.
How to fit it with the fundamental freedoms of the GPL or it is unfitable?
I understand that this would make the license non-free, since it puts constraints on what the code can be used for. It's sad that it doesn't combine in some way. Maybe change requirements to do not train "closed source AI"(without code and training data of AI model publicly available).
And how can I name it? Is it better to name it without "GPL" If this new license cannot be considered free? NoAIFL or your variants :)?
Is it good to just add a new item?
For example like this:
Additional Clause:
You may not use the source code of this program, or any part thereof, to train any artificial intelligence model, machine learning model, or similar system without explicit written permission from the copyright holder.
or
Section [X]:
Restrictions on AI Training You may not use the source code of this program, or any part thereof, to train any artificial intelligence model, machine learning model, or similar system without explicit written permission from the copyright holder.
What you think about it? Maybe you already know licenses like this?
I doubt GitHub will make an effort to avoid violating less common licenses anytime soon. Once you have found a license that works for you, the best thing you can do is find alternative hosting for your code.
But what will stop them from train copilot on code from other publicly available hostings. Are there any restrictions why they won't be able to do it using something like the principles of fair use as an excuse in this case?
What will stop them is complexity and effort. Legal risk has proven to not be enough yet.
I understand that this would make the license non-free
You can potentially get around that by just specifying that any AI trained on it is considered a derivative work, and thus must be released under your new license.
That said, it's potentially moot, the argument the AI companies use for training on commercial data and art is that it's fair use under various exemptions.
Their argument should theoreticly fail because gpl doesnt just act as a copyright licence but also as a contract iirc.
That's a good idea. Now I have to think about how to formulate it better and what it will mean. :)
Maybe It is possible to simply add functions to files that are not used anywhere with very delusional content. If people read it, they will easily understand that some nonsense is written in the function. Perhaps even with a comment that this is to protect against "AI" training. But only so that they do not repeat themselves and it is difficult to remove them all by one pattern...