Skip to content

Instantly share code, notes, and snippets.

@mariocesar
Last active December 11, 2015 18:09
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save mariocesar/4639503 to your computer and use it in GitHub Desktop.
Save mariocesar/4639503 to your computer and use it in GitHub Desktop.
Formula para el calculo del Aporte Nacional Solidario Laboral, un aporte obligatorio en Bolivia, para usar como una regla salarial en OpenERP (hr.salary.rule)
"""
Formula para el calculo del Aporte Nacional Solidario Laboral
Esta es la explicación legal del calculo de la formula:
* 10% de la diferencia del total ganado solidario menos Bs. 35.000 de diferencia positiva
* 5% de la diferencia del total ganado solidario menos Bs. 25.000 de diferencia positiva
* 1% de la diferencia del total ganado solidario menos Bs. 13.000 de diferencia positiva
"""
def calc_ansl(basic):
def _calc_ansl(amount):
if amount >= 35000:
yield (amount - 35000) * 0.10
if amount >= 25000:
yield (amount - 25000) * 0.05
if amount >= 13000:
yield (amount - 13000) * 0.01
return sum(_calc_ansl(basic))
assert calc_ansl(42000.0) == 1840.0
assert calc_ansl(35000.0) == 848.0
assert '%.2f' % calc_ansl(35001.0) == '720.16'
assert calc_ansl(35000.0) == 720.0
assert calc_ansl(26900.0) == 234.0
assert calc_ansl(25000.0) == 120.0
assert calc_ansl(25000.0) == 120.0
assert '%.2f' % calc_ansl(24999.0) == '119.99'
assert calc_ansl(14000.0) == 10.0
assert calc_ansl(13120.0) == 1.2
assert calc_ansl(13000.0) == 0.0
assert calc_ansl(7662.0) == 0
# OpenERP al evalular la expresion en una regla salarial tiene una lista de operadores permitidos
# Lo siguiente funcionara correctamente si copias y pegas
basic = categories.BASIC
result = 0.0
if basic >= 35000:
result += (basic - 35000) * 0.10
if basic >= 25000:
result += (basic - 25000) * 0.05
if basic >= 13000:
result += (basic - 13000) * 0.01
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment