{
  "calculate_output": "calculate_output_divide",
  "default_value": 0,
  "definition_period": "year",
  "dtype": "float32",
  "entity": "foyer_fiscal",
  "file_path": "openfisca_france/model/prelevements_obligatoires/impot_revenu/contribution_differentielle_hauts_revenus.py",
  "formulas": {
    "2025-01-01": {
      "ast": {
        "args": {
          "args": [
            {
              "arg": "foyer_fiscal",
              "ast_class": "arg",
              "col_offset": 23,
              "end_col_offset": 35,
              "end_lineno": 1,
              "lineno": 1
            },
            {
              "arg": "period",
              "ast_class": "arg",
              "col_offset": 37,
              "end_col_offset": 43,
              "end_lineno": 1,
              "lineno": 1
            },
            {
              "arg": "parameters",
              "ast_class": "arg",
              "col_offset": 45,
              "end_col_offset": 55,
              "end_lineno": 1,
              "lineno": 1
            }
          ],
          "ast_class": "arguments",
          "defaults": [],
          "kw_defaults": [],
          "kwonlyargs": [],
          "posonlyargs": []
        },
        "ast_class": "FunctionDef",
        "body": [
          {
            "ast_class": "Assign",
            "col_offset": 4,
            "end_col_offset": 9,
            "end_lineno": 7,
            "lineno": 5,
            "targets": [
              {
                "ast_class": "Name",
                "col_offset": 4,
                "ctx": {
                  "ast_class": "Store"
                },
                "end_col_offset": 56,
                "end_lineno": 5,
                "id": "contribution_differentielle_hauts_revenus_ressources",
                "lineno": 5
              }
            ],
            "value": {
              "args": [
                {
                  "ast_class": "Constant",
                  "col_offset": 8,
                  "end_col_offset": 62,
                  "end_lineno": 6,
                  "lineno": 6,
                  "value": "contribution_differentielle_hauts_revenus_ressources"
                },
                {
                  "ast_class": "Name",
                  "col_offset": 64,
                  "ctx": {
                    "ast_class": "Load"
                  },
                  "end_col_offset": 70,
                  "end_lineno": 6,
                  "id": "period",
                  "lineno": 6
                }
              ],
              "ast_class": "Call",
              "col_offset": 59,
              "end_col_offset": 9,
              "end_lineno": 7,
              "func": {
                "ast_class": "Name",
                "col_offset": 59,
                "ctx": {
                  "ast_class": "Load"
                },
                "end_col_offset": 71,
                "end_lineno": 5,
                "id": "foyer_fiscal",
                "lineno": 5
              },
              "keywords": [],
              "lineno": 5
            }
          },
          {
            "ast_class": "Assign",
            "col_offset": 4,
            "end_col_offset": 94,
            "end_lineno": 12,
            "lineno": 10,
            "targets": [
              {
                "ast_class": "Name",
                "col_offset": 4,
                "ctx": {
                  "ast_class": "Store"
                },
                "end_col_offset": 19,
                "end_lineno": 10,
                "id": "cdhr_parameters",
                "lineno": 10
              }
            ],
            "value": {
              "ast_class": "Attribute",
              "attr": "contribution_differentielle_hauts_revenus",
              "col_offset": 22,
              "ctx": {
                "ast_class": "Load"
              },
              "end_col_offset": 94,
              "end_lineno": 12,
              "lineno": 10,
              "value": {
                "ast_class": "Attribute",
                "attr": "contributions_exceptionnelles",
                "col_offset": 22,
                "ctx": {
                  "ast_class": "Load"
                },
                "end_col_offset": 52,
                "end_lineno": 12,
                "lineno": 10,
                "value": {
                  "ast_class": "Attribute",
                  "attr": "impot_revenu",
                  "col_offset": 22,
                  "ctx": {
                    "ast_class": "Load"
                  },
                  "end_col_offset": 22,
                  "end_lineno": 12,
                  "lineno": 10,
                  "value": {
                    "args": [
                      {
                        "ast_class": "Name",
                        "col_offset": 8,
                        "ctx": {
                          "ast_class": "Load"
                        },
                        "end_col_offset": 14,
                        "end_lineno": 11,
                        "id": "period",
                        "lineno": 11
                      }
                    ],
                    "ast_class": "Call",
                    "col_offset": 22,
                    "end_col_offset": 9,
                    "end_lineno": 12,
                    "func": {
                      "ast_class": "Name",
                      "col_offset": 22,
                      "ctx": {
                        "ast_class": "Load"
                      },
                      "end_col_offset": 32,
                      "end_lineno": 10,
                      "id": "parameters",
                      "lineno": 10
                    },
                    "keywords": [],
                    "lineno": 10
                  }
                }
              }
            }
          },
          {
            "ast_class": "Assign",
            "col_offset": 4,
            "end_col_offset": 57,
            "end_lineno": 14,
            "lineno": 14,
            "targets": [
              {
                "ast_class": "Name",
                "col_offset": 4,
                "ctx": {
                  "ast_class": "Store"
                },
                "end_col_offset": 21,
                "end_lineno": 14,
                "id": "seuil_celibataire",
                "lineno": 14
              }
            ],
            "value": {
              "ast_class": "Attribute",
              "attr": "seuil_celibataire",
              "col_offset": 24,
              "ctx": {
                "ast_class": "Load"
              },
              "end_col_offset": 57,
              "end_lineno": 14,
              "lineno": 14,
              "value": {
                "ast_class": "Name",
                "col_offset": 24,
                "ctx": {
                  "ast_class": "Load"
                },
                "end_col_offset": 39,
                "end_lineno": 14,
                "id": "cdhr_parameters",
                "lineno": 14
              }
            }
          },
          {
            "ast_class": "Assign",
            "col_offset": 4,
            "end_col_offset": 47,
            "end_lineno": 15,
            "lineno": 15,
            "targets": [
              {
                "ast_class": "Name",
                "col_offset": 4,
                "ctx": {
                  "ast_class": "Store"
                },
                "end_col_offset": 16,
                "end_lineno": 15,
                "id": "seuil_couple",
                "lineno": 15
              }
            ],
            "value": {
              "ast_class": "Attribute",
              "attr": "seuil_couple",
              "col_offset": 19,
              "ctx": {
                "ast_class": "Load"
              },
              "end_col_offset": 47,
              "end_lineno": 15,
              "lineno": 15,
              "value": {
                "ast_class": "Name",
                "col_offset": 19,
                "ctx": {
                  "ast_class": "Load"
                },
                "end_col_offset": 34,
                "end_lineno": 15,
                "id": "cdhr_parameters",
                "lineno": 15
              }
            }
          },
          {
            "ast_class": "Assign",
            "col_offset": 4,
            "end_col_offset": 47,
            "end_lineno": 16,
            "lineno": 16,
            "targets": [
              {
                "ast_class": "Name",
                "col_offset": 4,
                "ctx": {
                  "ast_class": "Store"
                },
                "end_col_offset": 12,
                "end_lineno": 16,
                "id": "nb_adult",
                "lineno": 16
              }
            ],
            "value": {
              "args": [
                {
                  "ast_class": "Constant",
                  "col_offset": 28,
                  "end_col_offset": 38,
                  "end_lineno": 16,
                  "lineno": 16,
                  "value": "nb_adult"
                },
                {
                  "ast_class": "Name",
                  "col_offset": 40,
                  "ctx": {
                    "ast_class": "Load"
                  },
                  "end_col_offset": 46,
                  "end_lineno": 16,
                  "id": "period",
                  "lineno": 16
                }
              ],
              "ast_class": "Call",
              "col_offset": 15,
              "end_col_offset": 47,
              "end_lineno": 16,
              "func": {
                "ast_class": "Name",
                "col_offset": 15,
                "ctx": {
                  "ast_class": "Load"
                },
                "end_col_offset": 27,
                "end_lineno": 16,
                "id": "foyer_fiscal",
                "lineno": 16
              },
              "keywords": [],
              "lineno": 16
            }
          },
          {
            "ast_class": "Assign",
            "col_offset": 4,
            "end_col_offset": 9,
            "end_lineno": 20,
            "lineno": 18,
            "targets": [
              {
                "ast_class": "Name",
                "col_offset": 4,
                "ctx": {
                  "ast_class": "Store"
                },
                "end_col_offset": 31,
                "end_lineno": 18,
                "id": "revenu_celibataire_eligible",
                "lineno": 18
              }
            ],
            "value": {
              "ast_class": "BinOp",
              "col_offset": 34,
              "end_col_offset": 9,
              "end_lineno": 20,
              "left": {
                "ast_class": "Compare",
                "col_offset": 35,
                "comparators": [
                  {
                    "ast_class": "Constant",
                    "col_offset": 47,
                    "end_col_offset": 48,
                    "end_lineno": 18,
                    "lineno": 18,
                    "value": 1
                  }
                ],
                "end_col_offset": 48,
                "end_lineno": 18,
                "left": {
                  "ast_class": "Name",
                  "col_offset": 35,
                  "ctx": {
                    "ast_class": "Load"
                  },
                  "end_col_offset": 43,
                  "end_lineno": 18,
                  "id": "nb_adult",
                  "lineno": 18
                },
                "lineno": 18,
                "ops": [
                  {
                    "ast_class": "Eq"
                  }
                ]
              },
              "lineno": 18,
              "op": {
                "ast_class": "Mult"
              },
              "right": {
                "ast_class": "Compare",
                "col_offset": 8,
                "comparators": [
                  {
                    "ast_class": "Name",
                    "col_offset": 63,
                    "ctx": {
                      "ast_class": "Load"
                    },
                    "end_col_offset": 80,
                    "end_lineno": 19,
                    "id": "seuil_celibataire",
                    "lineno": 19
                  }
                ],
                "end_col_offset": 80,
                "end_lineno": 19,
                "left": {
                  "ast_class": "Name",
                  "col_offset": 8,
                  "ctx": {
                    "ast_class": "Load"
                  },
                  "end_col_offset": 60,
                  "end_lineno": 19,
                  "id": "contribution_differentielle_hauts_revenus_ressources",
                  "lineno": 19
                },
                "lineno": 19,
                "ops": [
                  {
                    "ast_class": "Gt"
                  }
                ]
              }
            }
          },
          {
            "ast_class": "Assign",
            "col_offset": 4,
            "end_col_offset": 9,
            "end_lineno": 23,
            "lineno": 21,
            "targets": [
              {
                "ast_class": "Name",
                "col_offset": 4,
                "ctx": {
                  "ast_class": "Store"
                },
                "end_col_offset": 26,
                "end_lineno": 21,
                "id": "revenu_couple_eligible",
                "lineno": 21
              }
            ],
            "value": {
              "ast_class": "BinOp",
              "col_offset": 29,
              "end_col_offset": 9,
              "end_lineno": 23,
              "left": {
                "ast_class": "Compare",
                "col_offset": 30,
                "comparators": [
                  {
                    "ast_class": "Constant",
                    "col_offset": 42,
                    "end_col_offset": 43,
                    "end_lineno": 21,
                    "lineno": 21,
                    "value": 2
                  }
                ],
                "end_col_offset": 43,
                "end_lineno": 21,
                "left": {
                  "ast_class": "Name",
                  "col_offset": 30,
                  "ctx": {
                    "ast_class": "Load"
                  },
                  "end_col_offset": 38,
                  "end_lineno": 21,
                  "id": "nb_adult",
                  "lineno": 21
                },
                "lineno": 21,
                "ops": [
                  {
                    "ast_class": "Eq"
                  }
                ]
              },
              "lineno": 21,
              "op": {
                "ast_class": "Mult"
              },
              "right": {
                "ast_class": "Compare",
                "col_offset": 8,
                "comparators": [
                  {
                    "ast_class": "Name",
                    "col_offset": 63,
                    "ctx": {
                      "ast_class": "Load"
                    },
                    "end_col_offset": 75,
                    "end_lineno": 22,
                    "id": "seuil_couple",
                    "lineno": 22
                  }
                ],
                "end_col_offset": 75,
                "end_lineno": 22,
                "left": {
                  "ast_class": "Name",
                  "col_offset": 8,
                  "ctx": {
                    "ast_class": "Load"
                  },
                  "end_col_offset": 60,
                  "end_lineno": 22,
                  "id": "contribution_differentielle_hauts_revenus_ressources",
                  "lineno": 22
                },
                "lineno": 22,
                "ops": [
                  {
                    "ast_class": "Gt"
                  }
                ]
              }
            }
          },
          {
            "ast_class": "Return",
            "col_offset": 4,
            "end_col_offset": 63,
            "end_lineno": 25,
            "lineno": 25,
            "value": {
              "ast_class": "BinOp",
              "col_offset": 11,
              "end_col_offset": 63,
              "end_lineno": 25,
              "left": {
                "ast_class": "Name",
                "col_offset": 11,
                "ctx": {
                  "ast_class": "Load"
                },
                "end_col_offset": 38,
                "end_lineno": 25,
                "id": "revenu_celibataire_eligible",
                "lineno": 25
              },
              "lineno": 25,
              "op": {
                "ast_class": "Add"
              },
              "right": {
                "ast_class": "Name",
                "col_offset": 41,
                "ctx": {
                  "ast_class": "Load"
                },
                "end_col_offset": 63,
                "end_lineno": 25,
                "id": "revenu_couple_eligible",
                "lineno": 25
              }
            }
          }
        ],
        "col_offset": 0,
        "decorator_list": [],
        "end_col_offset": 63,
        "end_lineno": 25,
        "lineno": 1,
        "name": "formula_2025_01_01"
      },
      "file_path": "openfisca_france/model/prelevements_obligatoires/impot_revenu/contribution_differentielle_hauts_revenus.py",
      "parameters": [
        "impot_revenu.contributions_exceptionnelles.contribution_differentielle_hauts_revenus.seuil_celibataire",
        "impot_revenu.contributions_exceptionnelles.contribution_differentielle_hauts_revenus.seuil_couple"
      ],
      "source_code": "def formula_2025_01_01(foyer_fiscal, period, parameters):  # Sur revenus 2025\n    # I. - Il est institué une contribution à la charge des contribuables\n    # domiciliés fiscalement en France au sens de l’article 4 B (hypothèse = toujours vrai)\n    # dont le revenu du foyer fiscal tel que défini au II\n    contribution_differentielle_hauts_revenus_ressources = foyer_fiscal(\n        'contribution_differentielle_hauts_revenus_ressources', period\n        )\n    # est supérieur à 250 000 € pour les contribuables célibataires, veufs, séparés ou divorcés\n    # et à 500 000 € pour les contribuables soumis à imposition commune.\n    cdhr_parameters = parameters(\n        period\n        ).impot_revenu.contributions_exceptionnelles.contribution_differentielle_hauts_revenus\n    # info : montants de seuils égaux aux seuils du barème CEHR mais usage différent\n    seuil_celibataire = cdhr_parameters.seuil_celibataire\n    seuil_couple = cdhr_parameters.seuil_couple\n    nb_adult = foyer_fiscal('nb_adult', period)\n\n    revenu_celibataire_eligible = (nb_adult == 1) * (\n        contribution_differentielle_hauts_revenus_ressources > seuil_celibataire\n        )\n    revenu_couple_eligible = (nb_adult == 2) * (\n        contribution_differentielle_hauts_revenus_ressources > seuil_couple\n        )\n\n    return revenu_celibataire_eligible + revenu_couple_eligible\n",
      "start_line_number": 56,
      "stop_line_number": 81,
      "variables": [
        "contribution_differentielle_hauts_revenus_ressources",
        "nb_adult"
      ]
    }
  },
  "json_type": "number",
  "label": "Éligibilité à la contribution différentielle sur les hauts revenus",
  "last_value_still_valid_on": "2025-01-01",
  "name": "contribution_differentielle_hauts_revenus_eligible",
  "reference": {
    "0001-01-01": [
      {
        "href": "https://www.legifrance.gouv.fr/codes/article_lc/LEGIARTI000051200465/2025-02-16"
      }
    ]
  },
  "referring_variables": [
    "contribution_differentielle_hauts_revenus",
    "contribution_differentielle_hauts_revenus_decote"
  ],
  "start_line_number": 48,
  "stop_line_number": 81,
  "value_type": "float"
}
