Skip to content

Instantly share code, notes, and snippets.

@svschannak
Created February 27, 2023 12:58
Show Gist options
  • Save svschannak/04b27a977cd80bf7476a58d70cde41a0 to your computer and use it in GitHub Desktop.
Save svschannak/04b27a977cd80bf7476a58d70cde41a0 to your computer and use it in GitHub Desktop.
<pap name="Lohnsteuer2019Big" version="1.0" versionnummer="1.0">
<variables>
<!-- Stand: 2018-11-12 -->
<!-- ITZBund Düsseldorf-->
<!-- EINGABEPARAMETER -->
<inputs>
<!-- 1, wenn die Anwendung des Faktorverfahrens gewählt wurden (nur in Steuerklasse IV) -->
<input name="af" type="int" default="1"/>
<!-- Auf die Vollendung des 64. Lebensjahres folgende
Kalenderjahr (erforderlich, wenn ALTER1=1) -->
<input name="AJAHR" type="int"/>
<!-- 1, wenn das 64. Lebensjahr zu Beginn des Kalenderjahres vollendet wurde, in dem
der Lohnzahlungszeitraum endet (§ 24 a EStG), sonst = 0 -->
<input name="ALTER1" type="int"/>
<!-- in VKAPA und VMT enthaltene Entschädigungen nach §24 Nummer 1 EStG in Cent -->
<input name="ENTSCH" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- eingetragener Faktor mit drei Nachkommastellen -->
<input name="f" type="double" default="1.0"/>
<!-- Jahresfreibetrag nach Maßgabe der Eintragungen auf der
Lohnsteuerkarte in Cents (ggf. 0) -->
<input name="JFREIB" type="BigDecimal"/>
<!-- Jahreshinzurechnungsbetrag in Cents (ggf. 0) -->
<input name="JHINZU" type="BigDecimal"/>
<!-- Voraussichtlicher Jahresarbeitslohn ohne sonstige Bezüge und ohne Vergütung für mehrjährige Tätigkeit in Cent.
Anmerkung: Die Eingabe dieses Feldes (ggf. 0) ist erforderlich bei Eingabe „sonsti-ger Bezüge“ (Feld SONSTB)
oder bei Eingabe der „Vergütung für mehrjährige Tätigkeit“ (Feld VMT).
Sind in einem vorangegangenen Abrechnungszeitraum bereits sonstige Bezüge gezahlt worden, so sind sie dem
voraussichtlichen Jahresarbeitslohn hinzuzurechnen. Vergütungen für mehrere Jahres aus einem vorangegangenen
Abrechnungszeitraum sind in voller Höhe hinzuzurechnen. -->
<input name="JRE4" type="BigDecimal"/>
<!-- In JRE4 enthaltene Versorgungsbezuege in Cents (ggf. 0) -->
<input name="JVBEZ" type="BigDecimal"/>
<!--Merker für die Vorsorgepauschale
2 = der Arbeitnehmer ist NICHT in der gesetzlichen Rentenversicherung versichert.
1 = der Arbeitnehmer ist in der gesetzlichen Rentenversicherung versichert, es gilt die
Beitragsbemessungsgrenze OST.
0 = der Arbeitnehmer ist in der gesetzlichen Rentenversicherung versichert, es gilt die
Beitragsbemessungsgrenze WEST. -->
<input name="KRV" type="int"/>
<!-- Einkommensbezogener Zusatzbeitragssatz eines gesetzlich krankenversicherten Arbeitnehmers,
auf dessen Basis der an die Krankenkasse zu zahlende Zusatzbeitrag berechnet wird,
in Prozent (bspw. 0,90 für 0,90 %) mit 2 Dezimalstellen.
Der von der Kranken-kasse festgesetzte Zusatzbeitragssatz ist bei Abweichungen unmaßgeblich. -->
<input name="KVZ" type="BigDecimal"/>
<!-- Lohnzahlungszeitraum:
1 = Jahr
2 = Monat
3 = Woche
4 = Tag -->
<input name="LZZ" type="int"/>
<!-- In der Lohnsteuerkarte des Arbeitnehmers eingetragener Freibetrag für
den Lohnzahlungszeitraum in Cent -->
<input name="LZZFREIB" type="BigDecimal"/>
<!-- In der Lohnsteuerkarte des Arbeitnehmers eingetragener Hinzurechnungsbetrag
für den Lohnzahlungszeitraum in Cent -->
<input name="LZZHINZU" type="BigDecimal"/>
<!-- Dem Arbeitgeber mitgeteilte Zahlungen des Arbeitnehmers zur privaten
Kranken- bzw. Pflegeversicherung im Sinne des §10 Abs. 1 Nr. 3 EStG 2010
als Monatsbetrag in Cent (der Wert ist inabhängig vom Lohnzahlungszeitraum immer
als Monatsbetrag anzugeben).-->
<input name="PKPV" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Krankenversicherung:
0 = gesetzlich krankenversicherte Arbeitnehmer
1 = ausschließlich privat krankenversicherte Arbeitnehmer OHNE Arbeitgeberzuschuss
2 = ausschließlich privat krankenversicherte Arbeitnehmer MIT Arbeitgeberzuschuss -->
<input name="PKV" type="int" default="0"/>
<!-- 1, wenn bei der sozialen Pflegeversicherung die Besonderheiten in Sachsen zu berücksichtigen sind bzw.
zu berücksichtigen wären, sonst 0. -->
<input name="PVS" type="int" default="0"/>
<!-- 1, wenn er der Arbeitnehmer den Zuschlag zur sozialen Pflegeversicherung
zu zahlen hat, sonst 0. -->
<input name="PVZ" type="int" default="0"/>
<!-- Religionsgemeinschaft des Arbeitnehmers lt. Lohnsteuerkarte (bei
keiner Religionszugehoerigkeit = 0) -->
<input name="R" type="int"/>
<!-- Steuerpflichtiger Arbeitslohn vor Beruecksichtigung der Freibetraege
fuer Versorgungsbezuege, des Altersentlastungsbetrags und des auf
der Lohnsteuerkarte fuer den Lohnzahlungszeitraum eingetragenen
Freibetrags in Cents. -->
<input name="RE4" type="BigDecimal"/>
<!-- Sonstige Bezuege (ohne Verguetung aus mehrjaehriger Taetigkeit) einschliesslich
Sterbegeld bei Versorgungsbezuegen sowie Kapitalauszahlungen/Abfindungen,
soweit es sich nicht um Bezuege fuer mehrere Jahre handelt in Cents (ggf. 0) -->
<input name="SONSTB" type="BigDecimal"/>
<!-- Sterbegeld bei Versorgungsbezuegen sowie Kapitalauszahlungen/Abfindungen,
soweit es sich nicht um Bezuege fuer mehrere Jahre handelt
(in SONSTB enthalten) in Cents -->
<input name="STERBE" type="BigDecimal" regex_test="" regex_transform=""/>
<!-- Steuerklasse:
1 = I
2 = II
3 = III
4 = IV
5 = V
6 = VI -->
<input name="STKL" type="int"/>
<!-- In RE4 enthaltene Versorgungsbezuege in Cents (ggf. 0) -->
<input name="VBEZ" type="BigDecimal"/>
<!-- Vorsorgungsbezug im Januar 2005 bzw. fuer den ersten vollen Monat
in Cents-->
<input name="VBEZM" type="BigDecimal"/>
<!-- Voraussichtliche Sonderzahlungen im Kalenderjahr des Versorgungsbeginns
bei Versorgungsempfaengern ohne Sterbegeld, Kapitalauszahlungen/Abfindungen
bei Versorgungsbezuegen in Cents-->
<input name="VBEZS" type="BigDecimal"/>
<!-- In SONSTB enthaltene Versorgungsbezuege einschliesslich Sterbegeld
in Cents (ggf. 0) -->
<input name="VBS" type="BigDecimal"/>
<!-- Jahr, in dem der Versorgungsbezug erstmalig gewaehrt wurde; werden
mehrere Versorgungsbezuege gezahlt, so gilt der aelteste erstmalige Bezug -->
<input name="VJAHR" type="int" regex_test="" regex_transform=""/>
<!-- Kapitalauszahlungen / Abfindungen / Nachzahlungen bei Versorgungsbezügen
für mehrere Jahre in Cent (ggf. 0) -->
<input name="VKAPA" type="BigDecimal" regex_test="" regex_transform=""/>
<!-- Vergütung für mehrjährige Tätigkeit ohne Kapitalauszahlungen und ohne Abfindungen
bei Versorgungsbezügen in Cent (ggf. 0) -->
<input name="VMT" type="BigDecimal" regex_test="" regex_transform=""/>
<!-- Zahl der Freibetraege fuer Kinder (eine Dezimalstelle, nur bei Steuerklassen
I, II, III und IV) -->
<input name="ZKF" type="BigDecimal" regex_test="" regex_transform=""/>
<!-- Zahl der Monate, fuer die Versorgungsbezuege gezahlt werden (nur
erforderlich bei Jahresberechnung (LZZ = 1) -->
<input name="ZMVB" type="int" regex_test="" regex_transform=""/>
<!-- In JRE4 enthaltene Entschädigungen nach § 24 Nummer 1 EStG in Cent -->
<input name="JRE4ENT" type="BigDecimal" default="BigDecimal.ZERO"/>
<!-- In SONSTB enthaltene Entschädigungen nach § 24 Nummer 1 EStG in Cent -->
<input name="SONSTENT" type="BigDecimal" default="BigDecimal.ZERO"/>
</inputs>
<!-- AUSGABEPARAMETER -->
<outputs type="STANDARD">
<!-- Bemessungsgrundlage fuer die Kirchenlohnsteuer in Cents -->
<output name="BK" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Bemessungsgrundlage der sonstigen Einkuenfte (ohne Verguetung
fuer mehrjaehrige Taetigkeit) fuer die Kirchenlohnsteuer in Cents -->
<output name="BKS" type="BigDecimal" default="new BigDecimal(0)"/>
<output name="BKV" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Fuer den Lohnzahlungszeitraum einzubehaltende Lohnsteuer in Cents -->
<output name="LSTLZZ" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Fuer den Lohnzahlungszeitraum einzubehaltender Solidaritaetszuschlag
in Cents -->
<output name="SOLZLZZ" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Solidaritaetszuschlag fuer sonstige Bezuege (ohne Verguetung fuer mehrjaehrige
Taetigkeit) in Cents -->
<output name="SOLZS" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Solidaritaetszuschlag fuer die Verguetung fuer mehrjaehrige Taetigkeit in
Cents -->
<output name="SOLZV" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Lohnsteuer fuer sonstige Einkuenfte (ohne Verguetung fuer mehrjaehrige
Taetigkeit) in Cents -->
<output name="STS" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Lohnsteuer fuer Verguetung fuer mehrjaehrige Taetigkeit in Cents -->
<output name="STV" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Für den Lohnzahlungszeitraum berücksichtigte Beiträge des Arbeitnehmers zur
privaten Basis-Krankenversicherung und privaten Pflege-Pflichtversicherung (ggf. auch
die Mindestvorsorgepauschale) in Cent beim laufenden Arbeitslohn. Für Zwecke der Lohn-
steuerbescheinigung sind die einzelnen Ausgabewerte außerhalb des eigentlichen Lohn-
steuerbescheinigungsprogramms zu addieren; hinzuzurechnen sind auch die Ausgabewerte
VKVSONST -->
<output name="VKVLZZ" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Für den Lohnzahlungszeitraum berücksichtigte Beiträge des Arbeitnehmers
zur privaten Basis-Krankenversicherung und privaten Pflege-Pflichtversicherung (ggf.
auch die Mindestvorsorgepauschale) in Cent bei sonstigen Bezügen. Der Ausgabewert kann
auch negativ sein. Für tarifermäßigt zu besteuernde Vergütungen für mehrjährige
Tätigkeiten enthält der PAP keinen entsprechenden Ausgabewert. -->
<output name="VKVSONST" type="BigDecimal" default="new BigDecimal(0)"/>
</outputs>
<!-- AUSGABEPARAMETER DBA -->
<outputs type="DBA">
<!-- Verbrauchter Freibetrag bei Berechnung des laufenden Arbeitslohns, in Cent -->
<output name="VFRB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Verbrauchter Freibetrag bei Berechnung des voraussichtlichen Jahresarbeitslohns, in Cent -->
<output name="VFRBS1" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Verbrauchter Freibetrag bei Berechnung der sonstigen Bezüge, in Cent -->
<output name="VFRBS2" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Für die weitergehende Berücksichtigung des Steuerfreibetrags nach dem DBA Türkei verfügbares ZVE über
dem Grundfreibetrag bei der Berechnung des laufenden Arbeitslohns, in Cent -->
<output name="WVFRB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Für die weitergehende Berücksichtigung des Steuerfreibetrags nach dem DBA Türkei verfügbares ZVE über dem Grundfreibetrag
bei der Berechnung des voraussichtlichen Jahresarbeitslohns, in Cent -->
<output name="WVFRBO" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Für die weitergehende Berücksichtigung des Steuerfreibetrags nach dem DBA Türkei verfügbares ZVE
über dem Grundfreibetrag bei der Berechnung der sonstigen Bezüge, in Cent -->
<output name="WVFRBM" type="BigDecimal" default="new BigDecimal(0)"/>
</outputs>
<!-- INTERNE FELDER -->
<internals>
<!-- Altersentlastungsbetrag nach Alterseinkünftegesetz in €,
Cent (2 Dezimalstellen) -->
<internal name="ALTE" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Arbeitnehmer-Pauschbetrag in EURO -->
<internal name="ANP" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Auf den Lohnzahlungszeitraum entfallender Anteil von Jahreswerten
auf ganze Cents abgerundet -->
<internal name="ANTEIL1" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Bemessungsgrundlage für Altersentlastungsbetrag in €, Cent
(2 Dezimalstellen) -->
<internal name="BMG" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Beitragsbemessungsgrenze in der gesetzlichen Krankenversicherung
und der sozialen Pflegeversicherung in Euro -->
<internal name="BBGKVPV" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Nach Programmablaufplan 2019 -->
<internal name="bd" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- allgemeine Beitragsbemessungsgrenze in der allgemeinen Renten-versicherung in Euro -->
<internal name="BBGRV" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Differenz zwischen ST1 und ST2 in EURO -->
<internal name="DIFF" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Entlastungsbetrag fuer Alleinerziehende in EURO -->
<internal name="EFA" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Versorgungsfreibetrag in €, Cent (2 Dezimalstellen) -->
<internal name="FVB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Versorgungsfreibetrag in €, Cent (2 Dezimalstellen) für die Berechnung
der Lohnsteuer für den sonstigen Bezug -->
<internal name="FVBSO" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zuschlag zum Versorgungsfreibetrag in EURO -->
<internal name="FVBZ" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zuschlag zum Versorgungsfreibetrag in EURO fuer die Berechnung
der Lohnsteuer beim sonstigen Bezug -->
<internal name="FVBZSO" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Grundfreibetrag in Euro -->
<internal name="GFB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Maximaler Altersentlastungsbetrag in € -->
<internal name="HBALTE" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Massgeblicher maximaler Versorgungsfreibetrag in € -->
<internal name="HFVB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Massgeblicher maximaler Zuschlag zum Versorgungsfreibetrag in €,Cent
(2 Dezimalstellen) -->
<internal name="HFVBZ" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Massgeblicher maximaler Zuschlag zum Versorgungsfreibetrag in €, Cent
(2 Dezimalstellen) für die Berechnung der Lohnsteuer für den
sonstigen Bezug -->
<internal name="HFVBZSO" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Nummer der Tabellenwerte fuer Versorgungsparameter -->
<internal name="J" type="int" default="0"/>
<!-- Jahressteuer nach § 51a EStG, aus der Solidaritaetszuschlag und
Bemessungsgrundlage fuer die Kirchenlohnsteuer ermittelt werden in EURO -->
<internal name="JBMG" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Auf einen Jahreslohn hochgerechneter LZZFREIB in €, Cent
(2 Dezimalstellen) -->
<internal name="JLFREIB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Auf einen Jahreslohn hochgerechnete LZZHINZU in €, Cent
(2 Dezimalstellen) -->
<internal name="JLHINZU" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Jahreswert, dessen Anteil fuer einen Lohnzahlungszeitraum in
UPANTEIL errechnet werden soll in Cents -->
<internal name="JW" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Nummer der Tabellenwerte fuer Parameter bei Altersentlastungsbetrag -->
<internal name="K" type="int" default="0"/>
<!-- Merker für Berechnung Lohnsteuer für mehrjährige Tätigkeit.
0 = normale Steuerberechnung
1 = Steuerberechnung für mehrjährige Tätigkeit
2 = entfällt -->
<internal name="KENNVMT" type="int" default="0"/>
<!-- Summe der Freibetraege fuer Kinder in EURO -->
<internal name="KFB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Beitragssatz des Arbeitgebers zur Krankenversicherung -->
<internal name="KVSATZAG" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Beitragssatz des Arbeitnehmers zur Krankenversicherung -->
<internal name="KVSATZAN" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Kennzahl fuer die Einkommensteuer-Tabellenart:
1 = Grundtabelle
2 = Splittingtabelle -->
<internal name="KZTAB" type="int" default="0"/>
<!-- Jahreslohnsteuer in EURO -->
<internal name="LSTJAHR" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zwischenfelder der Jahreslohnsteuer in Cent -->
<internal name="LST1" type="BigDecimal" default="new BigDecimal(0)"/>
<internal name="LST2" type="BigDecimal" default="new BigDecimal(0)"/>
<internal name="LST3" type="BigDecimal" default="new BigDecimal(0)"/>
<internal name="LSTOSO" type="BigDecimal" default="new BigDecimal(0)"/>
<internal name="LSTSO" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Mindeststeuer fuer die Steuerklassen V und VI in EURO -->
<internal name="MIST" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Beitragssatz des Arbeitgebers zur Pflegeversicherung -->
<internal name="PVSATZAG" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Beitragssatz des Arbeitnehmers zur Pflegeversicherung -->
<internal name="PVSATZAN" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Beitragssatz des Arbeitnehmers in der allgemeinen gesetzlichen Rentenversicherung (4 Dezimalstellen) -->
<internal name="RVSATZAN" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Rechenwert in Gleitkommadarstellung -->
<internal name="RW" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Sonderausgaben-Pauschbetrag in EURO -->
<internal name="SAP" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Freigrenze fuer den Solidaritaetszuschlag in EURO -->
<internal name="SOLZFREI" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Solidaritaetszuschlag auf die Jahreslohnsteuer in EURO, C (2 Dezimalstellen) -->
<internal name="SOLZJ" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zwischenwert fuer den Solidaritaetszuschlag auf die Jahreslohnsteuer
in EURO, C (2 Dezimalstellen) -->
<internal name="SOLZMIN" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Tarifliche Einkommensteuer in EURO -->
<internal name="ST" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Tarifliche Einkommensteuer auf das 1,25-fache ZX in EURO -->
<internal name="ST1" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Tarifliche Einkommensteuer auf das 0,75-fache ZX in EURO -->
<internal name="ST2" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zwischenfeld zur Ermittlung der Steuer auf Vergütungen für mehrjährige Tätigkeit -->
<internal name="STOVMT" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Teilbetragssatz der Vorsorgepauschale für die Rentenversicherung (2 Dezimalstellen) -->
<internal name="TBSVORV" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Bemessungsgrundlage fuer den Versorgungsfreibetrag in Cents -->
<internal name="VBEZB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Bemessungsgrundlage für den Versorgungsfreibetrag in Cent für
den sonstigen Bezug -->
<internal name="VBEZBSO" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Hoechstbetrag der Vorsorgepauschale nach Alterseinkuenftegesetz in EURO, C -->
<internal name="VHB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Vorsorgepauschale in EURO, C (2 Dezimalstellen) -->
<internal name="VSP" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Vorsorgepauschale nach Alterseinkuenftegesetz in EURO, C -->
<internal name="VSPN" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zwischenwert 1 bei der Berechnung der Vorsorgepauschale nach
dem Alterseinkuenftegesetz in EURO, C (2 Dezimalstellen) -->
<internal name="VSP1" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zwischenwert 2 bei der Berechnung der Vorsorgepauschale nach
dem Alterseinkuenftegesetz in EURO, C (2 Dezimalstellen) -->
<internal name="VSP2" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Vorsorgepauschale mit Teilbeträgen für die gesetzliche Kranken- und
soziale Pflegeversicherung nach fiktiven Beträgen oder ggf. für die
private Basiskrankenversicherung und private Pflege-Pflichtversicherung
in Euro, Cent (2 Dezimalstellen) -->
<internal name="VSP3" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Erster Grenzwert in Steuerklasse V/VI in Euro -->
<internal name="W1STKL5" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zweiter Grenzwert in Steuerklasse V/VI in Euro -->
<internal name="W2STKL5" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Dritter Grenzwert in Steuerklasse V/VI in Euro -->
<internal name="W3STKL5" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Hoechstbetrag der Vorsorgepauschale nach § 10c Abs. 2 Nr. 2 EStG in EURO -->
<internal name="VSPMAX1" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Hoechstbetrag der Vorsorgepauschale nach § 10c Abs. 2 Nr. 3 EStG in EURO -->
<internal name="VSPMAX2" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Vorsorgepauschale nach § 10c Abs. 2 Satz 2 EStG vor der Hoechstbetragsberechnung
in EURO, C (2 Dezimalstellen) -->
<internal name="VSPO" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Fuer den Abzug nach § 10c Abs. 2 Nrn. 2 und 3 EStG verbleibender
Rest von VSPO in EURO, C (2 Dezimalstellen) -->
<internal name="VSPREST" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Hoechstbetrag der Vorsorgepauschale nach § 10c Abs. 2 Nr. 1 EStG
in EURO, C (2 Dezimalstellen) -->
<internal name="VSPVOR" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zu versteuerndes Einkommen gem. § 32a Abs. 1 und 2 EStG €, C
(2 Dezimalstellen) -->
<internal name="X" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- gem. § 32a Abs. 1 EStG (6 Dezimalstellen) -->
<internal name="Y" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Auf einen Jahreslohn hochgerechnetes RE4 in €, C (2 Dezimalstellen)
nach Abzug der Freibeträge nach § 39 b Abs. 2 Satz 3 und 4. -->
<internal name="ZRE4" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Auf einen Jahreslohn hochgerechnetes RE4 in €, C (2 Dezimalstellen) -->
<internal name="ZRE4J" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Auf einen Jahreslohn hochgerechnetes RE4 in €, C (2 Dezimalstellen)
nach Abzug des Versorgungsfreibetrags und des Alterentlastungsbetrags
zur Berechnung der Vorsorgepauschale in €, Cent (2 Dezimalstellen) -->
<internal name="ZRE4VP" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Feste Tabellenfreibeträge (ohne Vorsorgepauschale) in €, Cent
(2 Dezimalstellen) -->
<internal name="ZTABFB" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Auf einen Jahreslohn hochgerechnetes (VBEZ abzueglich FVB) in
EURO, C (2 Dezimalstellen) -->
<internal name="ZVBEZ" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Auf einen Jahreslohn hochgerechnetes VBEZ in €, C (2 Dezimalstellen) -->
<internal name="ZVBEZJ" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zu versteuerndes Einkommen in €, C (2 Dezimalstellen) -->
<internal name="ZVE" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Zwischenfelder zu X fuer die Berechnung der Steuer nach § 39b
Abs. 2 Satz 7 EStG in € -->
<internal name="ZX" type="BigDecimal" default="new BigDecimal(0)"/>
<internal name="ZZX" type="BigDecimal" default="new BigDecimal(0)"/>
<internal name="HOCH" type="BigDecimal" default="new BigDecimal(0)"/>
<internal name="VERGL" type="BigDecimal" default="new BigDecimal(0)"/>
<!-- Jahreswert der berücksichtigten Beiträge zur privaten Basis-Krankenversicherung und
privaten Pflege-Pflichtversicherung (ggf. auch die Mindestvorsorgepauschale) in Cent. -->
<internal name="VKV" type="BigDecimal" default="new BigDecimal(0)"/>
</internals>
</variables>
<constants>
<!-- Tabelle fuer die Vomhundertsaetze des Versorgungsfreibetrags -->
<constant name="TAB1" type="BigDecimal[]" value="{BigDecimal.valueOf (0.0), BigDecimal.valueOf (0.4), BigDecimal.valueOf (0.384), BigDecimal.valueOf (0.368),
BigDecimal.valueOf (0.352), BigDecimal.valueOf (0.336), BigDecimal.valueOf (0.32), BigDecimal.valueOf (0.304),
BigDecimal.valueOf (0.288), BigDecimal.valueOf (0.272), BigDecimal.valueOf (0.256), BigDecimal.valueOf (0.24),
BigDecimal.valueOf (0.224), BigDecimal.valueOf (0.208), BigDecimal.valueOf (0.192), BigDecimal.valueOf (0.176),
BigDecimal.valueOf (0.16), BigDecimal.valueOf (0.152), BigDecimal.valueOf (0.144), BigDecimal.valueOf (0.136),
BigDecimal.valueOf (0.128), BigDecimal.valueOf (0.12), BigDecimal.valueOf (0.112), BigDecimal.valueOf (0.104),
BigDecimal.valueOf (0.096), BigDecimal.valueOf (0.088), BigDecimal.valueOf (0.08), BigDecimal.valueOf (0.072),
BigDecimal.valueOf (0.064), BigDecimal.valueOf (0.056), BigDecimal.valueOf (0.048), BigDecimal.valueOf (0.04),
BigDecimal.valueOf (0.032), BigDecimal.valueOf (0.024), BigDecimal.valueOf (0.016), BigDecimal.valueOf (0.008),
BigDecimal.valueOf (0.0)}"/>
<!-- Tabelle fuer die Hoechstbetrage des Versorgungsfreibetrags -->
<constant name="TAB2" type="BigDecimal[]" value="{BigDecimal.valueOf (0), BigDecimal.valueOf (3000), BigDecimal.valueOf (2880),
BigDecimal.valueOf (2760), BigDecimal.valueOf (2640), BigDecimal.valueOf (2520), BigDecimal.valueOf (2400),
BigDecimal.valueOf (2280), BigDecimal.valueOf (2160), BigDecimal.valueOf (2040), BigDecimal.valueOf (1920),
BigDecimal.valueOf (1800), BigDecimal.valueOf (1680), BigDecimal.valueOf (1560), BigDecimal.valueOf (1440),
BigDecimal.valueOf (1320), BigDecimal.valueOf (1200), BigDecimal.valueOf (1140), BigDecimal.valueOf (1080),
BigDecimal.valueOf (1020), BigDecimal.valueOf (960), BigDecimal.valueOf (900), BigDecimal.valueOf (840),
BigDecimal.valueOf (780), BigDecimal.valueOf (720), BigDecimal.valueOf (660), BigDecimal.valueOf (600),
BigDecimal.valueOf (540), BigDecimal.valueOf (480), BigDecimal.valueOf (420), BigDecimal.valueOf (360),
BigDecimal.valueOf (300), BigDecimal.valueOf (240), BigDecimal.valueOf (180), BigDecimal.valueOf (120),
BigDecimal.valueOf (60), BigDecimal.valueOf (0)}"/>
<!-- Tabelle fuer die Zuschlaege zum Versorgungsfreibetrag -->
<constant name="TAB3" type="BigDecimal[]" value="{BigDecimal.valueOf (0), BigDecimal.valueOf (900), BigDecimal.valueOf (864),
BigDecimal.valueOf (828), BigDecimal.valueOf (792), BigDecimal.valueOf (756), BigDecimal.valueOf (720),
BigDecimal.valueOf (684), BigDecimal.valueOf (648), BigDecimal.valueOf (612), BigDecimal.valueOf (576),
BigDecimal.valueOf (540), BigDecimal.valueOf (504), BigDecimal.valueOf (468), BigDecimal.valueOf (432),
BigDecimal.valueOf (396), BigDecimal.valueOf (360), BigDecimal.valueOf (342), BigDecimal.valueOf (324),
BigDecimal.valueOf (306), BigDecimal.valueOf (288), BigDecimal.valueOf (270), BigDecimal.valueOf (252),
BigDecimal.valueOf (234), BigDecimal.valueOf (216), BigDecimal.valueOf (198), BigDecimal.valueOf (180),
BigDecimal.valueOf (162), BigDecimal.valueOf (144), BigDecimal.valueOf (126), BigDecimal.valueOf (108),
BigDecimal.valueOf (90), BigDecimal.valueOf (72), BigDecimal.valueOf (54), BigDecimal.valueOf (36),
BigDecimal.valueOf (18), BigDecimal.valueOf (0)}"/>
<!-- Tabelle fuer die Vomhundertsaetze des Altersentlastungsbetrags -->
<constant name="TAB4" type="BigDecimal[]" value="{BigDecimal.valueOf (0.0), BigDecimal.valueOf (0.4), BigDecimal.valueOf (0.384),
BigDecimal.valueOf (0.368), BigDecimal.valueOf (0.352), BigDecimal.valueOf (0.336), BigDecimal.valueOf (0.32),
BigDecimal.valueOf (0.304), BigDecimal.valueOf (0.288), BigDecimal.valueOf (0.272), BigDecimal.valueOf (0.256),
BigDecimal.valueOf (0.24), BigDecimal.valueOf (0.224), BigDecimal.valueOf (0.208), BigDecimal.valueOf (0.192),
BigDecimal.valueOf (0.176), BigDecimal.valueOf (0.16), BigDecimal.valueOf (0.152), BigDecimal.valueOf (0.144),
BigDecimal.valueOf (0.136), BigDecimal.valueOf (0.128), BigDecimal.valueOf (0.12), BigDecimal.valueOf (0.112),
BigDecimal.valueOf (0.104), BigDecimal.valueOf (0.096), BigDecimal.valueOf (0.088), BigDecimal.valueOf (0.08),
BigDecimal.valueOf (0.072), BigDecimal.valueOf (0.064), BigDecimal.valueOf (0.056), BigDecimal.valueOf (0.048),
BigDecimal.valueOf (0.04), BigDecimal.valueOf (0.032), BigDecimal.valueOf (0.024), BigDecimal.valueOf (0.016),
BigDecimal.valueOf (0.008), BigDecimal.valueOf (0.0)}"/>
<!-- Tabelle fuer die Hoechstbetraege des Altersentlastungsbetrags -->
<constant name="TAB5" type="BigDecimal[]" value="{BigDecimal.valueOf (0), BigDecimal.valueOf (1900), BigDecimal.valueOf (1824),
BigDecimal.valueOf (1748), BigDecimal.valueOf (1672), BigDecimal.valueOf (1596), BigDecimal.valueOf (1520),
BigDecimal.valueOf (1444), BigDecimal.valueOf (1368), BigDecimal.valueOf (1292), BigDecimal.valueOf (1216),
BigDecimal.valueOf (1140), BigDecimal.valueOf (1064), BigDecimal.valueOf (988), BigDecimal.valueOf (912),
BigDecimal.valueOf (836), BigDecimal.valueOf (760), BigDecimal.valueOf (722), BigDecimal.valueOf (684),
BigDecimal.valueOf (646), BigDecimal.valueOf (608), BigDecimal.valueOf (570), BigDecimal.valueOf (532),
BigDecimal.valueOf (494), BigDecimal.valueOf (456), BigDecimal.valueOf (418), BigDecimal.valueOf (380),
BigDecimal.valueOf (342), BigDecimal.valueOf (304), BigDecimal.valueOf (266), BigDecimal.valueOf (228),
BigDecimal.valueOf (190), BigDecimal.valueOf (152), BigDecimal.valueOf (114), BigDecimal.valueOf (76),
BigDecimal.valueOf (38), BigDecimal.valueOf (0)}"/>
<!-- Zahlenkonstanten fuer im Plan oft genutzte BigDecimal Werte -->
<constant name="ZAHL1" type="BigDecimal" value="BigDecimal.ONE"/>
<constant name="ZAHL2" type="BigDecimal" value="new BigDecimal(2)"/>
<constant name="ZAHL5" type="BigDecimal" value="new BigDecimal(5)"/>
<constant name="ZAHL7" type="BigDecimal" value="new BigDecimal(7)"/>
<constant name="ZAHL12" type="BigDecimal" value="new BigDecimal(12)"/>
<constant name="ZAHL100" type="BigDecimal" value="new BigDecimal(100)"/>
<constant name="ZAHL360" type="BigDecimal" value="new BigDecimal(360)"/>
<constant name="ZAHL500" type="BigDecimal" value="new BigDecimal(500)"/>
<constant name="ZAHL700" type="BigDecimal" value="new BigDecimal(700)"/>
<constant name="ZAHL1000" type="BigDecimal" value="new BigDecimal(1000)"/>
<constant name="ZAHL10000" type="BigDecimal" value="new BigDecimal(10000)"/>
</constants>
<methods>
<!-- PROGRAMMABLAUFPLAN, PAP Seite 13 -->
<main>
<execute method="MPARA"/>
<execute method="MRE4JL"/>
<eval exec="VBEZBSO= BigDecimal.ZERO"/>
<eval exec="KENNVMT= 0"/>
<execute method="MRE4"/>
<execute method="MRE4ABZ"/>
<execute method="MBERECH"/>
<execute method="MSONST"/>
<execute method="MVMT"/>
</main>
<!-- Zuweisung von Werten für bestimmte Sozialversicherungsparameter PAP Seite 14 -->
<method name="MPARA">
<if expr="KRV < 2"><!-- &lt; = < -->
<then>
<if expr="KRV == 0">
<then>
<eval exec="BBGRV = new BigDecimal(80400)"/> <!-- Neu 2019 -->
</then>
<else>
<eval exec="BBGRV = new BigDecimal(73800)"/> <!-- Neu 2019 -->
</else>
</if>
<eval exec="RVSATZAN = BigDecimal.valueOf(0.093)"/> <!-- Neu 2019 -->
<eval exec="TBSVORV = BigDecimal.valueOf(0.76)"/> <!-- Neu 2019 -->
</then>
<else>
<!-- Nichts zu tun -->
</else>
</if>
<eval exec="BBGKVPV = new BigDecimal(54450)"/> <!-- Neu 2019 -->
<eval exec="bd = new BigDecimal(2)"/><!-- Neu 2019 -->
<eval exec="KVSATZAN = (KVZ.divide(bd).divide(ZAHL100)).add(BigDecimal.valueOf(0.07))"/><!-- Neu 2019 -->
<eval exec="KVSATZAG = BigDecimal.valueOf(0.0045+0.07)"/><!-- Neu 2019 -->
<if expr="PVS == 1">
<then>
<eval exec="PVSATZAN = BigDecimal.valueOf(0.02025)"/> <!-- Neu 2019 -->
<eval exec="PVSATZAG = BigDecimal.valueOf(0.01025)"/> <!-- Neu 2019 -->
</then>
<else>
<eval exec="PVSATZAN = BigDecimal.valueOf(0.01525)"/> <!-- Neu 2019 -->
<eval exec="PVSATZAG = BigDecimal.valueOf(0.01525)"/> <!-- Neu 2019 -->
</else>
</if>
<if expr="PVZ == 1">
<then>
<eval exec="PVSATZAN = PVSATZAN.add(BigDecimal.valueOf(0.0025))"/>
</then>
</if>
<!-- Anfang Neu 2019 -->
<eval exec="W1STKL5 = new BigDecimal(10635)"/>
<eval exec="W2STKL5 = new BigDecimal(27980)"/>
<eval exec="W3STKL5 = new BigDecimal(212261)"/>
<eval exec="GFB = new BigDecimal(9168)"/>
<!-- Ende Neu 2019 -->
<eval exec="SOLZFREI = new BigDecimal(972)"/>
</method>
<!-- Ermittlung des Jahresarbeitslohns nach § 39 b Abs. 2 Satz 2 EStG, PAP Seite 15 -->
<method name="MRE4JL">
<if expr="LZZ == 1">
<then>
<eval exec="ZRE4J= RE4.divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="ZVBEZJ= VBEZ.divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLFREIB= LZZFREIB.divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLHINZU= LZZHINZU.divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<if expr="LZZ == 2">
<then>
<eval exec="ZRE4J= (RE4.multiply (ZAHL12)).divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="ZVBEZJ= (VBEZ.multiply (ZAHL12)).divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLFREIB= (LZZFREIB.multiply (ZAHL12)).divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLHINZU= (LZZHINZU.multiply (ZAHL12)).divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<if expr="LZZ == 3">
<then>
<eval exec="ZRE4J= (RE4.multiply (ZAHL360)).divide (ZAHL700, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="ZVBEZJ= (VBEZ.multiply (ZAHL360)).divide (ZAHL700, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLFREIB= (LZZFREIB.multiply (ZAHL360)).divide (ZAHL700, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLHINZU= (LZZHINZU.multiply (ZAHL360)).divide (ZAHL700, 2, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<eval exec="ZRE4J= (RE4.multiply (ZAHL360)).divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="ZVBEZJ= (VBEZ.multiply (ZAHL360)).divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLFREIB= (LZZFREIB.multiply (ZAHL360)).divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLHINZU= (LZZHINZU.multiply (ZAHL360)).divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
</else>
</if>
</else>
</if>
</else>
</if>
<if expr="af == 0">
<then>
<eval exec="f= 1"/>
</then>
</if>
</method>
<!-- Freibeträge für Versorgungsbezüge, Altersentlastungsbetrag (§ 39b Abs. 2 Satz 3 EStG), PAP Seite 16 -->
<method name="MRE4">
<if expr="ZVBEZJ.compareTo (BigDecimal.ZERO) == 0">
<then>
<eval exec="FVBZ= BigDecimal.ZERO"/>
<eval exec="FVB= BigDecimal.ZERO"/>
<eval exec="FVBZSO= BigDecimal.ZERO"/>
<eval exec="FVBSO= BigDecimal.ZERO"/>
</then>
<else>
<if expr="VJAHR < 2006">
<then>
<eval exec="J= 1"/>
</then>
<else>
<if expr="VJAHR < 2040">
<then>
<eval exec="J= VJAHR - 2004"/>
</then>
<else>
<eval exec="J= 36"/>
</else>
</if>
</else>
</if>
<if expr="LZZ == 1">
<then>
<eval exec="VBEZB= (VBEZM.multiply (BigDecimal.valueOf (ZMVB))).add (VBEZS)"/>
<eval exec="HFVB= TAB2[J].divide (ZAHL12).multiply (BigDecimal.valueOf (ZMVB))"/>
<eval exec="FVBZ= TAB3[J].divide (ZAHL12).multiply (BigDecimal.valueOf (ZMVB)).setScale (0, BigDecimal.ROUND_UP)"/>
</then>
<else>
<eval exec="VBEZB= ((VBEZM.multiply (ZAHL12)).add (VBEZS)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<eval exec="HFVB= TAB2[J]"/>
<eval exec="FVBZ= TAB3[J]"/>
</else>
</if>
<eval exec="FVB= ((VBEZB.multiply (TAB1[J]))).divide (ZAHL100).setScale (2, BigDecimal.ROUND_UP)"/>
<if expr="FVB.compareTo (HFVB) == 1">
<then>
<eval exec="FVB = HFVB"/>
</then>
</if>
<if expr="FVB.compareTo (ZVBEZJ) == 1">
<then>
<eval exec="FVB = ZVBEZJ"/>
</then>
</if>
<eval exec="FVBSO= (FVB.add((VBEZBSO.multiply (TAB1[J])).divide (ZAHL100))).setScale (2, BigDecimal.ROUND_UP)"/>
<if expr="FVBSO.compareTo (TAB2[J]) == 1">
<then>
<eval exec="FVBSO = TAB2[J]"/>
</then>
</if>
<eval exec="HFVBZSO= (((VBEZB.add(VBEZBSO)).divide (ZAHL100)).subtract (FVBSO)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<eval exec="FVBZSO= (FVBZ.add((VBEZBSO).divide (ZAHL100))).setScale (0, BigDecimal.ROUND_UP)"/>
<if expr="FVBZSO.compareTo (HFVBZSO) == 1">
<then>
<eval exec="FVBZSO = HFVBZSO.setScale(0, BigDecimal.ROUND_UP)"/>
</then>
</if>
<if expr="FVBZSO.compareTo (TAB3[J]) == 1">
<then>
<eval exec="FVBZSO = TAB3[J]"/>
</then>
</if>
<eval exec="HFVBZ= ((VBEZB.divide (ZAHL100)).subtract (FVB)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<if expr="FVBZ.compareTo (HFVBZ) == 1">
<then>
<eval exec="FVBZ = HFVBZ.setScale (0, BigDecimal.ROUND_UP)"/>
</then>
</if>
</else>
</if>
<execute method="MRE4ALTE"/>
</method>
<!-- Altersentlastungsbetrag (§ 39b Abs. 2 Satz 3 EStG), PAP Seite 17 -->
<method name="MRE4ALTE">
<if expr="ALTER1 == 0">
<then>
<eval exec="ALTE= BigDecimal.ZERO"/>
</then>
<else>
<if expr="AJAHR < 2006">
<then>
<eval exec="K= 1"/>
</then>
<else>
<if expr="AJAHR < 2040">
<then>
<eval exec="K= AJAHR - 2004"/>
</then>
<else>
<eval exec="K= 36"/>
</else>
</if>
</else>
</if>
<eval exec="BMG= ZRE4J.subtract (ZVBEZJ)"/>
<!-- Lt. PAP muss hier auf ganze EUR gerundet werden -->
<eval exec="ALTE = (BMG.multiply(TAB4[K])).setScale(0, BigDecimal.ROUND_UP)"/>
<eval exec="HBALTE= TAB5[K]"/>
<if expr="ALTE.compareTo (HBALTE) == 1">
<then>
<eval exec="ALTE= HBALTE"/>
</then>
</if>
</else>
</if>
</method>
<!-- Ermittlung des Jahresarbeitslohns nach Abzug der Freibeträge nach § 39 b Abs. 2 Satz 3 und 4 EStG, PAP Seite 19 -->
<method name="MRE4ABZ">
<eval exec="ZRE4= (ZRE4J.subtract (FVB).subtract (ALTE).subtract (JLFREIB).add (JLHINZU)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<if expr="ZRE4.compareTo (BigDecimal.ZERO) == -1">
<then>
<eval exec="ZRE4= BigDecimal.ZERO"/>
</then>
</if>
<eval exec="ZRE4VP= ZRE4J"/>
<if expr="KENNVMT == 2">
<then>
<eval exec="ZRE4VP = ZRE4VP.subtract(ENTSCH.divide(ZAHL100)).setScale(2,BigDecimal.ROUND_DOWN)"/>
</then>
</if>
<eval exec="ZVBEZ = ZVBEZJ.subtract(FVB).setScale(2, BigDecimal.ROUND_DOWN)"/>
<if expr="ZVBEZ.compareTo(BigDecimal.ZERO) == -1">
<then>
<eval exec="ZVBEZ = BigDecimal.ZERO"/>
</then>
</if>
</method>
<!-- Berechnung fuer laufende Lohnzahlungszeitraueme Seite 20-->
<method name="MBERECH">
<execute method="MZTABFB"/>
<eval exec="VFRB = ((ANP.add(FVB.add(FVBZ))).multiply(ZAHL100)).setScale(0, BigDecimal.ROUND_DOWN)"/>
<execute method="MLSTJAHR"/>
<eval exec="WVFRB = ((ZVE.subtract(GFB)).multiply(ZAHL100)).setScale(0, BigDecimal.ROUND_DOWN)"/>
<if expr="WVFRB.compareTo(BigDecimal.ZERO) == -1"> <!-- WVFRB < 0 -->
<then>
<eval exec="WVFRB = BigDecimal.valueOf(0)"/>
</then>
</if>
<eval exec="LSTJAHR = (ST.multiply(BigDecimal.valueOf(f))).setScale(0,BigDecimal.ROUND_DOWN)"/>
<execute method="UPLSTLZZ"/>
<execute method="UPVKVLZZ"/>
<if expr="ZKF.compareTo(BigDecimal.ZERO) == 1"> <!-- ZKF > 0 -->
<then>
<eval exec="ZTABFB = ZTABFB.add(KFB)"/>
<execute method="MRE4ABZ"/>
<execute method="MLSTJAHR"/>
<eval exec="JBMG = (ST.multiply(BigDecimal.valueOf(f))).setScale(0,BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<eval exec="JBMG = LSTJAHR"/>
</else>
</if>
<execute method="MSOLZ"/>
</method>
<!-- Ermittlung der festen Tabellenfreibeträge (ohne Vorsorgepauschale), PAP Seite 21 -->
<method name="MZTABFB">
<eval exec="ANP= BigDecimal.ZERO"/>
<if expr="ZVBEZ.compareTo (BigDecimal.ZERO) >= 0 &amp;&amp; ZVBEZ.compareTo(FVBZ) == -1">
<then>
<eval exec="FVBZ = BigDecimal.valueOf(ZVBEZ.longValue())"/>
</then>
</if>
<if expr="STKL < 6">
<then>
<if expr="ZVBEZ.compareTo (BigDecimal.ZERO) == 1">
<then>
<if expr="(ZVBEZ.subtract (FVBZ)).compareTo (BigDecimal.valueOf (102)) == -1">
<then>
<eval exec="ANP= (ZVBEZ.subtract (FVBZ)).setScale (0, BigDecimal.ROUND_UP)"/>
</then>
<else>
<eval exec="ANP= BigDecimal.valueOf (102)"/>
</else>
</if>
</then>
</if>
</then>
<else>
<eval exec="FVBZ= BigDecimal.valueOf (0)"/>
<eval exec="FVBZSO= BigDecimal.valueOf (0)"/>
</else>
</if>
<if expr="STKL < 6">
<then>
<if expr="ZRE4.compareTo(ZVBEZ) == 1">
<then>
<if expr="ZRE4.subtract(ZVBEZ).compareTo(ZAHL1000) == -1">
<then>
<eval exec="ANP = ANP.add(ZRE4).subtract(ZVBEZ).setScale(0,BigDecimal.ROUND_UP)"/>
</then>
<else>
<eval exec="ANP = ANP.add(ZAHL1000)"/>
</else>
</if>
</then>
</if>
</then>
</if>
<eval exec="KZTAB= 1"/>
<if expr="STKL == 1">
<then>
<eval exec="SAP= BigDecimal.valueOf (36)"/>
<eval exec="KFB= (ZKF.multiply (BigDecimal.valueOf (7620))).setScale (0, BigDecimal.ROUND_DOWN)"/> <!-- Neu 2019 -->
</then>
<else>
<if expr="STKL == 2">
<then>
<eval exec="EFA= BigDecimal.valueOf (1908)"/>
<eval exec="SAP= BigDecimal.valueOf (36)"/>
<eval exec="KFB= (ZKF.multiply (BigDecimal.valueOf (7620))).setScale (0, BigDecimal.ROUND_DOWN)"/> <!-- Neu 2019 -->
</then>
<else>
<if expr="STKL == 3">
<then>
<eval exec="KZTAB= 2"/>
<eval exec="SAP= BigDecimal.valueOf (36)"/>
<eval exec="KFB= (ZKF.multiply (BigDecimal.valueOf (7620))).setScale (0, BigDecimal.ROUND_DOWN)"/> <!-- Neu 2019 -->
</then>
<else>
<if expr="STKL == 4">
<then>
<eval exec="SAP= BigDecimal.valueOf (36)"/>
<eval exec="KFB= (ZKF.multiply (BigDecimal.valueOf (3810))).setScale (0, BigDecimal.ROUND_DOWN)"/> <!-- Neu 2019 -->
</then>
<else>
<if expr="STKL == 5">
<then>
<eval exec="SAP= BigDecimal.valueOf (36)"/>
<eval exec="KFB= BigDecimal.ZERO"/>
</then>
<else>
<eval exec="KFB= BigDecimal.ZERO"/>
</else>
</if>
</else>
</if>
</else>
</if>
</else>
</if>
</else>
</if>
<eval exec="ZTABFB= (EFA.add (ANP).add (SAP).add (FVBZ)).setScale (2, BigDecimal.ROUND_DOWN)"/>
</method>
<!-- Ermittlung Jahreslohnsteuer, PAP Seite 22 -->
<method name="MLSTJAHR">
<execute method="UPEVP"/>
<if expr="KENNVMT != 1">
<then>
<eval exec="ZVE= (ZRE4.subtract (ZTABFB).subtract (VSP)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<execute method="UPMLST"/>
</then>
<else>
<eval exec="ZVE= (ZRE4.subtract (ZTABFB).subtract (VSP).subtract ((VMT).divide (ZAHL100)).subtract ((VKAPA).divide (ZAHL100))).setScale (2, BigDecimal.ROUND_DOWN)"/>
<if expr="ZVE.compareTo (BigDecimal.ZERO) == -1">
<then>
<eval exec=" ZVE = ZVE.add(VMT.divide(ZAHL100)).add(VKAPA.divide(ZAHL100)).divide(ZAHL5).setScale(2,BigDecimal.ROUND_DOWN)"/>
<execute method="UPMLST"/>
<eval exec="ST= (ST.multiply (ZAHL5)).setScale (0, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<execute method="UPMLST"/>
<eval exec="STOVMT= ST"/>
<eval exec="ZVE= (ZVE.add(((VMT.add (VKAPA)).divide (ZAHL500)))).setScale (2, BigDecimal.ROUND_DOWN)"/>
<execute method="UPMLST"/>
<eval exec="ST= (((ST.subtract (STOVMT)).multiply (ZAHL5)).add (STOVMT)).setScale (0, BigDecimal.ROUND_DOWN)"/>
</else>
</if>
</else>
</if>
</method>
<!-- PAP Seite 23 -->
<method name="UPVKVLZZ">
<execute method="UPVKV"/>
<eval exec="JW = VKV"/>
<execute method="UPANTEIL"/>
<eval exec="VKVLZZ = ANTEIL1"/>
</method>
<!-- PAP Seite 23 -->
<method name="UPVKV">
<if expr="PKV > 0">
<then>
<if expr="VSP2.compareTo(VSP3) == 1">
<then>
<eval exec="VKV = VSP2.multiply(ZAHL100)"/>
</then>
<else>
<eval exec="VKV = VSP3.multiply(ZAHL100)"/>
</else>
</if>
</then>
<else>
<eval exec="VKV = BigDecimal.ZERO"/>
</else>
</if>
</method>
<!-- PAP Seite 24 -->
<method name="UPLSTLZZ">
<eval exec="JW = LSTJAHR.multiply(ZAHL100)"/>
<execute method="UPANTEIL"/>
<eval exec="LSTLZZ = ANTEIL1"/>
</method>
<!-- Ermittlung der Jahreslohnsteuer aus dem Einkommensteuertarif. PAP Seite 25 -->
<method name="UPMLST">
<if expr="ZVE.compareTo (ZAHL1) == -1">
<then>
<eval exec="ZVE= BigDecimal.ZERO"/>
<eval exec="X= BigDecimal.ZERO"/>
</then>
<else>
<eval exec="X= (ZVE.divide (BigDecimal.valueOf(KZTAB))).setScale (0, BigDecimal.ROUND_DOWN)"/>
</else>
</if>
<if expr="STKL < 5">
<then>
<!-- Neu 2019 -->
<execute method="UPTAB19"/>
</then>
<else>
<execute method="MST5_6"/>
</else>
</if>
</method>
<!-- Vorsorgepauschale (§ 39b Absatz 2 Satz 5 Nummer 3 und Absatz 4 EStG)
Achtung: Es wird davon ausgegangen, dass
a) Es wird davon ausge-gangen, dassa) für die BBG (Ost) 60.000 Euro und für die BBG (West) 71.400 Euro festgelegt wird sowie
b) der Beitragssatz zur Rentenversicherung auf 18,9 % gesenkt wird.
PAP Seite 26 -->
<method name="UPEVP">
<if expr="KRV > 1"><!-- &lt; = < &gt; = > -->
<then>
<eval exec="VSP1= BigDecimal.ZERO"/>
</then>
<else>
<if expr="ZRE4VP.compareTo(BBGRV) == 1">
<then>
<eval exec="ZRE4VP = BBGRV"/>
</then>
</if>
<eval exec="VSP1 = (TBSVORV.multiply(ZRE4VP)).setScale(2,BigDecimal.ROUND_DOWN)"/>
<eval exec="VSP1 = (VSP1.multiply(RVSATZAN)).setScale(2,BigDecimal.ROUND_DOWN)"/>
</else>
</if>
<eval exec="VSP2 = (ZRE4VP.multiply(BigDecimal.valueOf(0.12))).setScale(2,BigDecimal.ROUND_DOWN)"/>
<if expr="STKL == 3">
<then>
<eval exec="VHB = BigDecimal.valueOf(3000)"/>
</then>
<else>
<eval exec="VHB = BigDecimal.valueOf(1900)"/>
</else>
</if>
<if expr="VSP2.compareTo (VHB) == 1">
<then>
<eval exec="VSP2= VHB"/>
</then>
</if>
<eval exec="VSPN= (VSP1.add (VSP2)).setScale (0, BigDecimal.ROUND_UP)"/>
<execute method="MVSP"/>
<if expr="VSPN.compareTo (VSP) == 1">
<then>
<eval exec="VSP= VSPN.setScale (2, BigDecimal.ROUND_DOWN)"/>
</then>
</if>
</method>
<!-- Vorsorgepauschale (§39b Abs. 2 Satz 5 Nr 3 EStG) Vergleichsberechnung fuer Guenstigerpruefung, PAP Seite 27 -->
<method name="MVSP">
<if expr="ZRE4VP.compareTo(BBGKVPV) == 1">
<then>
<eval exec="ZRE4VP = BBGKVPV"/>
</then>
</if>
<if expr="PKV > 0">
<then>
<if expr="STKL == 6">
<then>
<eval exec="VSP3 = BigDecimal.ZERO"/>
</then>
<else>
<eval exec="VSP3 = PKPV.multiply(ZAHL12).divide(ZAHL100)"/>
<if expr="PKV == 2">
<then>
<eval exec="VSP3 = VSP3.subtract( ZRE4VP.multiply( KVSATZAG.add(PVSATZAG))).setScale(2,BigDecimal.ROUND_DOWN)"/>
</then>
</if>
</else>
</if>
</then>
<else>
<eval exec="VSP3 = ZRE4VP.multiply(KVSATZAN.add(PVSATZAN)).setScale(2, BigDecimal.ROUND_DOWN)"/>
</else>
</if>
<eval exec="VSP = VSP3.add(VSP1).setScale(0, BigDecimal.ROUND_UP)"/>
</method>
<!-- Lohnsteuer fuer die Steuerklassen V und VI (§ 39b Abs. 2 Satz 7 EStG), PAP Seite 28 -->
<method name="MST5_6">
<eval exec="ZZX= X"/>
<if expr="ZZX.compareTo(W2STKL5) == 1">
<then>
<eval exec="ZX= W2STKL5"/>
<execute method="UP5_6"/>
<if expr="ZZX.compareTo (W3STKL5) == 1">
<then>
<eval exec="ST= (ST.add ((W3STKL5.subtract (W2STKL5)).multiply (BigDecimal.valueOf (0.42)))).setScale (0, BigDecimal.ROUND_DOWN)"/>
<eval exec="ST= (ST.add ((ZZX.subtract (W3STKL5)).multiply (BigDecimal.valueOf (0.45)))).setScale (0, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<eval exec="ST= (ST.add ((ZZX.subtract (W2STKL5)).multiply (BigDecimal.valueOf (0.42)))).setScale (0, BigDecimal.ROUND_DOWN)"/>
</else>
</if>
</then>
<else>
<eval exec="ZX= ZZX"/>
<execute method="UP5_6"/>
<if expr="ZZX.compareTo (W1STKL5) == 1">
<then>
<eval exec="VERGL= ST"/>
<eval exec="ZX= W1STKL5"/>
<execute method="UP5_6"/>
<eval exec="HOCH= (ST.add ((ZZX.subtract (W1STKL5)).multiply (BigDecimal.valueOf (0.42)))).setScale (0, BigDecimal.ROUND_DOWN)"/> <!-- Neuer Wert 2014 -->
<if expr="HOCH.compareTo (VERGL) == -1">
<then>
<eval exec="ST= HOCH"/>
</then>
<else>
<eval exec="ST= VERGL"/>
</else>
</if>
</then>
</if>
</else>
</if>
</method>
<!-- Unterprogramm zur Lohnsteuer fuer die Steuerklassen V und VI (§ 39b Abs. 2 Satz 7 EStG), PAP Seite 29 -->
<method name="UP5_6">
<eval exec="X= (ZX.multiply (BigDecimal.valueOf (1.25))).setScale (2, BigDecimal.ROUND_DOWN)"/>
<!-- Neu 2019 -->
<execute method="UPTAB19"/>
<eval exec="ST1= ST"/>
<eval exec="X= (ZX.multiply (BigDecimal.valueOf (0.75))).setScale (2, BigDecimal.ROUND_DOWN)"/>
<!-- Neu 2019 -->
<execute method="UPTAB19"/>
<eval exec="ST2= ST"/>
<eval exec="DIFF= (ST1.subtract (ST2)).multiply (ZAHL2)"/>
<eval exec="MIST= (ZX.multiply (BigDecimal.valueOf (0.14))).setScale (0, BigDecimal.ROUND_DOWN)"/>
<if expr="MIST.compareTo (DIFF) == 1">
<then>
<eval exec="ST= MIST"/>
</then>
<else>
<eval exec="ST= DIFF"/>
</else>
</if>
</method>
<!-- Solidaritaetszuschlag, PAP Seite 30 -->
<method name="MSOLZ">
<eval exec="SOLZFREI = (SOLZFREI.multiply(BigDecimal.valueOf(KZTAB)))"/>
<if expr="JBMG.compareTo (SOLZFREI) == 1">
<then>
<eval exec="SOLZJ= (JBMG.multiply (BigDecimal.valueOf (5.5))).divide(ZAHL100).setScale(2, BigDecimal.ROUND_DOWN)"/>
<eval exec="SOLZMIN= (JBMG.subtract (SOLZFREI)).multiply (BigDecimal.valueOf (20)).divide (ZAHL100).setScale (2, BigDecimal.ROUND_DOWN)"/>
<if expr="SOLZMIN.compareTo (SOLZJ) == -1">
<then>
<eval exec="SOLZJ= SOLZMIN"/>
</then>
</if>
<eval exec="JW= SOLZJ.multiply (ZAHL100).setScale (0, BigDecimal.ROUND_DOWN)"/>
<execute method="UPANTEIL"/>
<eval exec="SOLZLZZ= ANTEIL1"/>
</then>
<else>
<eval exec="SOLZLZZ= BigDecimal.ZERO"/>
</else>
</if>
<if expr="R > 0">
<then>
<eval exec="JW= JBMG.multiply (ZAHL100)"/>
<execute method="UPANTEIL"/>
<eval exec="BK= ANTEIL1"/>
</then>
<else>
<eval exec="BK= BigDecimal.ZERO"/>
</else>
</if>
</method>
<!-- Anteil von Jahresbetraegen fuer einen LZZ (§ 39b Abs. 2 Satz 9 EStG), PAP Seite 31 -->
<method name="UPANTEIL">
<if expr="LZZ == 1">
<then>
<eval exec="ANTEIL1= JW"/>
</then>
<else>
<if expr="LZZ == 2">
<then>
<eval exec="ANTEIL1= JW.divide (ZAHL12, 0, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<if expr="LZZ == 3">
<then>
<eval exec="ANTEIL1= (JW.multiply (ZAHL7)).divide (ZAHL360, 0, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<eval exec="ANTEIL1= JW.divide (ZAHL360, 0, BigDecimal.ROUND_DOWN)"/>
</else>
</if>
</else>
</if>
</else>
</if>
</method>
<!-- Berechnung sonstiger Bezuege nach § 39b Abs. 3 Saetze 1 bis 8 EStG), PAP Seite 32 -->
<method name="MSONST">
<eval exec="LZZ= 1"/>
<if expr="ZMVB == 0">
<then>
<eval exec="ZMVB= 12"/>
</then>
</if>
<if expr="SONSTB.compareTo (BigDecimal.ZERO) == 0">
<then>
<eval exec="VKVSONST= BigDecimal.ZERO"/>
<eval exec="LSTSO= BigDecimal.ZERO"/>
<eval exec="STS= BigDecimal.ZERO"/>
<eval exec="SOLZS= BigDecimal.ZERO"/>
<eval exec="BKS= BigDecimal.ZERO"/>
</then>
<else>
<execute method="MOSONST"/>
<execute method="UPVKV"/>
<eval exec="VKVSONST = VKV"/>
<eval exec="ZRE4J= ((JRE4.add (SONSTB)).divide (ZAHL100)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<eval exec="ZVBEZJ= ((JVBEZ.add (VBS)).divide (ZAHL100)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<eval exec="VBEZBSO= STERBE"/>
<execute method="MRE4SONST"/>
<execute method="MLSTJAHR"/>
<eval exec="WVFRBM = (ZVE.subtract(GFB)).multiply(ZAHL100).setScale(2,BigDecimal.ROUND_DOWN)"/>
<if expr="WVFRBM.compareTo(BigDecimal.ZERO) == -1"> <!-- WVFRBM < 0 -->
<then>
<eval exec="WVFRBM = BigDecimal.ZERO"/>
</then>
</if>
<execute method="UPVKV"/>
<eval exec="VKVSONST = VKV.subtract(VKVSONST)"/>
<eval exec="LSTSO= ST.multiply (ZAHL100)"/>
<!-- lt. PAP muss hier auf ganze EUR aufgerundet werden,
allerdings muss der Wert in Cent vorgehalten werden,
deshalb nach dem Aufrunden auf ganze EUR durch 'divide(ZAHL100, 0, BigDecimal.ROUND_DOWN)'
wieder die Multiplikation mit 100 -->
<eval exec="STS = LSTSO.subtract(LSTOSO).multiply(BigDecimal.valueOf(f)).divide(ZAHL100, 0, BigDecimal.ROUND_DOWN).multiply(ZAHL100)"/>
<if expr="STS.compareTo (BigDecimal.ZERO) == -1">
<then>
<eval exec="STS= BigDecimal.ZERO"/>
</then>
</if>
<eval exec="SOLZS= STS.multiply (BigDecimal.valueOf (5.5)).divide (ZAHL100, 0, BigDecimal.ROUND_DOWN)"/>
<if expr="R > 0">
<then>
<eval exec="BKS= STS"/>
</then>
<else>
<eval exec="BKS= BigDecimal.ZERO"/>
</else>
</if>
</else>
</if>
</method>
<!-- Berechnung der Verguetung fuer mehrjaehrige Taetigkeit nach § 39b Abs. 3 Satz 9 und 10 EStG), PAP Seite 33 -->
<method name="MVMT">
<if expr="VKAPA.compareTo (BigDecimal.ZERO) == -1">
<then>
<eval exec="VKAPA= BigDecimal.ZERO"/>
</then>
</if>
<if expr="(VMT.add (VKAPA)).compareTo (BigDecimal.ZERO) == 1">
<then>
<if expr="LSTSO.compareTo (BigDecimal.ZERO) == 0">
<then>
<execute method="MOSONST"/>
<eval exec="LST1= LSTOSO"/>
</then>
<else>
<eval exec="LST1= LSTSO"/>
</else>
</if>
<eval exec="VBEZBSO= STERBE.add (VKAPA)"/>
<eval exec="ZRE4J= ((JRE4.add (SONSTB).add (VMT).add (VKAPA)).divide (ZAHL100)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<eval exec="ZVBEZJ= ((JVBEZ.add (VBS).add (VKAPA)).divide (ZAHL100)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<eval exec="KENNVMT = 2"/>
<execute method="MRE4SONST"/>
<execute method="MLSTJAHR"/>
<eval exec="LST3= ST.multiply (ZAHL100)"/>
<execute method="MRE4ABZ"/>
<eval exec="ZRE4VP = ZRE4VP.subtract(JRE4ENT.divide(ZAHL100)).subtract(SONSTENT.divide(ZAHL100))"/>
<eval exec="KENNVMT= 1"/>
<execute method="MLSTJAHR"/>
<eval exec="LST2= ST.multiply (ZAHL100)"/>
<eval exec="STV= LST2.subtract (LST1)"/>
<eval exec="LST3= LST3.subtract (LST1)"/>
<if expr="LST3.compareTo (STV) == -1">
<then>
<eval exec="STV= LST3"/>
</then>
</if>
<if expr="STV.compareTo (BigDecimal.ZERO) == -1">
<then>
<eval exec="STV= BigDecimal.ZERO"/>
</then>
<else>
<!--
lt. PAP muss hier auf ganze EUR abgerundet werden.
Allerdings muss auch hier der Wert in Cent vorgehalten werden,
weshalb nach dem Aufrunden auf ganze EUR durch 'divide(ZAHL100, 0, BigDecimal.ROUND_DOWN)'
wieder die Multiplikation mit 100 erfolgt.
-->
<eval exec="STV = STV.multiply(BigDecimal.valueOf(f)).divide(ZAHL100, 0, BigDecimal.ROUND_DOWN).multiply(ZAHL100)"/>
</else>
</if>
<eval exec="SOLZV= ((STV.multiply (BigDecimal.valueOf (5.5))).divide (ZAHL100)).setScale (0, BigDecimal.ROUND_DOWN)"/>
<if expr="R > 0">
<then>
<eval exec="BKV= STV"/>
</then>
<else>
<eval exec="BKV= BigDecimal.ZERO"/>
</else>
</if>
</then>
<else>
<eval exec="STV= BigDecimal.ZERO"/>
<eval exec="SOLZV= BigDecimal.ZERO"/>
<eval exec="BKV= BigDecimal.ZERO"/>
</else>
</if>
</method>
<!-- Sonderberechnung ohne sonstige Bezüge für Berechnung bei sonstigen Bezügen oder Vergütung für mehrjährige Tätigkeit, PAP Seite 34 -->
<method name="MOSONST">
<eval exec="ZRE4J= (JRE4.divide (ZAHL100)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<eval exec="ZVBEZJ= (JVBEZ.divide (ZAHL100)).setScale (2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLFREIB= JFREIB.divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<eval exec="JLHINZU= JHINZU.divide (ZAHL100, 2, BigDecimal.ROUND_DOWN)"/>
<execute method="MRE4"/>
<execute method="MRE4ABZ"/>
<eval exec="ZRE4VP = ZRE4VP.subtract(JRE4ENT.divide(ZAHL100))"/>
<execute method="MZTABFB"/>
<eval exec="VFRBS1 = ((ANP.add(FVB.add(FVBZ))).multiply(ZAHL100)).setScale(2,BigDecimal.ROUND_DOWN)"/>
<execute method="MLSTJAHR"/>
<eval exec="WVFRBO = ((ZVE.subtract(GFB)).multiply(ZAHL100)).setScale(2, BigDecimal.ROUND_DOWN)"/>
<if expr="WVFRBO.compareTo(BigDecimal.ZERO) == -1 ">
<then>
<eval exec="WVFRBO = BigDecimal.ZERO"/>
</then>
</if>
<eval exec="LSTOSO= ST.multiply (ZAHL100)"/>
</method>
<!-- Sonderberechnung mit sonstige Bezüge für Berechnung bei sonstigen Bezügen oder Vergütung für mehrjährige Tätigkeit, PAP Seite 35 -->
<method name="MRE4SONST">
<execute method="MRE4"/>
<eval exec="FVB= FVBSO"/>
<execute method="MRE4ABZ"/>
<eval exec="ZRE4VP = ZRE4VP.subtract(JRE4ENT.divide(ZAHL100)).subtract(SONSTENT.divide(ZAHL100))"/>
<eval exec="FVBZ= FVBZSO"/>
<execute method="MZTABFB"/>
<eval exec="VFRBS2 = ((((ANP.add(FVB).add(FVBZ))).multiply(ZAHL100))).subtract(VFRBS1)"/>
</method>
<!-- Komplett Neu 2019 -->
<!-- Tarifliche Einkommensteuer §32a EStG, PAP Seite 36 -->
<method name="UPTAB19">
<if expr="X.compareTo(GFB.add(ZAHL1)) == -1">
<then>
<eval exec="ST= BigDecimal.ZERO"/>
</then>
<else>
<if expr="X.compareTo (BigDecimal.valueOf (14255)) == -1">
<then>
<eval exec="Y = (X.subtract(GFB)).divide(ZAHL10000, 6,BigDecimal.ROUND_DOWN)"/>
<eval exec="RW= Y.multiply (BigDecimal.valueOf (980.14))"/>
<eval exec="RW= RW.add (BigDecimal.valueOf (1400))"/>
<eval exec="ST= (RW.multiply (Y)).setScale (0, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<if expr="X.compareTo (BigDecimal.valueOf (55961)) == -1">
<then>
<eval exec="Y= (X.subtract (BigDecimal.valueOf (14254))).divide (ZAHL10000, 6, BigDecimal.ROUND_DOWN)"/>
<eval exec="RW= Y.multiply (BigDecimal.valueOf (216.16))"/>
<eval exec="RW= RW.add (BigDecimal.valueOf (2397))"/>
<eval exec="RW= RW.multiply (Y)"/>
<eval exec="ST= (RW.add (BigDecimal.valueOf (965.58))).setScale (0, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<if expr="X.compareTo (BigDecimal.valueOf (265327)) == -1">
<then>
<eval exec="ST= ((X.multiply (BigDecimal.valueOf (0.42))).subtract (BigDecimal.valueOf (8780.9))).setScale (0, BigDecimal.ROUND_DOWN)"/>
</then>
<else>
<eval exec="ST= ((X.multiply (BigDecimal.valueOf (0.45))).subtract (BigDecimal.valueOf (16740.68))).setScale (0, BigDecimal.ROUND_DOWN)"/>
</else>
</if>
</else>
</if>
</else>
</if>
</else>
</if>
<eval exec="ST= ST.multiply (BigDecimal.valueOf (KZTAB))"/>
</method>
</methods>
</pap>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment