Impôt du Québec¶
Survol¶
L’impôt du Québec est pris en charge par le module quebec. Ce module contient un gabarit que nous documentons ci-dessous ainsi que des classes dérivées spécifiques pour chaque année.
La fonction form permet de choisir l’année du rapport d’impôt et ira tirer une instance du rapport pour cette année. L’instance est retournée par la fonction.
-
srd.quebec.
form
(year)¶ Fonction qui permet de sélectionner le formulaire d’impôt provincial par année.
- Paramètres
year (int) – année (présentement entre 2016 et 2020)
- Renvoie
Une instance du formulaire pour l’année sélectionnée.
- Type renvoyé
class instance
Gabarit du rapport¶
Nous utilisons un gabarit afin de créer les rapports chaque année. Quand l’impôt change seulement au niveau des paramètres d’une année à l’autre, le rapport ira seulement chercher les nouveaux paramètres. Quand des fonctions changent, l’utilisateur n’a qu’à modifier les fonctions touchées (ou à en ajouter de nouvelles). Toutes les modifications de fonction survenues après l’année 2016 sont indiquées ci-dessous.
Nous reproduisons ici la spécification du gabarit. Il est basé sur le rapport de 2016.
-
class
srd.quebec.
template
¶ Gabarit pour l’impôt provincial québécois.
-
file
(hh)¶ Fonction qui permet de calculer les impôts.
Cette fonction est celle qui calcule les déductions, les crédits non-remboursables et remboursables et les impôts nets.
- Paramètres
hh (Hhold) – instance de la classe Hhold
-
calc_gross_income
(p)¶ Fonction qui calcule le revenu total (brut).
Cette fonction correspond au revenu total d’une personne aux fins de l’impôt.
- Paramètres
p (Person) – instance de la classe Person
-
calc_net_income
(p)¶ Fonction qui calcule le revenu net au sens de l’impôt.
Cette fonction correspond au revenu net d’une personne aux fins de l’impôt. On y soustrait les déductions.
- Paramètres
p (Person) – instance de la classe Person
-
calc_taxable_income
(p)¶ Fonction qui calcule le revenu imposable au sens de l’impôt.
- Paramètres
p (Person) – instance de la classe Person
-
calc_deduc_gross_income
(p)¶ Fonction qui calcule les déductions.
Cette fonction fait la somme des différentes déductions du contribuable.
- Paramètres
p (Person) – instance de la classe Person
-
work_deduc
(p)¶ Fonction qui calcule la déduction pour travailleur.
- Paramètres
p (Person) – instance de la classe Person
- Renvoie
Montant de la déduction
- Type renvoyé
float
-
cpp_qpip_deduction
(p)¶ Déduction pour les cotisations RRQ / RPC et au RQAP pour le travail autonome.
- Paramètres
p (Person) – instance de la classe Person
- Renvoie
Montant de la déduction.
- Type renvoyé
float
-
calc_deduc_net_income
(p)¶ Fonction qui calcule les déductions suivantes: 1. Pertes en capital net des autres années; 2. Déduction pour gain en capital exonéré.
Permet une déduction maximale égale aux gains en capital taxables nets.
- Paramètres
p (Person) – instance de la classe Person
-
calc_tax
(p)¶ Fonction qui calcule l’impôt à payer selon la table d’impôt.
Cette fonction utilise la table d’impôt de l’année en cours.
- Paramètres
p (Person) – instance de la classe Person
-
calc_non_refundable_tax_credits
(p, hh)¶ Fonction qui calcule les crédits d’impôt non-remboursables.
Cette fonction fait la somme de tous les crédits d’impôt modélisés.
-
get_age_cred
(p)¶ Fonction qui calcule le crédit d’impôt non-remboursable en raison de l’âge.
- Paramètres
p (Person) – instance de la classe Person
- Renvoie
Montant du crédit.
- Type renvoyé
float
-
get_living_alone_cred
(p, hh)¶ Fonction qui calcule le crédit d’impôt non-remboursable pour personne vivant seule.
-
get_pension_cred
(p)¶ Fonction qui calcule le crédit d’impôt non-remboursable pour revenu de retraite.
- Paramètres
p (Person) – instance de la classe Person
- Renvoie
Montant du crédit.
- Type renvoyé
float
-
get_nrtcred_clawback
(p, hh)¶ Fonction qui calcule la récupération de la somme des crédits non-remboursables 1. en raison de l’âge; 2. pour personne vivant seule; et 3. pour revenu de retraite.
Cette fonction utilise le revenu net du ménage.
-
get_exp_worker_cred
(p)¶ Fonction qui calcule le crédit d’impôt non-remboursable pour les travailleurs d’expérience. Depuis 2019, renommé crédit d’impôt pour la prolongation de carrière.
On fait l’hypothèse que les travailleurs de 65 ans sont nés le 1er janvier de l’année en cours. (En réalité, les revenus gagnés avant et après le 65e anniversaire sont soumis à des traitements différents, ce qui complique beaucoup le modèle mais change peu les résultats.)
- Paramètres
p (Person) – instance de la classe Person
- Renvoie
Montant du crédit.
- Type renvoyé
float
-
get_donations_cred
(p)¶ Fonction qui calcule le crédit d’impôt non-remboursable pour dons.
- Paramètres
p (Person) – instance de la classe Person
- Renvoie
Montant du crédit.
- Type renvoyé
float
-
get_union_dues_cred
(p)¶ Fonction qui calcule le crédit d’impôt non-remboursable pour cotisations syndicales et professionnelles.
- Paramètres
p (Person) – instance de la classe Person
- Renvoie
Montant du crédit.
- Type renvoyé
float
-
get_disabled_cred
(p)¶ Fonction qui calcule le crédit d’impôt pour invalidité.
- Paramètres
p (Person) – instance de la classe Person
- Renvoie
Montant du crédit.
- Type renvoyé
float
-
get_med_exp_cred
(p, hh)¶ Fonction qui calcule le crédit d’impôt non-remboursable pour frais médicaux.
-
div_tax_credit
(p)¶ Fonction qui calcule le crédit d’impôt pour dividendes.
- Paramètres
p (Person) – instance de la classe Person
-
calc_refundable_tax_credits
(p, hh)¶ Fonction qui fait la somme des crédits remboursables.
-
chcare
(p, hh)¶ Fonction qui calcule le crédit d’impôt remboursable pour frais de garde.
-
witb
(p, hh)¶ Fonction qui calcule la prime au travail.
Le calcul est fait en tenant compte du revenu de travail, du revenu du ménage et de la présence d’un enfant à charge. Pour les couples, la prime est partagée au prorata des revenus de travail.
Notes: le supplément à la prime au travail et la prime au travail adaptée ne sont pas calculés.
-
home_support
(p, hh)¶ Fonction qui calcule le crédit d’impôt pour maintien à domicile des aînés.
-
med_exp
(p, hh)¶ Fonction qui calcule le crédit remboursable pour frais médicaux.
-
ccap
(p, hh)¶ Fonction qui calcule l’Allocation famille (qui s’appelait le Soutien aux enfants avant 2019).
Cette fonction calcule le montant reçu en fonction du nombre d’enfants, de la situation familiale (couple/monoparental) et du revenu.
-
calc_contributions
(p, hh)¶ Fonction fait la somme des contributions du contribuable. La contribution santé a été abolie en 2017; la contribution additionnelle pour les services de garde éducatifs à l’enfance subventionnés a été abolie en 2019.
-
health_contrib
(p, hh)¶ Fonction qui calcule la contribution santé.
Cette fonction calcule le montant dû en fonction du revenu net. La contribution santé a été abolie en 2017.
-
add_contrib_subsid_chcare
(p, hh)¶ Contribution additionnelle pour les services de garde éducatifs à l’enfance subventionnés.
Cette fonction calcule le montant dû en fonction du nombre de jours de garde et du revenu familial. Chaque conjoint paie en fonction du nombre de jours de garde sur son relevé 30. La contribution a été abolie en 2019.
-
solidarity
(p, hh)¶ Fonction qui calcule le crédit d’impôt pour solidarité.
Cette fonction calcule le montant reçu par chacun des conjoints en fonction du revenu familial de l’année fiscale courante (en réalité, le calcul est basé sur le revenu de l’année précédente).
-
Le gabarit collige les résultats dans un formulaire d’impôt qui sera rattaché à la personne sous la forme d’un dictionnaire Python. Cette procédure permet de différencier les attributs d’une personne qui font partie de son profil des variables générées par l’impôt. C’est la fonction create_return() qui fait ce travail.
-
srd.quebec.
create_return
()¶
Fonctions spécifiques ou modifiées par année¶
-
class
srd.quebec.
form_2016
¶ Formulaire d’impôt de 2016.
-
class
srd.quebec.
form_2017
¶ Formulaire d’impôt de 2017.
-
calc_contributions
(p, hh)¶ Fonction qui remplace dans le gabarit (classe srd.quebec.template) la fonction du même nom, et calcule les contributions.
Cette fonction fait la somme des contributions du contribuable. La contribution santé est abolie en 2017.
-
-
class
srd.quebec.
form_2018
¶ Formulaire d’impôt de 2018.
-
senior_assist
(p, hh)¶ Fonction qui remplace dans le gabarit (classe srd.quebec.template) la fonction du même nom, et calcule le crédit remboursable pour support aux ainés. En vigueur à partir de 2018.
-
-
class
srd.quebec.
form_2019
¶ Formulaire d’impôt de 2019.
-
calc_contributions
(p, hh)¶ Fonction qui remplace la fonction antérieure du même nom, et calcule les contributions.
Cette fonction fait la somme des contributions du contribuable. La contribution additionnelle pour service de garde éducatifs à l’enfance subventionnés est abolie en 2019.
-
-
class
srd.quebec.
form_2020
¶ Formulaire d’impôt de 2020.