1 La Teoría de las Restricciones

El Modelo Mental de la Theory of Constraints

Dr. Eli Goldrat

goldrat

Bibliografía

  • La Meta

  • Un Proceso de Mejora Continua

  • Género: Novela

  • Primer libro de la serie


Material disponible en https://www.cuspide.com/9789506418069/La+Meta

Markdown Monster icon

  • Necesario pero No Suficiente

  • Gestión de la Tecnología (Bolsa)

  • Género: Gerencial - Interrogativo

  • Segundo libro de la serie

  • Fragilidad de las Grandes Empresas

  • Nos enseña a revertir la tendencia


Material disponible en https://www.cuspide.com/9788479784874/Necesario+Pero+No+Suficiente

Markdown Monster icon

2 Rigurosidad

Es necesario comprender que cuando hablamos de formar un modelo mental para la toma de decisiones en gobiernos o empresas, debemos atenernos a la rigurosidad. Que tan cierto es lo que estoy diciendo?. O en otras palabras que margen de error puedo esperar respecto a lo que afirmo.

Goldrat recurre al truco que luego fue más desarrollado en el “Cúrculo de Oro” de Somon Sinek, y ataca por el lado de las dudas antes que por el de las certezas.

Para ello usa el paradigma que menos certezas tiene , La TEORÍA

Paradigma Rigor
Ley Se cumple en todo lugar del universo. Ej. Ley Gravitación Universal
Principio Es casi tan riguroso como la ley, pero no se ha validado universalmente. Ej. Principio 1 de la Termodinámica
Empirismo Funciona, pero no se sabe por qué. Ej. Ciclos de mantenimiento de cojinetes
Paradigma Está tan fuertemente arraigado que parece una ley, pero no lo es. Ej. My Flower
Teoría Tienen un modelo con el que se ha encontrado respuesta, es muy verosimil, pero su autor lo limita hasta encontrar más evidencia. Ej. TOC
Evidencia
Congetura
Con suerte puede derivar en un empirismo
Teorema Matemática y Filosóficamente es perfecto. Pero su aplicación a la realidad da lugar a sofismas, falacias y paradojas

#Modelar con teoremas es más fácil:

Markdown Monster icon

Markdown Monster icon


Markdown Monster icon


2.1 Modelar estos problemas

    1. Modele el problema de una presa hidroeléctrica destinada a producir electricidad y suministro de agua potable.
    1. Modelar una glorieta en en centro de una plaza a la que convergen varias 8 calles.
    1. Describa un ecosistema en el que hay varias especies (animal y vegetal) y recursos (campo de hierbas)

3 Situación Problema

  • Presentamos esta situación problema. Dos redes consumen la energía que poducimos que llamaremos P y Q

*¿Qué cantidad de P y qué cantidad de Q nos conviene entregar?

Markdown Monster icon

  • Consignas:

El Mercado P consume 100 GW/Sem
Podemos cobrale $90 / GWh

El Mercado Q consume 50 GW/Sem
Podemos cobrarle $100 / GWh


Tengo una oficina D encargada de :

  • Calidad*
  • Eficiencia*
  • Data Engineering*
  • IOIT*
  • Sistema Interconectado*

Las Horas Hombre del secor D son:
* 15 min / GWh si vendo en el mercado P 05 min / GWh si vendo en el mercado Q*


  • Tengo tres material primas (combustibles y lubricantes)*
  • Para facilitar los cáculos supongo a todos con el mismo costo*
  • MP_1 es quemado en el equipo que opera el Sr. A y custas $20/ GWh*
  • MP_2 los usa B para mantenimientode equipo que opera el Sr. B y custas $20/ GWh*
  • MP_3 es quemado en el equipo que opera el Sr. A y custas $20/ GWh*

Los Ingenieros Expertos A y B necesitan trabajar
* 15 min / GWh si generamos para P 10 min / GWh si generamos para Q El Mantenimiento B ocupa 15 Minutos para P y 15 para Q*


Impuestos: Cuando vendo energía a P , tengo que pagar $5 / GWh


Horas Hombre Disponibles 2.400 Horas por semana de A,B,C y D


Costos Operativos Genero o no genere, venda o no venda; al final de semana tengo que gastar $ 6000
Operating Expenses


#¿Que Cantidad de P y Q Tengo que Vender para Oprimizar Ganancia

      Habitualmente nos centramos en las resupestas,pero encontrar la pregunta indicada es simpre mejor que hallar la respuesta correcta

      Maríe Curié
      

4 Primea Aproximación Caja Negra

  • Tenemos más informción de la que necesitamos.
  • Pensemos en un sistema entrada salida

Markdown Monster icon


