mon-entreprise/publicodes/docs/mecanisms.yaml

588 lines
16 KiB
YAML
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

une de ces conditions:
description: >-
Renvoie `oui` si l'une des règles listées est _applicable_.
Equivaut à un `ou` logique.
retourne: Booléen
exemples:
base: >-
âge:
formule: 17 ans
mineur émancipé:
formule: oui
peut voter:
formule:
une de ces conditions:
- âge >= 18 ans
- mineur émancipé
toutes ces conditions:
description: >-
Renvoie `oui` si toutes toutes les règles listées sont _applicables_.
Equivaut à un `et` logique.
argument:
- '*'
- ...
exemples:
base: >-
âge:
formule: 17 ans
citoyenneté française:
formule: oui
peut voter:
formule:
toutes ces conditions:
- citoyenneté française
- âge >= 18 ans
produit:
description: >-
C'est une multiplication adaptée pour exprimer au mieux les cotisations.
Sa propriété `assiette` est multipliée par un pourcentage `taux`, ou par un
`facteur` quand ce nom est plus approprié.
La multiplication peut être plafonnée : ce plafond sépare l'assiette en
deux, et la partie au-dessus du plafond est tout simplement ignorée. Dans ce
cas, elle se comporte comme une barème en taux marginaux à deux tranches, la
deuxième au taux nul et allant de `plafond` à l'infini.
argument:
assiette: Valeur à multiplier
taux: Taux à appliquer
facteur: Facteur multiplicatif
plafond: Plafond au dessus duquel le taux appliqué est nul
exemples:
base: >-
cotisation:
formule:
produit:
assiette: 2000 €/mois
taux: 5%
assiette plafonnée: >-
plafond sécurité sociale:
formule: 3000 €/mois
assiette cotisation:
formule: 15000 €/mois
chômage:
formule:
produit:
assiette: assiette cotisation
plafond: 400% * plafond sécurité sociale
taux: 4%
variations:
description: >-
Contient une liste de conditions (`si`) et leurs conséquences associées
(`alors`), ainsi qu'un cas par défaut (`sinon`).
Pour la première condition vraie dans la liste, on retient la valeur qui lui
est associée.
Si aucune condition n'est vraie, alors ce mécanisme renvoie implicitement
`non applicable`.
Ce mécanisme peut aussi être utilisé au sein d'un autre mécanisme
compatible, tel que `produit` ou `barème`.
arguments:
- si: condition à vérifier
alors: consequence évaluée si la condition est vrai
- ...
- sinon: consequence évaluée si aucune des conditions précédente n'était applicable
exemples:
base: >-
taux réduit:
formule: oui
taux allocation familiales:
formule:
variations:
- si: taux réduit
alors: 3.45%
- sinon: 5.25%
dans un produit: >-
assiette cotisation:
formule: 2300 €/mois
taux réduit:
formule: oui
allocation familiales:
formule:
produit:
assiette: assiette cotisation
variations:
- si: taux réduit
alors:
taux: 3.45%
- sinon:
taux: 5.25%
somme:
description: >-
Somme de chaque terme de la liste.
Si un des terme n'est pas applicable, il vaut zéro.
On peut retrancher des valeurs grâce à l'opérateur unaire `-`
arguments:
- '*'
- ...
exemples:
base: >-
exemple:
formule:
somme:
- 15.89 €
- 12% * 14 €
- (-20 €)
terme non applicable: >-
a:
formule: 50 €
b:
applicable si: non
formule: 20 €
somme:
formule:
somme:
- a
- b
- 40 €
le maximum de:
description: >-
Renvoie la valeur numérique de la liste de propositions fournie qui est la
plus grande.
Pour ajouter un plancher à une valeur, préférer l'utilisation du
mécanisme `encadrement`.
exemples:
base: >-
max:
formule:
le maximum de:
- 50
- 100
le minimum de:
description: >-
Renvoie la valeur numérique de la liste de propositions fournie qui est la
plus petite.
Pour plafonner une valeur, préférer l'utilisation du mécanisme `encadrement`.
exemples:
base: >-
min:
formule:
le minimum de:
- 50
- 100
arrondi:
description: >-
Arrondi à l'entier le plus proche, ou à une précision donnée.
exemples:
base: >-
arrondi:
formule:
arrondi:
valeur: 12.45
décimales: 1
régularisation:
description: |
Permet de régulariser progressivement un calcul de cotisation en fonction du
cumul de variables numériques mensuelles.
Ce mécanisme spécifique est utilisé pour le calcul des cotisations
mensuelles, afin de "lisser" un plafond ou un calcul sur plusieurs mois.
La régularisation progressive s'opère le long d'une année civile complète.
## Explication du calcul
Pour chaque mois, on évalue la valeur à régulariser en faisant le cumul des
éléments nécessaires au calcul sur la période écoulée depuis le premier
jour de lannée.
Par exemple, pour la cotisation suivante :
```yaml
cotisation:
formule:
produit:
assiette: brut
plafond: 2000 €/mois
taux: 10%
```
Avec un brut de 1000 € en janvier et 3500 € en février et 1000€ en mars, le cumul sera le
suivant :
| | brut | plafond | cotisation |
| --- | ------ | ------- |------------------- |
| JAN | 1000 € | 2000 € | 1000 × 10% = 100 € |
| FEV | 4500 € | 4000 € | 4000 × 10% = 400 € |
| MAR | 5500 € | 6000 € | 5500 × 10% = 550 € |
On regarde ensuite le cumul des valeurs déjà versées les mois précédents, pour
ne garder que la différence entre les deux montants. Dans notre exemple, on
aboutit aux valeurs suivantes :
| | cotisation cumul | cotisation régularisée |
| --- | ---------------- | ---------------------- |
| JAN | 100 € | 100 € |
| FEV | 400 € | 400 € - 100 € = 300 € |
| MAR | 550 € | 550 € - 300 € = 150 € |
arguments:
règle: règle à régulariser
valeurs cumulées:
- liste de variables cumulée mensuellement pour calculer la régularisation. Doivent être
numérique, et avoir une unité `/mois`
exemples:
base: >-
brut:
formule:
somme:
- 1000 €/mois | du 01/01/2020 | au 31/01/2020
- 3500 €/mois | du 01/02/2020 | au 29/02/2020
- 1000 €/mois | du 01/03/2020 | au 31/03/2020
cotisation:
formule:
régularisation:
règle:
produit:
assiette: brut
plafond [ref]: 2000 €/mois
taux: 10%
valeurs cumulées:
- brut
- plafond
valeur cumulée à partir d'une date: >-
SMIC: 1521.22 €/mois
primes:
formule:
somme:
- 2470 €/mois | du 01/01/2019 | au 31/01/2019
- 1470 €/mois | du 01/05/2019 | au 31/05/2019
rémunération:
formule:
somme:
- 1530 €/mois | du 01/01/2019 | au 31/12/2019
- primes
réduction sur AC au 1er janvier:
formule: non
réduction générale chômage . coefficient:
formule:
arrondi:
valeur: (0.0405 / 0.60 ) * (1.60 * SMIC / rémunération - 1)
décimales: 4
réduction générale chômage . réduction sans régularisation:
formule:
encadrement:
plancher: 0
valeur:
arrondi:
valeur:
multiplication:
assiette: rémunération
taux: coefficient
décimales: 2
réduction générale chômage:
formule:
régularisation:
règle: réduction sans régularisation
valeurs cumulées:
- 'SMIC | à partir du 01/10/2019'
- 'rémunération | à partir du 01/10/2019'
recalcul:
description: >-
Relance le calcul d'une règle dans une situation différente de la situation
courante. Permet par exemple de calculer le montant des cotisations au niveau du
SMIC, même si le salaire est plus élevé dans la situation actuelle.
exemples:
base: >-
brut:
formule: 2000€
cotisations:
formule:
produit:
assiette: brut
taux: 20%
cotisations pour un SMIC:
formule:
recalcul:
règle: cotisations
avec:
brut: 1500 €
barème:
description: C'est un barème en taux marginaux, mécanisme de calcul connu de
par son utilisation dans le calcul de l'impôt sur le revenu.
L'assiette est décomposée en plusieurs tranches, qui sont multipliées par un
taux spécifique et enfin additionnées pour donner le résultat.
Les tranches sont souvent exprimées sous forme de facteurs d'une variable
que l'on appelle `multiplicateur`, par exemple une fois le plafond de la
sécurité sociale.
exemples:
sans multiplicateur: >-
revenu imposable:
formule: 54126 €
impôt sur le revenu:
formule:
barème:
assiette: revenu imposable
tranches:
- taux: 0%
plafond: 9807 €
- taux: 14%
plafond: 27086 €
- taux: 30%
plafond: 72617 €
- taux: 41%
plafond: 153783 €
- taux: 45%
avec multiplicateur: >-
retraite de base:
formule:
barème:
assiette: assiette retraite
multiplicateur: plafond sécurité sociale temps plein
tranches:
- taux: 17.75%
plafond: 1
- taux: 0.6%
arrondi: oui
grille:
description: >-
C'est un barème sous la forme d'une grille de correspondance simple. C'est
le mécanisme de calcul de l'impôt neutre, aussi appelé impôt non
personnalisé.
Il est composé de tranches qui se suivent. Il suffit de trouver l'assiette
qui correspond à la tranche, et de selectionner le montant associé à
l'assiette.
exemples:
grille avec multiplicateur et unité: >-
SMIC horaire:
formule: 10 €/heure
revenu moyen:
formule:
250 €/mois
trimestres validés:
formule:
grille:
unité: trimestres validés/an
assiette: revenu moyen
multiplicateur: SMIC horaire
tranches:
- montant: 0
plafond: 150 heures/an
- montant: 1
plafond: 300 heures/an
- montant: 2
plafond: 450 heures/an
- montant: 3
plafond: 600 heures/an
- montant: 4
taux progressif:
description: >-
Ce mécanisme permet de calculer un taux progressif. On spécifie pour chaque
tranche le plafond et le taux associé. Le taux effectif renvoyé est calculé
en lissant la différence de taux entre la borne inférieure et supérieure de
l'assiette.
Par exemple, si nous nous avons les tranches suivantes :
- taux: 50% / plafond: 0
- taux: 100% / plafond: 1000
Pour une assiette de 500, le taux retourné sera 75%, car il correspond au
taux situé à la moitié de la tranche correspondante.
exemples:
base: >-
chiffre d'affaires:
formule: 30000 €/an
plafond:
formule: 3000 €/mois
taux réduction de cotisation:
formule:
taux progressif:
assiette: chiffre d'affaires
multiplicateur: plafond
tranches:
- taux: 100%
plafond: 75%
- taux: 0%
plafond: 100%
composantes:
description: >-
Beaucoup de cotisations sont composées de deux parties qui partagent la
méthode de calcul mais diffèrent selons certains paramètres. Pour ne pas
définir deux variables quasi-redondantes, on utilise ce mécanisme.
Dans les calculs, `composantes` se comporte **exactement comme une somme**.
La documentation, elle, sera adaptée pour montrer chaque composantes.
Chaque composante peut contenir un champs `nom` (de type texte) ou un champs
`attributs` (de type objet avec des champs libres) qui remonteront dans la
documentation pour aider à l'explicabilité.
Il est possible, pour les mécanismes `barème` et `produit` de garder en
commun un paramètre comme l'assiette, puis de déclarer des composantes pour
le taux.
> L'exemple le plus courant de composantes est la distinction part
employeur / part salarié (ex. retraite AGIRC).
exemples:
base: >-
CSG . base:
formule:
multiplication:
assiette: assiette de base
composantes:
- attributs:
impôt sur le revenu: déductible
taux: taux déductible
- attributs:
impôt sur le revenu: non déductible
taux: taux non déductible
allègement:
description: >-
Permet de réduire le montant d'une variable.
Très utilisé dans le contexte des impôts.
exemples:
base: >-
impôt . revenu abattu:
formule:
allègement:
assiette: base des cotisations
abattement: abattement
encadrement:
description: Permet d'ajouter un plafond et/ou un plancher à une valeur.
exemples:
base: >-
assiette plafonnée:
formule:
encadrement:
plancher: 0 €
valeur: 2000 €
plafond: 1500 €
durée:
description: Permet d'obtenir le nombre de jours entre deux dates
exemples:
base: >-
date d'embauche:
formule: 14/04/2008
ancienneté en fin d'année:
unité: an
formule:
durée:
depuis: date d'embauche
jusqu'à: 31/12/2020
synchronisation:
description: Permet de récupérer certaines informations, tels que les les
codes postaux des villes, à partir d'APIs externes, telles que l'[API
commune](https://geo.api.gouv.fr/decoupage-administratif/communes).
Attention, ce mécanisme est encore en cours de développement, et sa syntaxe
n'est pas stable. Se référer aux exemples existants.
inversion numérique:
description: >-
Il est souhaitable de rédiger les règles de calcul
en publicodes de la même façon qu'elles sont décrites dans la loi ou les
interprétations administratives ou juridiques existantes. En conséquence,
certaines variables n'auront donc pas de méthode de calcul clairement
explicitée, il s'agira donc de la déduire des autres valeurs renseignées.
De façon simplifiée, il s'agira donc, à partir d'une règle existante
explicitant `y = ƒ(x)` de calculer `x` à partir de `y`.
L'inversion numérique permet d'estimer la valeur de la variable en question
au plus près à partir d'un des _objectifs_, listés dans la propriété `avec`.
Il faut alors renseigner une valeur cible pour ces objectifs.
L'algorithme utilisé est la [méthode de
Brent](https://fr.wikipedia.org/wiki/M%C3%A9thode_de_Brent). L'idée générale
est de prendre une valeur au hasard pour la variable en question, et
d'améliorer mathématiquement le choix jusqu'à ce que les valeurs cibles
soient toutes suffisamment proches des objectifs
Si on demande au moteur la valeur d'une variable qui a pour formule une
inversion, il va vérifier qu'une des variables `avec` a bien une valeur
(calculée ou saisie), et procéder à l'inversion décrite plus haut à partir
de celle-ci. Sinon, ces possibilités d'inversions seront listées comme
manquantes.