Skip to content

Commit 2ea99e2

Browse files
authored
Update README.md
formatting
1 parent 597a10d commit 2ea99e2

File tree

1 file changed

+29
-21
lines changed

1 file changed

+29
-21
lines changed

README.md

+29-21
Original file line numberDiff line numberDiff line change
@@ -144,7 +144,8 @@ This license should be "fire and forget". Just set the price, slap it on uploa
144144
## Consequences of these goals
145145

146146
Let's list out and number the target features for easy reference (TODO: auto-link):
147-
**Goals:
147+
148+
**Goals:**
148149
1. Source-available
149150
2. Anyone can contribute to or fork a project
150151
3. Modifications to the code must be disclosed
@@ -183,9 +184,9 @@ the royalty distribution table would look like this:
183184
| Contributor D | 20 |
184185
| Contributor E | 20 |
185186

186-
*Total royalty cost: 7%
187+
*Total royalty cost: 7%*
187188

188-
Another contributor adding the same amount of value to the project would just add another row to the table and raise the total royalty by 20% to 8.4% (from $\frac{\text{shares after}}{\text{shares before}} = \frac{20*6}{20*5} = \frac{120}{100}= 1.2 \Rightarrow 1.2 * 7\% = 8.4\%$)
189+
Another contributor adding the same amount of value to the project would just add another row to the table and raise the total royalty by 20% to 8.4% (from $`\frac{\text{shares after}}{\text{shares before}} = \frac{20*6}{20*5} = \frac{120}{100}= 1.2 \Rightarrow 1.2 * 7\% = 8.4\%`$)
189190

190191
| name | shares |
191192
|:------------------:|:------:|
@@ -196,7 +197,7 @@ Another contributor adding the same amount of value to the project would just ad
196197
| Contributor E | 20 |
197198
| Contributor F | 20 |
198199

199-
*Total royalty cost 8.4%
200+
*Total royalty cost 8.4%*
200201

201202
While this should leave all contributors happy, as they were each getting $20/100 * 7\% = 1.4\%$ of revenue as royalties before, and $20/120 * 8.4\% = 1.4\%$ of revenue as royalties after, there is clearly an effect on the user of the licensed software, who sees their cost go up 20%.
202203

@@ -217,7 +218,7 @@ If we start here:
217218
| Contributor D | 20 |
218219
| Contributor E | 20 |
219220

220-
*Total royalty cost: 7%
221+
*Total royalty cost: 7%*
221222

222223
And add "just" sixty-seven more equal contributors:
223224

@@ -231,15 +232,16 @@ And add "just" sixty-seven more equal contributors:
231232
| ... | ... |
232233
| Contributor #72 | 20 |
233234

234-
*Total royalty cost: 100.8%
235+
*Total royalty cost: 100.8%*
235236

236-
$\frac{\text{shares after}}{\text{shares before}} = \frac{20*72}{20*5} = \frac{1440}{100}= 14.4 \Rightarrow 14.4 * 7\% = 100.8\%$
237+
$`\frac{\text{shares after}}{\text{shares before}} = \frac{20*72}{20*5} = \frac{1440}{100}= 14.4 \Rightarrow 14.4 * 7\% = 100.8\%`$
237238

238239
Using the project costs more than 100% of revenue, and the end user gets no revenue themselves, even needing to pay more money than the revenue they bring in. This doesn't seem right, as even if the value of the software has gone up by a factor of 14, the end user is still doing valuable work they should be getting money for.
239240

240241
So we add a line of shares for them:
241242

242-
$$\text{end user shares} = \frac{\text{sum of contributor shares}}{\text{target royalty cost}} * (100\% - \text{target royalty cost}) = \frac{100}{7\%} * 93\% = 1328.5714$$
243+
$`\text{end user shares} = \frac{\text{sum of contributor shares}}{\text{target royalty cost}} * (100\% - \text{target royalty cost}) = \frac{100}{7\%} * 93\% = 1328.5714`$
244+
243245
Round to 1329 shares. Note that the fact that this is rounded means all calculations must be done from the number of shares. The final "total royalty cost" is imprecise (6.997901...% rather than 7%).
244246

245247
| name | shares |
@@ -252,12 +254,12 @@ Round to 1329 shares. Note that the fact that this is rounded means all calcula
252254
| | |
253255
| End User | 1329 |
254256

255-
*Total royalty cost: ~7%
257+
*Total royalty cost: ~7%*
256258

257259
>[!note]
258260
>The "End User" name is not replaced with an actual name when this table is placed in a real project. It is a stand-in for "Whoever uses this project under this license".
259261
260-
Then when we add a new contributor, the formula for total royalty cost becomes $\frac{\text{sum of contributor shares}}{\text{sum of all shares}} = \frac{20*72}{20*72 + 1329} = \frac{1440}{2769}= {\sim}0.52 = {\sim}52\%$
262+
Then when we add a new contributor, the formula for total royalty cost becomes $`\frac{\text{sum of contributor shares}}{\text{sum of all shares}} = \frac{20*72}{20*72 + 1329} = \frac{1440}{2769}= {\sim}0.52 = {\sim}52\%`$
261263