Según este esquema :

  • Potencial de mercado de \(P = 100 GW/sem\)
  • Descuento Costos e Ingresos
    \(100 GW /sem * (90 -40 -5) = 4.500 por semana (Ingreso)\)

  • Potencial de mercado de \(P = 50 GW/sem\)
  • Descuento Costos e Ingresos
    \(50 GW /sem * (100 -40) = 3.000 por semana (Ingreso)\)

Resultado operativo \(Utilidad_Neta = 4.500 + 3.000 - 6.000 = 1.500\) por semana

Un Excelente resultado si comparamos con la inversión.

#Primer Falacia TOC

Muy Simple

MUY MAL

  • B tendría que trabajar 3600 horas por semana para satisfacer a todo lo que esperamos de él.

        Hemos Violado la Restricción B = 2.400 min

NOTA Hemos Violado la Restricción B = 2.400 min

Box made with Triple Backticks
It works with almost all markdown flavours (the below blank line matters).

5 Encontrar las restricciones

  • Todo sistema está sujeto a un a más restricciones
  • Si no fuese así nada impediría que sus resultados aumenten hasta el infinito *Sabemos que hay algo que impide que esto suceda.

5.1 Que tipo de restricciones podemos tener

  • Restricción de MP -> ISO 9000 recomienda desarrollo proveedor
  • Restricción de Canal -> Gobierno, plan, Marketing, Industria 4.0
  • Pronóstico colaborativos funciona en muchos países
    Si la restrucción está dentro de la empresa aplico TOC

5.1.1 Primer principio

  • Cada centavo que gasto en optimizar algo que no sea la restricción en lugar de mejorar, empeora las cosas.

  • TOC se especializa en encontrar los cuellos de botella.

6 Cómo Identificar las Restricciones

Necesito crear nuevos indicadores para tomar decisiones

SIMULACIÓN sustantivo femenino

  1. Acción de simular. ejemplo :“las simulaciones orales ante un experto ayudan muchísimo a quienes tienen que rendir un examen oral”
  2. Efecto de simular.
  3. DERECHO Alteración aparente de la causa, la índole o el objeto verdaderos de un acto o contrato.

    Sinónimos: ficción fingimiento apariencia pamema paripé
    Antónimos: verdad, sinceridad

  • Primera Definición Formal
    Es una técnica numérica para conducir experimentos en una computadora digital… H. Maisel (1971)

    … con el propósito de entender el comportamiento de un sistema (mecánico) o de predecirlo y elaborar estrategias para el futuro.
    Robert Shannon (1948)


    Expresiones recurrentes en la bibliografía

    1 - A simulation is an approximate imitation of the operation of a process or system; the act of simulating first requires a model is developed. This model is a well-defined description of the simulated subject, and represents its key characteristics, such as its behaviour, functions and abstract or physical properties. The model represents the system itself, whereas the simulation represents its operation over time.

    2 - Simulation is used in many contexts, such as simulation of technology for performance optimization, safety engineering, testing, training, education, and video games. Often, computer experiments are used to study simulation models. Simulation is also used with scientific modelling of natural systems or human systems to gain insight into their functioning, as in economics. Simulation can be used to show the eventual real effects of alternative conditions and courses of action. Simulation is also used when the real system cannot be engaged, because it may not be accessible, or it may be dangerous or unacceptable to engage, or it is being designed but not yet built, or it may simply not exist.

    3 - Key issues in simulation include the acquisition of valid source information about the relevant selection of key characteristics and behaviours, the use of simplifying approximations and assumptions within the simulation, and fidelity and validity of the simulation outcomes. Procedures and protocols for model verification and validation are an ongoing field of academic study, refinement, research and development in simulations technology or practice, particularly in the field of computer simulation.


    La simulación no cambia la realidad

    • Apenas es capaz de cambiar la percepción de la realidad
    • Y eso lo cambia todo
    • Leer la quinta disciplina (Peter Senge) y se entenderá lo que es un modelo mental

    El modelo mental del Pierre Collet (Univ. de Strasbour)

    Modelo Mental del Cómputo

    Cómputo

    Modelo Mental de Simulación y Aprendizaje Profundo Simulación


    Esto no puede hacerlo simplemente en una hoja de cálculo

    ¿Es necesario usar una computadora para hacer una simulación?

    • No necesariamente
    • Minicaso #1 - ¿Cómo has hecho para aprender? ¿La inteligencia es natural o se adquiere?

    Simulación

    Simulación

    • Se puede aprender jugando
    • La Universidad ha enseñado por más de 500 años
    • Pero la humanidad ha aprendido por el diálogo millones de años
    • El método del caso es un cuento
    • El cuento es un juego
    • El pensamiento de Maturana & Varela
    • Los Grobos
    • Vamos Manao
    • Sie Tu Helados
    • Son historias que emocionan
    • Sin emoción no hay pasión
    • Sin pasión no hay aprendizaje

    Clasificación de juegos de simulación

    • De realidad limitada (ceteris paribus)
    • Juegos con cartas
    • Juegos secuenciales
    • Juegos en solitario
    • Juegos de Dinámica de Sistemas
    • Juegos de Guerra
    • Juegos de Nash (Suma Cero)
    Juegos para descargar :

    http://eduscol.education.fr/numerique/dossier/apprendre/jeuxserieux
    • Beer Game (SCM)
    • Hotzone (Bomberos)
    • MEG Balkans (ONU)
    • Merchant (Conflicto)
    • Triskelion (Desarrollo personal)
    • Los carteles de San Luis (5S)
    • Juego del Tomate (Corrupción)
    • Minicaso #2 - ¿Por qué estás estudiando este posgrado?

