martes, 15 de agosto de 2023

Gráficas con Matplotlib - Init

 

# Ejemplo básico

import matplotlib.pyplot as plt
import numpy as np

eje_x = ["a","b","c","d","e"]
datos = [10,20,30,40,50]

plt.plot(eje_x,datos)
plt.show()

# Ejemplo básico 1



años = ["2011","2012","2013","2014","2015",
        "2016","2017","2018","2019","2020"]

nivel1 = np.random.rand(10)*100
nivel2 = np.random.rand(10)*200 + 100
nivel3 = np.random.rand(10)*300 + 200
nivel4 = np.random.rand(10)*400 + 300
nivel5 = np.random.rand(10)*500 + 400

plt.plot(años,nivel1, label="Nivel 1",color="purple",marker="<",linestyle="-")
plt.plot(años,nivel2, label="Nivel 2",marker="*",linestyle="--")
plt.plot(años,nivel3, label="Nivel 3",marker="^",linestyle=":")
plt.plot(años,nivel4, label="Nivel 4",marker=".",linestyle="-.")
plt.plot(años,nivel5, label="Nivel 5",marker="+",linestyle=" ")

# activar Leyendas
plt.legend()
# activar titulo grafica
plt.title("Examen de Certificación")
# activar etiquetas de ejes
plt.xlabel("Años")
plt.ylabel("Puntaje")
# personalizar incrementos/escala de cada eje
plt.yticks(np.arange(0,1001,50)) #rango de 0 a 1000 y brincos de cada 50
# activar cuadricula de la grafica
plt.grid()
# activar cuadricula de la grafica más fina
plt.minorticks_on()

# mostrar grafica
plt.show()



miércoles, 30 de junio de 2021

¿Cómo mido la eficiencia de mi código fuente?

¿Alguna vez te has preguntado sobre la eficiencia de tu código programado? En esta ocasión explicaremos sobre Big O (también llamado O grande / O mayúscula).

La O mayúscula es una notación matemática que nos ayuda a describir el comportamiento de una función “al límite”. Esta notación tiene muchos usos en realidad, sin embargo, el que nos interesa ahora es el que se le da en las Ciencias de la Computación.

En las ciencias de la computación esta notación nos ayuda a describir el comportamiento de un algoritmo, ya sea temporal (cuantas unidades de tiempo va a tardar en ejecutarse) o en espacio (cuanta memoria va a ocupar mientras se ejecuta), esto basado en la cantidad de entradas que recibe y sobre los que opera. A este "comportamiento" también se le conoce como complejidad de un algoritmo. Este análisis de complejidad nos sirve generalmente cuando las entradas de el algoritmo analizado son muy grandes.

En un ejemplo directo aplicado sería buscar un valor dentro de un arreglo de enteros ordenado (de seguro ya tienes una solución para dicho algoritmo) pero analicemos por partes (queremos buscar el valor 26) en la siguiente cadena de longitud n=9, plantearemos 2 soluciones:

 


 

1.      Si pensamos de “una forma normal” sería fácil; recorro desde el inicio hasta encontrar el número 26. Si pensamos en “el peor de los casos” sería 9 veces leía la cadena. Vemos que es igual a N entonces digamos que la complejidad computacional será de O(n).

2.      Ahora que pasaría si te digo que podríamos hacer lo siguiente: partimos en 2 la cadena y quedaría de la siguiente forma:


 

Validamos si el elemento del centro (en este caso es 18) es menor, igual o mayor que el elemento buscado (26) y confirmaremos que estará al lado derecho.

Y empezamos a recorrer la mitad de la derecha y luego aplicamos lo mismo (partimos la cadena nuevamente en dos) hasta encontrar el resultado ¿Se puede visualizar que es más rápido? En este caso ya no recorrerá N, sino que en el peor de los casos será de: . ¿Cómo lo obtuve? En otro post detalle este resultado.  En lenguaje computación suelen omitir la base del logaritmo y solo poner:

. Entonces la complejidad de este algoritmo será de O(logn).


En el siguiente gráfico nos mostrará sobre la eficiencia de nuestro algoritmo, claramente el resultado en el punto 2 es lo más óptimo.