262264
| name | shares |
263265
|:---------------:|:------:|
@@ -270,16 +272,19 @@ Then when we add a new contributor, the formula for total royalty cost becomes $
270272
| | |
271273
| End User | 1328.6 |
272274

273-
*Total royalty cost: ~52%
275+
*Total royalty cost: ~52%*
274276

275-
With each contributor individually getting $\frac{\text{contributor shares}}{\text{sum of all shares}} = \frac{20}{2769} = {\sim}0.0072 = {\sim}0.72\%$ of revenue
277+
With each contributor individually getting $`\frac{\text{contributor shares}}{\text{sum of all shares}} = \frac{20}{2769} = {\sim}0.0072 = {\sim}0.72\%`$ of revenue
276278

277279
At this point, you may notice that each contributor's fraction of revenue just went down. This makes sense if you consider the revenue before the contributions and after the contributions as two different values $R_1$ and $R_2$, with $R_2$ being larger due to the value increase of the project allowing the end user to bring in more revenue.
278280

279281
Everything is fine if an early contributor is bringing in the same amount of money before and after the later contributions. (Again note that these calculations must be done with the numbers of shares, as the percentage values are approximate)
280-
$$\frac{\text{contributor's shares at start}}{\text{total shares at start}} * R_1 = \frac{\text{contributor's shares at end}}{\text{total shares at end}} * R_2 \\\Rightarrow \frac{\cancel{20} * 2769}{\cancel{20} * 1429} * R_1 = R_2 \\\Rightarrow \boxed{ \frac{R_2}{R_1} = {\sim}1.94}$$
282+
283+
$`\frac{\text{contributor's shares at start}}{\text{total shares at start}} * R_1 = \frac{\text{contributor's shares at end}}{\text{total shares at end}} * R_2 \\\Rightarrow \frac{\cancel{20} * 2769}{\cancel{20} * 1429} * R_1 = R_2 \\\Rightarrow \boxed{ \frac{R_2}{R_1} = {\sim}1.94}`$
284+
281285
The same goes for the end user:
282-
$$\frac{\text{end user's shares at start}}{\text{total shares at start}} * R_1 = \frac{\text{end user's shares at end}}{\text{total shares at end}} * R_2 \\\Rightarrow \frac{\cancel{1329} * 2769}{\cancel{1329} * 1429} * R_1 = R_2 \\\Rightarrow \boxed{ \frac{R_2}{R_1} = {\sim}1.94}$$
286+
287+
$`\frac{\text{end user's shares at start}}{\text{total shares at start}} * R_1 = \frac{\text{end user's shares at end}}{\text{total shares at end}} * R_2 \\\Rightarrow \frac{\cancel{1329} * 2769}{\cancel{1329} * 1429} * R_1 = R_2 \\\Rightarrow \boxed{ \frac{R_2}{R_1} = {\sim}1.94}`$
283288

284289
If the contributions make the revenue go up by a factor of ~1.94, the math works out.
285290

@@ -299,26 +304,28 @@ This is good because it allows us to treat every sub-project inclusion as just a
299304
Now all that's left is the actual mapping of shares from the sub-project to the main project.
300305
For example, let's say there are two existing contributors to a project, and they want to include a sub-project
301306

302-
**Main project:
307+
**Main project:**
303308

304309
| name | shares |
305310
|:-------------:|:------:|
306311
| Contributor A | 20 |
307312
| Contributor B | 20 |
308313
| | |
309314
| End User | 60 |
310-
*Total royalty cost: 40%
315+
316+
*Total royalty cost: 40%*
311317

312318

313-
**Sub-project:
319+
**Sub-project:**
314320

315321
| name | shares |
316322
|:-------------:|:------:|
317323
| Contributor C | 8 |
318324
| Contributor D | 2 |
319325
| | |
320326
| End User | 90 |
321-
*Total royalty cost: 10%
327+
328+
*Total royalty cost: 10%*
322329

323330
Let's put these in one table for convenience:
324331

@@ -351,7 +358,8 @@ Before these tables can be combined properly, we need to make the end user share
351358
| Contributor D | 4 |
352359
| | |
353360
| End User | 180 |
354-
*Total royalty cost: $\frac{140}{320}={\sim}44\%$
361+
362+
*Total royalty cost:* $`\frac{140}{320}={\sim}44\%`$
355363

356364
## Current licensing options
357365

@@ -405,7 +413,7 @@ Something along the lines of:
405413
"This license is the LGPL license, but with the additional condition that you need to pay a percentage of your total annual revenue to the contributors of this project with as defined in the included `royalty_distribution_table.csv` file."
406414

407415

408-
> [!Caution] Disclaimer
416+
> [!Info] Disclaimer
409417
> I am not a lawyer.
410418
411419
### The specific behavior we want out of the license:
@@ -494,4 +502,4 @@ A. How's that strategy been working out with taxes / global warming / this exact
494502

495503
1. Get feedback on this document
496504
2. Create a rough draft of the license itself
497-
- As I am not a lawyer, I can only assume that if I write it myself, it will be wrong
505+
- As I am not a lawyer, I can only assume that if I write it myself, it will be wrong

0 commit comments

Comments
 (0)