7 Ejemplos de Simuladores

Este simulador puede ser accedido en http://themys.sid.uncu.edu.ar/r-cran/Talca/simulador

Simulador icon


Código de ética del simulador

  • Recuerde siempre que Economía es una Ciencia Social.
  • Toda la economía es microeconomía.
  • Piensa primero !!! calcula después.
  • Conoce (bien) tus datos.
  • SEAMOS ÉTICOS.
  • seamos humildes.

Receta para disfrutar la aventura de realizar una simulación

  • 1 Defina el sistema
  • 2 Formule el modelo
  • 3 Coleccione datos
  • 4 Implemente el modelo en una computadora
  • 5 Valide el modelo
  • 6 Use esto como su “bola de cristal”
  • 7 Jugar es APRENDER

8 Simulación con Modelos Determinísticos

Minicaso 3 Freight Forwarder

Un caso de emprendedora exitoso en la región vitı́cola de Menoza Argentina está ligado a una egresada de la carrera de ingenierı́a industrial que a comienzos de la década de 1990, ante la incertidumbre de las crisis económicas decidió, sincapital alguno, lanzarse como free lance en el negocio de mover containers con vino a los puertos de Valparaı́so y San Antonio - Chile. Su empresa actuava como intgradora de servicios entre transportistas, despachantes de aduana, bodegas, navieras y clientes de brokers en el extranjero.
Un factor clave de éxito ( KPI ) era el tamaño de lote óptimo a transportar en cada envı́o. Es bien conocido el modelo de Wilson que data de la década de 1920, pero que hoy resulta casi una garantı́a al fracaso si se utiliza en contextos tan turbulentos como los que nos toca vivir. A pesar de ello el modelo aún se estudia y no es descartado, pués sirve de base para ser mejorado. El modelo tiene tres variables independientes y una dependiente, a saber:

El modelo de Wilson

Variables Independientes

  • Demanda Media Anual D (en Containers por año)

  • Costo de almacenamiento unitario Ca ($ por mes)

  • Costo de emisión o gestión Ce ($ por orden)

Variable Dependiente

  • Tamaño de Lote Mensual EOQ

Modelo Mateático

\[ {EOQ} = \sqrt {(\frac {2*D * Ce} {Ca} )}\]

El caso de la Bodega Torrenti operada por el Freight Forwarder

Esta bodega tiene tres destinos principales de exportación.

  • Estados Unidos demanda 500 TEUs al año
  • Brasil demanda 53 TEUs al año
  • Cadandá demand 28 TEUs al año

  • Costo de Almacenamiento U$D 2.500

  • Costo de Gestión U$D 750

Modelado numérico en R-CRAN

D1 <-500
D2 <-52
D3 <-28

D<- D1+D2+D3

Ca <- 2500
Ce <- 750

EOQ <- sqrt(2*D*Ce/Ca)

EOQ
[1] 18.65476

9 Simulación con modelos Estocásticos

Cálculo del EOQ por Montecarlo

Este método no concibe a las variables independientes como fijas, sino que las considera variables aleatorias e introduce Ruido en el modelo matemático. En esta parte deberíaos analizar el comportamento de cada variable y asociarle una distribución (función paramétrica) de probabilidad. Por sencillez supondremos en este ejemplo que las varaibles siguen una distribución normal.
En rigor deberíamos estudiar que distribución siguen los datos con los que alimentaremos el modelo. <bR R-Cran tiene por defecto definidas las siguientes distribuciones de probabilidad.

  • Normal
  • Logística
  • Uniforme
  • Gamma
  • Lognormal
  • Weibull
  • Cauchy
  • Exponencial
  • Chi-cuadrado
  • F
  • T-Student.


Estocatización de Variables

  • Estados Unidos demanda promedio 500 TEUs al año con una varianza de 90

  • Cadandá demanda promedio 28 TEUs con una varianza de 6 al año

  • Brasil demanda promedio 93 TEUs al año con una varianza de 8


  • Costo de Almacenamiento U$D 2.500 Varianza 1.000

  • Costo de Gestión U$D 750 varianza 250