Recuerda que hay un tiempo constante “c”, el cual es el tiempo que la maquina donde lo correrás el algoritmo.

Utilizar Big O, no sólo puede ayudarte optimizar y/o iniciar la optimización de tu código sino en tener algoritmos mucho más livianos para que no sufra mucho tus servidores. Otro campo por ejemplo donde recién estoy iniciando y me gustaría escribir en otro post es en la aplicación en al Bioinformática.

Para concluir, de hoy en adelante cuando alguien te pregunte la complejidad de tu algoritmo. Lo que espera es una expresión Big O, como el tamaño de conjunto de datos afecta el rendimiento del tamaño del algoritmo. Espero te haya servidor de ayuda y publicará algunos ejemplos en siguientes post.

 

Fuentes importantes de extracción de información para este post:

 

http://www.cs.us.es/~jalonso/cursos/i1m/temas/tema-28.html

https://thatcsharpguy.com/post/notacion-o-grande/

https://codingbackside.wordpress.com/2018/06/24/big-o-notation/

https://www.asanzdiego.com/2018/12/la-notacion-o-grande-con-ejemplos-en-javascript.html


jueves, 4 de marzo de 2021

API vs Microservicio: Microservicios más que un API

 Cuando escribimos software, se debe considerar la implementación y la arquitectura del código. El software es más eficiente cuando se escribe de una forma que la lógica tenga sentido. En forma adicional, se debe considerar la interacción con los usuarios, así como la interface que se utilizara.


Ambos, el concepto de un API y el concepto de microservicios envuelven la estructura e interacciones del software. Un microservicio puede mal interpretarse en algo similar a un API, pero los microservicios tienen mucha más flexibilidad y capacidad que eso. En el artículo revisamos las diferencias entre las API y los microservicios, y detallaremos algunos de los beneficios de un microservicio.

¿Que es un API?

Primero, definamos que es un API. De acuerdo a wikipedia, un API es:

Un conjunto de definiciones de subrutinas, protocolos de comunicación y herramientas para crear software. En términos generales, es un conjunto de métodos de comunicación claramente definidos entre varios componentes.

Una manera fácil de pensar en una API es considerarla como un contrato de acciones que puede solicitar para un servicio en particular. Las API se usan hoy en una multitud de aplicaciones web, como redes sociales, software bancario y mucho más. El contrato estandarizado permite que las aplicaciones externas interactúen con otras.

Acciones comúnes de un API

En el mundo actual, los APIs son usualmente desarrollados con el estilo RESTful. Estos APIs tiene un conjunto de verbos asociados con las acciones del protocolo HTTP, tal como:

  • GET (obtener un único elemento o una colección)
  • POST (agregar un elemento a una colección)
  • PUT (editar un elemento que existe en una colección)
  • DELETE (eliminar un elemento de una colección)

La ventaja de esta coherencia a través de diferentes aplicaciones es tener un estándar al realizar diversas acciones. Los cuatro verbos de HTTP se correlacionan con las capacidades CRUD que muchas aplicaciones usan hoy en día. Cuando se trabaja con diferentes APIs en una aplicación, esto constituye una forma reconocible de comprender las implicaciones de las acciones tomadas en diferentes interfaces.

Ahora que revisamos sobre las APIs, echemos un vistazo a los microservicios.

¿Que es un Microservicio?

De acuerdo a la definición de wikipedia, un microservicio es:

Una técnica de desarrollo de software: una variante del estilo arquitectónico de arquitectura orientada a servicios (SOA) que estructura una aplicación como una colección de servicios acoplados libremente. En una arquitectura de microservicios, los servicios son específicos y los protocolos son livianos.

Pero antes de profundizar en lo que son los microservicios y cómo pueden ser útiles, echemos un vistazo rápido a una arquitectura monolitica. Comprender cómo los microservicios difieren de los monoliticos le dará una mejor idea de los beneficios de pasar a una arquitectura de microservicios.

Aplicaciones Monolíticas

En los inicios del desarrollo de software (y aún en muchos negocios hoy), existe el concepto de monolítico. Una aplicación monolítica es una aplicación única que contiene una colección compleja de funcionalidades, que sirve como un lugar para almacenar todo. Arquitectónicamente, se ve así:


Todos los componentes de la aplicación residen en un área, incluida la capa de interface gráfica, la capa de lógica de negocios y la capa de acceso a datos. Crear aplicaciones monolíticas es un proceso fácil y natural, y la mayoría de proyectos comienzan de esta manera. Pero agregar funcionalidad a la base de código provoca un aumento tanto en el tamaño como en la complejidad, y permitir que este tipo de aplicaciones crezca conlleva desventajas con el tiempo, algunas de estas desventajas conlleva a:

  • Riesgo de caer en la gran bola de lodo anti-patrón, por el volumen de la aplicación, que llegue un momento y no se pueda entender desde un alto nivel.
  • Restricción de la antiguedad tecnologíca dentro de la aplicación monolítica. Especialmente a medida que la aplicación crece, la capacidad de moverse hacia una tecnología diferente se vuelve cada vez más díficil.
  • Realizar cualquier código en la base del código afecta a toda la aplicación, sin importar cuán pequeña sea.

Entonces, ¿Cual es la alternativa a construir una aplicación monolítica?. Una alternativa es, tomar la aplicación monolítica y dividirla en microservicios.

¿Que es un Microservicio?

Tomemos el ejemplo de la aplicación monolítica y modifiquemosla para utilizar microservicios. En este caso, la arquitectura de la aplicación cambiara y se verá de la siguiente forma:

Hay algunas conclusiones clave de esta nueva arquitectura:

  • Las secciones desglosadas de la lógica empresarial, cada una de las cuales abarca un microservicio. En lugar de tener un límite único para toda la aplicación, la aplicación se divide en pedazos. La complejidad de la aplicación se reduce, ya que los diferentes servicios tienen interacciones bien definidos entre sí.
  • La capa de interface gráfica de antes solo necesita interactuar con el cliente y los microservicios de eventos, eliminando una dependencia para los microservicios de facturación en la interface gráfica.
  • El microservicio de facturación no necesita almacenar datos, por lo que no tiene una capa de acceso a datos, en cambio, interactúa y procesa datos directamente desde el microservicio del cliente y del evento.

Ventajas de utilizar este tipo de arquitectura:

  • Es más fácil separar las preocupaciones. Estos límites entre las áreas ayudan con el desarrollo (Solo necesitan preocuparse por los microservicios, no por la aplicación completa) y por comprender la arquitectura de la aplicación.
  • A diferencia de una aplicación monolítica, un microservicio puede usar una tecnología diferente según sea necesario. 
  • Las implementaciones de la aplicación en su conjunto se vuelven más enfocadas. Los microservicios brindan la flexibilidad de implementar diferentes servicios según sea necesario.

Diferencia entre APIs y Microservicios

Hay muchas diferencias entre APIs y Microservicios:

  • Un API es un contrato que proporciona orientación para que un consumidor use un determinado servicio.
  • Un microservicio es un diseño arquitectónico que separa partes de una aplicación (generalmente monolítica) en pequeños servicios independientes.

Por definición, esto significa que un API suele ser una parde de un microservicio, lo que permite la interacción con el propio microservicio. Otra forma de pensar en esto es que la API sirve como un contrato para las interacciones dentro del microservicio, presentando las opciones disponibles para interactuar con el microservicio.

Sin embargo, si miramos el diagrama de microservicios anterior, podemos ver que cada microservicios se construye de manera ligeramente diferente según sus necesidades.

Una aplicación completa puede abarcar una serie de microservicios que usan sus propias APIs para comunicarse entre sí. Además, cada uno de estos microservicios puede abstraer su propia funcionalidad, trazando límites lógicos para la responsabilidad en la aplicación y separando las preocupaciones para crear una base de código más fácil de mantener.

Conclusiones

Con suerte, ahora tiene una mejor comprensión de lo que son las APIs y los microservicios. El mantenimiento y la calidad del código son partes clave de la estrategía de TI exitosa. Los microservicios ayudan en este objetivo. Mantienen a sus equipos ágiles y lo ayudan a satisfacer las demandas de los clientes al producir código de alta calidad y fácil de mantener.


