Les fichiers contenus dans l'archive sont l'ensemble des fichiers de paramétrage utilisés par les services informatiques de la Direction Générale des Finances Publiques pour réaliser la taxation des foyers fiscaux (IR, ISF, CSG).
Ces fichiers sont développés sous licence CeCILL 2.1 soumise au droit français et respectant les principes de diffusion des logiciels libres.
Cette version est la 2.5 qui a servi au cours de l'année 2015 pour produire les avis d'impôt sur les revenus 2014.
Les fichiers contenus dans le répertoire src
sont :
tgvH.m
: Tableau général des variables qui assure la correspondance entre les codes issus de la 2042 et les variables internes au calcul, les variables de calcul et les variables restituées par la calculette IRerrH.m
: Fichier décrivant les différentes anomaliescoiX.m
,cocX.m
,horizoc.m
,horizoi.m
: Fichiers de gestion des anomalies de la calculettechap-X.m
,res-ser1.m
,res-ser2.m
: Fichiers comportant les différentes règles de calcul pour un ensemble fonctionnel cohérent.
Cette section contient des informations devinées en lisant les fichiers du code source, durant le processus d'écriture du parser et du compilateur en Python.
Un tag FIXME
est placé lorsqu'une information est manquante et qu'il faut la compléter.
Les règles déclarées sont qualifiées par un ou plusieurs noms d'application.
Exemple :
regle 700:
application : bareme , iliad , batch ;
pour z=1,2:
RB5z = max( 0, RB0z + TETONEQUO1) ;
RB55 = max( 0, RB05 + TETONEQUOM1) ;
Les applications identifiées jusque là sont :
batch
est utilisée pour le calcul primitif de l'impôtiliad
est utilisée pour le calcul correctif de l'impôtFIXME
les autres applications
Les variables sont de plusieurs types :
- Les variables saisies correspondent aux cases de la déclaration des revenus (par exemple
1AJ
). - Les variables calculées ont une formule qui renvoie la valeur de la variable.
- Les variables calculées de base sont des variables qui peuvent être affectées avant le début du calcul.
Le fichier tgvH.m
définit des variables via plusieurs champs qui varient selon le type.
Exemples :
10MINS1 : calculee : "deductions hors droits d'auteur plafonnees" ;
10MINS1TOUT : calculee base : "10 pourcent TS dernier evt pour calcul de DEFRI" ;
4BACREP : saisie revenu classe = 2 priorite = 10 categorie_TL = 20 cotsoc = 5 ind_abat = 0 acompte = 1 avfisc = 0 rapcat = 8 sanction = 2 nat_code = 0 alias CJC : "BA exceptionnels sous CGA - Quotient 4 - PAC" ;
Quelques exemples de fichiers contenant des formules :
chap-1.m
contient les règles de calcul du montant net à payerchap-2.m
contient les règles de calcul du montant net à payerchap-51.m
contient les règles de calcul des droits simples résultant du taux progressifchap-55.m
contient les règles de calcul des droits simples résultant du taux progressifchap-6.m
contient les règles de calcul du nombre de partschap-isf.m
contient les règles de calcul de l'ISFchap-perp.m
contient les règles de calcul des déductions pour verserment sur un Plan d'Epargne Retraite Populaire
Le fichier errH.m
définit des erreurs via plusieurs champs :
code
(string
, unique) : le code unique de l'erreurtype
(enum(anomalie, discordance, informative)
) : le type d'erreurtype_code
(enum(A, D, I)
) : le code du type d'erreur (semble redondant avectype
)
Exemple :
A000:anomalie :"A":"000":"00":"SAISIE D UN MONTANT NEGATIF":"N";
coi1.m
décleche uniquement des erreurs de typediscordance
coi2.m
etcoi3.m
déclechent uniquement des erreurs de typeinformative
coc*.m
déclechent uniquement des erreurs de typeanomalie
horizoc.m
ethorizoi.m
déclechent uniquement des erreurs de typeanomalie
, et les vérifications concernent uniquement l'applicationiliad
Variables calculées :
IRN
: Impot net ou restitution nette
Variables saisies :
TSHALLOV
(1AJ
) : Salaires - Declarant 1
- qu'est-ce que le calcul correctif horizontal ? (cf
horizoc.m
:verif corrective horizontale 760
)