Cálculo del EOQ Montecarlo

#Genero tres variables aleatorias normales con 
#una cantidad de muestras m igual a tres veces #el tamaño de la media 

m1 <- 500*3
D1 <- rnorm(m1,500,90)
m2 <- 93*3
D2 <- rnorm(m2,93,8)
m3 <- 28*3
D3 <- rnorm(m3,28,6)
D <- c(D1,D2,D3)
# m_d muestras de demanda
m_d <- length(D)

#Generamos las variables aleatorias de costos igual a la cantidad de muestras de demanda que tenemos.

Ca <- rnorm(m_d,2500,1000)

Ce <- rnorm (m_d,750,250)

# Preparo área de graficos 3 filas 1 columna
#par(mfcol=c(1,3))

#Grafico 1
plot(density(D), 
xlab="Demanda TEU", #Change the x-axis label
ylab="Densidad", #y-axis label
main="Muestras de Demanda 5 años")#Main title

#Grafico 2
plot(density(Ca),
xlab="Costo Almacenamiento", #x-axis label
ylab="% eventos registrados", # y label
main="Población Costos Almacenamiento")     

#Grafico 3
plot(density(Ce),
xlab="Costo Gestión Inventario", #x-axis label
ylab="% eventos registrados", # y label
main="Población Costos Emisión")     

Cálculo de muestras de lote Económico EOQ

En este caso realizaremos las mismas operaciones que antes, pero las variables independientes ahora serán matrices y el resultado será un conjunto de valores con su propia distribución de probabilidades.

EOQ <- sqrt(2*D*Ce/Ca)
#Media del Lote Económico
mean(EOQ, na.rm=TRUE)
[1] 16.42379
#Varianza del Lote Económico
var(EOQ, na.rm=TRUE)
[1] 85.07541
#Desvio Estandard del Lote Económico
sd(EOQ, na.rm=TRUE)
[1] 9.223633
plot(density(EOQ,na.rm=TRUE))

Hallaremos los valores máximos y mínimos de las variables dependientes e independientes

[1] 1654
[1] 87
[1] 1843

Valores Mínimos

[1] -548.6222
[1] -240.5452
[1] 1.811889
[1] 270
[1] 1608
[1] 99

10 Casos de Estacionalidad

Exploramos la cabecera de datos importados de excel:

library(readxl)
Vino_Fiscal <- read_excel("MetodoPolinomialSenCosen.xls", sheet = "Hoja4")
head("Vino_Fiscal")
[1] "Vino_Fiscal"
head(Vino_Fiscal)
Mes Exportaciones Mwh
1 71200.0 12.960003
2 71200.0 12.250003
3 71200.0 11.560004
4 71200.0 10.890004
5 145951.4 10.240006
6 119782.1 9.610006

Exploramos los datos finales de la tabla

tail(Vino_Fiscal)
Mes Exportaciones Mwh
31 179337.5 0.3600083
32 178217.7 0.2500069
33 272545.6 0.1600140
34 240951.6 0.0900140
35 360435.2 0.0400140
36 307519.3 0.0100140

Estos datos reflejan la estacionalidad en los despachos de vinos de alta gama que se exportan desde la provincia de Mendoza, Argentina; y son fiscalizados por el INV (Instituto Nacional de Viticultura).

11 Expotaciones de Vino Mensuales Fiscalizadas

plot(Vino_Fiscal$Mes, Vino_Fiscal$Exportaciones, main="Millones de hl Exportado 3 años", ylab=" hl",xlab="mes",type="b" )
abline(v=mean(Vino_Fiscal$Mes),h=mean(Vino_Fiscal$Exportaciones),lty=2)

11.1 Regresión Lineal

Es una primera aproximación, tiene errores pero de es mejor que no tener nada.

Este comando construye el típico modelo de regresión lineal.

Asignaremos valores a las variables Xv que representa el mes , Yv que representa los valores reales de exportaciones y Ys que tiene los datos aproximados del modelo de regresión lineal.

coef(lm(Yv ~ Xv ))
(Intercept)          Xv 
  82655.235    4409.053 

Esto debe leerse como “Construye un modelo de regresión linea que explique Yv en función de Xv”. La función nos devuelve la ordenada al origen y la pendiente de la recta.

modelo_vino <- lm(Yv ~ Xv)

Una buena aproximación podría obtenerse con la media de los valores X y Y (la recta denería pasar por el promedio de X e Y) y la pendiente podría obtenerse de la varianza de Y dividido la varianza de X

X2 <- mean(Xv)
X2
[1] 18.5
Y2 <- mean(Yv)
Y2
[1] 164222.7
Delta_y <- var(Yv)
Delta_x <- var(Xv)

m <- Delta_y/Delta_x
m
[1] 51013413

Sin embargo este modelo que hemos construido es más preciso ya que no usa estimadores sino que se basa en el concepto de valores residuales.

plot(Vino_Fiscal$Mes, Vino_Fiscal$Exportaciones, main="Millones de hl Exportado 3 años", ylab=" hl",xlab="mes",type="b", ylim = c(70000, 380000), xlim = c(1,36) ) 

abline(modelo_vino, col="red")

** Residuales

par(mfrow=c(2,2))
plot(lm(Vino_Fiscal$Mes ~ Vino_Fiscal$Exportaciones , data=Vino_Fiscal))

library(ggplot2)
library(plotly)
library(plyr)

dat <- data.frame(Vino_Fiscal)
                 

p <- ggplot(dat, aes(x=Xv, y=Yv )) + 
  xlab("Julio 2016 a Julio 2019") +
  ylab("Hl Vino") +
            geom_point(shape=1) +     # Use hollow circles
            geom_smooth()            

ggplotly(p)

Uso de Bibliotecas en R

R-CRAN es un leguaje que originalmente se desarrolló para el campo disciplinar de la estadística. No es de sorprender entonces que haya mucho material de simulación basado en Montecarlo. Si bien hemos visto que es relativamente sencillo hacer el trabajo a mano (programado), esto muchas veces no es compatible con el tiempo disponible ni con los criterios de calidad del software que es requerido por la actividad profesional o científica. Una alternativa para evadir este inconveniente, es el uso de bibliotecas (library). Existen más de 20.000 bibliotecas específica oficiales. Cada una de ellas está avalada generalmente por más de cinco publicaciones con referato y sueles ser un alternativa segura y rápida para enfocarnos en el problema del modelado y la simulación sin tener que preocuparnos por el código.

Para poder invocar una biblioteca desde R es necesario descargarla de internet. Para ello se puede ejecutar en R-Studio la secuencia “Tools” “Install packages” y elegir el nombre del paquete que quieras instalar. También es posible hacer esto desde la línea de comando con:

    install.packages("nombre_paquete")

Una vez que la bibliotea se ha bajado y copiado en tu PC o teléfono, no deberás volver a hacer este proceso y para usarla sólo bastará con invocarla con el comando:

    library(nombre_paquete)

Esto agrega al lenguaje unos comandos nuevos que permiten resolver nuevos problemas. En el sitio https://cran.r-project.org/ la hoja específica de uso de todos los paquetes oficiales.

Usaremos una biblioteca llamada psycho debería instalarla así:

    install.packages("psycho")
library(psych)
pairs.panels(Vino_Fiscal)

Esto muestra la matriz de correlación o matriz de covarianza de las variables que intervienen. Note como se ha registrado una mayor eficiencia energética o lo que es lo mismo, un descenso de en lo que dentro de los ODS 2030 se llama intensidad energética.

Uso de Time Sieries como biblioteca

Estacionalidad en la energía

#VAN y TIR por el método Montecarlo

Recurriremos al uso de una biblioteca llamada FinCal, para repetir el proceso que ya ensayamos con el modelo del lote económico EOQ. Es decir veremos como usar R-CRAN para operar sobre un vector que tiene los flujos de fondos descontados e un proyecto utilizando una biblioteca específicamente diseñada para ello. Luego alimentaremos al modelo no con un vector de datos sino con un vector que contiene dos filas. La primera será el flujo de fondo tal como se usó en el primer caso y la segunda es una componente que representa la volatilidad. Este concepto de “volatilidad” hace referencia al riesgo que sumimos en pronosticar ingresos y egresos a futuro. Nuestra certeza sobre los flujos de hace menos confiable conforme transcurre más tiempo en el desarrollo del proyecto. Por lo tanto la segundo componente del nuevo vector tiene algo así como la varianza creciente por la que afectaremos a los pronósticos de fondos futuros.

Uso de la biblioteca FinCal

Tal como se señalo más arriba deberemos instalar la biblioteca usanso el comando respectivo solo la primera vez que deseemos instalar en unestro computador. Ejecuteremos entonces:

    install.packages("FinCal")
    

A partir de este momento podemos invocar a la biblioteca como ya sabemos.

library(FinCal)

Esta biblioteca ha agregado 62 comandos de matemática financiera a nuestra computadora. para saber cuales son ejecutamos la siguiente línea.

ls("package:FinCal")
 [1] "bdy"                   "bdy2mmy"               "candlestickChart"     
 [4] "cash.ratio"            "coefficient.variation" "cogs"                 
 [7] "current.ratio"         "ddb"                   "debt.ratio"           
[10] "diluted.EPS"           "discount.rate"         "ear"                  
[13] "ear.continuous"        "ear2bey"               "ear2hpr"              
[16] "EIR"                   "EPS"                   "financial.leverage"   
[19] "fv"                    "fv.annuity"            "fv.simple"            
[22] "fv.uneven"             "geometric.mean"        "get.ohlc.google"      
[25] "get.ohlc.yahoo"        "get.ohlcs.google"      "get.ohlcs.yahoo"      
[28] "gpm"                   "harmonic.mean"         "hpr"                  
[31] "hpr2bey"               "hpr2ear"               "hpr2mmy"              
[34] "irr"                   "irr2"                  "iss"                  
[37] "lineChart"             "lineChartMult"         "lt.d2e"               
[40] "mmy2hpr"               "n.period"              "npm"                  
[43] "npv"                   "pmt"                   "pv"                   
[46] "pv.annuity"            "pv.perpetuity"         "pv.simple"            
[49] "pv.uneven"             "quick.ratio"           "r.continuous"         
[52] "r.norminal"            "r.perpetuity"          "sampling.error"       
[55] "SFRatio"               "Sharpe.ratio"          "slde"                 
[58] "total.d2e"             "twrr"                  "volumeChart"          
[61] "was"                   "wpr"                  

Si necesito conocer que hace cada comando nuevo puedo usar el signo de pregunta para ver la página de ayuda interna. Asi:

    ?npv

Esto debería darle información sobre cada comando nuevo. Veremos algunos ejemplos simples para que tome experiencia en el caso de simulación determinística de flujo de fondos.

Minicaso

Un inversionista coloca $100 durante un año a una tasa de interés simple de 1.5% mensual pagadera mensualmente
¿Qué retribución obtiene durante el año?

I= 100*0.015*12
F=100 + I
F
[1] 118

Minicaso Reinversión de Dividendos

Considere el caso del inversionista del ejemplo anterior, pero suponiendo que recibe los intereses al final de cada mes y que los reinvierte inmediatamente en las mismas condiciones de la inversión inicial.
¿Qué cantidad de dinero recibirá al cabo de un año ?

fv.simple(r = 0.015, n=12, pv = -100)
[1] 119.5618

Convertir de tasa Anual a Mensual

¿Cuál es la tasa de interés nominal anual de una inversión que ofrece el 1.5% de interés pagado al final de cada mes?

r.norminal(r = 0.015, 12) * 12
[1] 0.1801125

Plazo fijo

¿Cuál es la tasa efectiva anual de rendimiento de una inversión que ofrece un interés nominal anual del 8%, pagadero cada semestre vencido, pero que el interesado procede a reinvertirlo?

ear(r = 0.08, 2)
[1] 0.0816

Minicaso flujo de fondos

Crearemo un flujo de fondos consolidado de un proyecto hipotético de la creación de una bodega boutique con destino enoturístico que compite contra otro proyecto similar pero del terreno de la cervezería artesanal. Cada uno de estos proyectos será identificado por los flujos totales FFN1 y FFN2. El proyecto comienza en 2019 y se puede recuperar la inversión hasta 2028


Crearemos el primer flujo de fondos:

#Enoturismo
año<-
c(2019,2020,2021,2022,2023,2024,2025,2026,2027,2028)
FFN1<-c(-940693, 186255, 186255, 186255,
37323,37323,37323,37323, 116482, 280651)
plot(año,FFN1,pch=19,cex=3,col="dark red")
abline(0,0)

Ahora crearemos el flujo de fondo correspondientes a la actividad de la cerveza. Este proyecto tiene equipos de frío que no sirven más a partir del año 2024.

#Cerveza artesanal
FFN2<-c(-19132841, 5691206, -14230711,
16387818, 24645898)
plot(año[2:6],FFN2,pch=19,cex=3,col=rgb(.25,
0.5, .3))
abline(0,0)

Selección de proyecto más conveniente

Comparemos los VAN de ambos proyectos

# Enoturismo
FinCal::pv.uneven(0.3339,-FFN1)
[1] -414627.2

Este proyecto se realiza en un país riesgozo de modo que lo castigo con una tasa más alta.

# Creveza artesanal
FinCal::pv.uneven(0.18,-FFN2)
[1] -1562583

Selección de mejor proyecto

    Proyecto del Enoturismo

Comparación por TIR

TIR1 = irr(FFN1)
TIR2 = irr(FFN2)
TIR1
[1] 0.03481718
TIR2
[1] 0.1487625

Según el TIR el proyecto más conveniente es:

  Proyecto de creveza artesanal.
  

¿Que proyecto elegirías tu?

TIR y VAN con Montecarlo

Determinaremos cuantos períodos tiene cada proyecto y le asignaremos una varianza creciente a sus flujos de fondos. Esto podría hacerse con la distribución de probalilidades F se Snedecor (Senedorv o Snedecorf). Pero por sencillez tomaremos valores estimados por nosotros.

Vector de Volatilidad

length(FFN1)
[1] 10
Volatilidad <- c( 0.1 ,0.2, 0.3, 0.4, 0.5,
0.6, 0.7, 0.8, 0.9, 1.0)

Flujo de Fondos Estocástico

VAN con Montecarlo

Las funciones de FinCal pueden aplicarse a una variable sola (que en realidad es una matriz de uno por uno), pero también a una matriz de mayores dimensiones. En lugar de darnos un valor nos dará una campana de Gauss de valores de salida.

Para ello crearemos un dataset.

FFN_S <- matrix(rnorm(144,FFN1,Volatilidad),
ncol=12, nrow=12, byrow=TRUE )
FFN_S[ ,1] <- rnorm(12, FFN1[1],
100*Volatilidad[1])

En este caso FFN_S representa el flujo de fondos Estocástico de 12 alternativas tomadas aleatoriamente usando la volatilidad como generador estocástico.

Histograma del VAN Enoturismo

#creo una variable auxiliar

VAN_S <- c(0,0,0,0,0,0,0,0,0,0,0,0)

# cargo en esa variable los valores de flujos aleatorios 
for (i in 1:12) { (VAN_S[i] <-
# calculo para cada uno de los 12 fondos un VAN
                     FinCal::npv(0.18,FFN_S[i,] ))}
# imprimo el histograma
hist(VAN_S)

Densidad de valores en el VAN Montecarlo

density(VAN_S)

Call:
    density.default(x = VAN_S)

Data: VAN_S (12 obs.);  Bandwidth 'bw' = 9.327e+04

       x                  y            
 Min.   :-1255828   Min.   :8.590e-09  
 1st Qu.:-1004399   1st Qu.:2.485e-07  
 Median : -752970   Median :1.167e-06  
 Mean   : -752970   Mean   :9.928e-07  
 3rd Qu.: -501541   3rd Qu.:1.561e-06  
 Max.   : -250112   Max.   :2.021e-06  

Gráfica de densidad del VAN Montecarlo

plot(density(VAN_S))

12 Anexo uso de R-Cran

12.1 Syntax highlighting

Here is a sample code chunk, just to show that syntax highlighting works as expected.

12.2 Exploración de datos

Here is the structure of the iris dataset.

str(iris)
'data.frame':   150 obs. of  5 variables:
 $ Sepal.Length: num  5.1 4.9 4.7 4.6 5 5.4 4.6 5 4.4 4.9 ...
 $ Sepal.Width : num  3.5 3 3.2 3.1 3.6 3.9 3.4 3.4 2.9 3.1 ...
 $ Petal.Length: num  1.4 1.4 1.3 1.5 1.4 1.7 1.4 1.5 1.4 1.5 ...
 $ Petal.Width : num  0.2 0.2 0.2 0.2 0.2 0.4 0.3 0.2 0.2 0.1 ...
 $ Species     : Factor w/ 3 levels "setosa","versicolor",..: 1 1 1 1 1 1 1 1 1 1 ...

12.3 Escritura de fórmulas

Estilo Latex :

\[\bar{x} = \frac{1}{n} \sum_{i=1}^n x_i\]

13 Tablas

Here is a sample table output.

(4.3,5.5] (5.5,6.7] (6.7,7.9]
(2,2.6] 11 12 1
(2.6,3.2] 18 49 16
(3.2,3.8] 26 8 3
(3.8,4.4] 4 2 0

Here we display a crosstab displayed in several different ways with a “pills” interface. To do this, just pass your table() result to the pilltabs() function.

Sepal.Length Sepal.Width Petal.Length Petal.Width Species
5.1 3.5 1.4 0.2 setosa
4.9 3.0 1.4 0.2 setosa
4.7 3.2 1.3 0.2 setosa
4.6 3.1 1.5 0.2 setosa
5.0 3.6 1.4 0.2 setosa
5.4 3.9 1.7 0.4 setosa
Sepal.Length Sepal.Width Petal.Length Petal.Width Species
5.1 3.5 1.4 0.2 setosa
4.9 3.0 1.4 0.2 setosa
4.7 3.2 1.3 0.2 setosa
4.6 3.1 1.5 0.2 setosa
5.0 3.6 1.4 0.2 setosa
5.4 3.9 1.7 0.4 setosa

14 Figuras

14.1 Base graphics

A base graphics histogram :

14.2 ggplot2

Same with ggplot2 :

Beautiful ggplot2 histogram, really

Figure 14.1: Beautiful ggplot2 histogram, really

15 Tabbed sections

Here we test if tabbed sections work correctly.

15.1 Classical tabs

classical tabs without fading effect.

15.1.1 First tab

Quisquam sunt fugit sed aut quis et rerum mollitia. Qui consectetur eius autem ut assumenda alias. Repudiandae aut deleniti quod saepe nihil ratione alias laborum. Quibusdam aspernatur autem omnis voluptatum. Delectus illo non aut. Perferendis sunt facilis sed quam velit. Veniam voluptates ut adipisci vel debitis deserunt rerum exercitationem. Accusamus quod eius occaecati voluptatem. Ut et qui veritatis. Nulla non eum id consectetur autem pariatur. Labore aperiam officiis molestiae sed ut perferendis ea. Aperiam aut ratione autem dolorem. Fuga reprehenderit tempora ut ipsam cumque officiis dolorum. Sapiente omnis rerum sint quibusdam et delectus ratione. Molestiae praesentium rerum debitis deleniti voluptates enim. Nihil aperiam velit provident accusamus suscipit voluptates. Aut sequi id debitis tempore. Qui atque quas sed illum officia maiores incidunt. Similique maxime aliquam corrupti aut provident eaque. Laudantium placeat cupiditate pariatur dolore perspiciatis expedita impedit nobis. Quaerat non temporibus tempora provident eligendi.

15.1.2 Second tab

Cum eaque dicta architecto culpa eius. Dignissimos officiis error exercitationem. Adipisci odit ad ea iusto fugiat laborum maiores. Dolore sunt et veritatis alias nesciunt maxime cumque. Culpa aut non ea. Culpa ex quia debitis sint eveniet cum. Non eos ex aperiam dolor hic. Consectetur delectus placeat rerum consequuntur ducimus sed fugiat non. Aut voluptatem et et. Omnis sunt veniam omnis ullam. Dolorem eius perspiciatis et veniam hic reprehenderit ipsam ut. Exercitationem rem eius quo. Nemo quis in voluptatibus ex. Aut nihil quo iure quia. Error quam quidem inventore. Aut est est aut atque ipsum aut repellat. Eligendi delectus aut et quia voluptas dolores. Perspiciatis et reiciendis deleniti harum nihil officiis aperiam. Laborum necessitatibus beatae modi aut illo. Quaerat esse eum ipsa quisquam totam. Vitae nesciunt excepturi voluptate iusto molestiae qui animi corrupti. Voluptates et illum quia.

15.2 Pill tabs

Pill tabs with fading effect.

15.2.1 First tab

Quisquam sunt fugit sed aut quis et rerum mollitia. Qui consectetur eius autem ut assumenda alias. Repudiandae aut deleniti quod saepe nihil ratione alias laborum. Quibusdam aspernatur autem omnis voluptatum. Delectus illo non aut. Perferendis sunt facilis sed quam velit. Veniam voluptates ut adipisci vel debitis deserunt rerum exercitationem. Accusamus quod eius occaecati voluptatem. Ut et qui veritatis. Nulla non eum id consectetur autem pariatur. Labore aperiam officiis molestiae sed ut perferendis ea. Aperiam aut ratione autem dolorem. Fuga reprehenderit tempora ut ipsam cumque officiis dolorum. Sapiente omnis rerum sint quibusdam et delectus ratione. Molestiae praesentium rerum debitis deleniti voluptates enim. Nihil aperiam velit provident accusamus suscipit voluptates. Aut sequi id debitis tempore. Qui atque quas sed illum officia maiores incidunt. Similique maxime aliquam corrupti aut provident eaque. Laudantium placeat cupiditate pariatur dolore perspiciatis expedita impedit nobis. Quaerat non temporibus tempora provident eligendi.

15.2.2 Second tab

Cum eaque dicta architecto culpa eius. Dignissimos officiis error exercitationem. Adipisci odit ad ea iusto fugiat laborum maiores. Dolore sunt et veritatis alias nesciunt maxime cumque. Culpa aut non ea. Culpa ex quia debitis sint eveniet cum. Non eos ex aperiam dolor hic. Consectetur delectus placeat rerum consequuntur ducimus sed fugiat non. Aut voluptatem et et. Omnis sunt veniam omnis ullam. Dolorem eius perspiciatis et veniam hic reprehenderit ipsam ut. Exercitationem rem eius quo. Nemo quis in voluptatibus ex. Aut nihil quo iure quia. Error quam quidem inventore. Aut est est aut atque ipsum aut repellat. Eligendi delectus aut et quia voluptas dolores. Perspiciatis et reiciendis deleniti harum nihil officiis aperiam. Laborum necessitatibus beatae modi aut illo. Quaerat esse eum ipsa quisquam totam. Vitae nesciunt excepturi voluptate iusto molestiae qui animi corrupti. Voluptates et illum quia.