Este artículo se encuentra basado en API vs Microservices: A Microservice Is More Than Just an API.  y traducido por https://www.clubdetecnologia.net/






jueves, 2 de abril de 2020

Oracle: ¿Cómo encriptar paquete?

¿Tienes un paquete que tiene un lógica importante en tu sistema? En Oracle existe una forma de encriptar esa porción de código.

También conocido con la terminología "ofuscar" (encubrir), alguna veces es necesario ya que damos acceso a nuestras bases de datos a personal que tal vez solo están de paso por nuestra empresa, a continuación detallo los pasos.

Antes de iniciar: Guarda el código fuente original, al momento de encriptar ya no hay vuelta atrás considerar que Oracle utiliza el método hash (no reversible).

  1. Existe un ejecutable en $ORACLE_HOME/bin que se llama wrap. Llamándolo desde la consola.
  2. Teniendo el cuerpo del paquete preparado y con nombre:  ob_pack_body.sql
  3. Ejecutamos en la consola lo siguiente: 
  4. wrap edebug=wrap_new_sql iname=ob_pack_body.sql
  5. Finalmente compilen el paquete y voila



    1. Ojo: Sólo hemos creado el body del paquete, se entiende que la cabecera ha sido creada de forma normal.

viernes, 5 de julio de 2019

A hidden message

Cambiamos un poco el enfoque del blog, publicaré de todo un poco.

Uno de mis grupos favoritos, Queen (primero siempre The Beatles), del cual me pareció alucinante su película.
Mientras escuchaba sus canciones en Youtube, un comentario salvaje apreció.

¿Qué opinan?

---------------------------
This is my first post after a few years, so I am so excited. Queen is one of my favorite groups. What do you think about this comment?

sábado, 30 de septiembre de 2017

¿Cómo empezar mi APP Android?

He estado investigando la mejor forma de desarrollar una aplicación móvil. Al inicio empece como todos bien "guerrero" con mi MySQL y servicios con PHP pero luego dije como hago el monitoreo, analytics, entre otras gestiones. No inventemos la rueda para eso existen ya un sin fin de plataformas de ayuda de desarrollo de aplicaciones móviles, en este caso usaremos FireBase de google.

¿Qué es FireBase?
Nada resume mejor que un video explicativo desde su página oficial.

Entre las cosas que maneja tenemos: 


Veo en su web que tiene un sin fin de documentación, lo contra es que puedes elegir planes desde free hasta lo que consumes mensual pagas. Pero en realidad se ve que vale la pena y no invertir dinero y esfuerzo en crear de nuevo la rueda.


En el próximo Post ya vamos a ir viendo la creación del login con el API que podemos usar con firebase.






martes, 8 de agosto de 2017

Android - Navegar en APP - Ejemplo01

Lo primero que debemos de saber para navegar en diferentes interfaces de una APP es tener en cuenta que un activity es como una página web en el idioma android.

Para navegar de activity a otro activity, sólo utiliza el siguiente código:


Intent intent = new Intent(MainActivity.this,Main2Activity.class); 
startActivity(intent);

Donde:

MainActivity--> Es el activity donde te encuentras.
Main2Activity-->Es el activity donde quieres ingresar.

Recuerda que esta porción de código lo debes de ingresar dentro de un evento onClick de un botón de la siguiente forma (el id del botón es "button"):


Button bSiguiente = (Button)findViewById(R.id.button);
bSiguiente.setOnClickListener(new View.OnClickListener() {
    @Override    public void onClick(View view) {
        Intent intent = new Intent(MainActivity.this,Main2Activity.class);
        startActivity(intent);
    }
});

Acá te dejo el código en github:
https://github.com/jocluis/Ejemplo01.git 




martes, 25 de julio de 2017

Android Básico - Instalación

Retomando el blog, desde hoy aprenderemos juntos a desarrollar aplicaciones móviles:

En este tutorial empezaremos con la instalación y primera APP (Hola Mundo), una recomendación tener una computador con mínimo 10 Gigas de RAM.




Créditos al canal Youtube: MaxQuePixels