Advertising





lunes, 23 de marzo de 2020

Driver privado de Nvidia Optimus para Debian. Easy install

Algunos siempre hemos instalado el driver de Nvidia, de la forma difícil, que es con el Driver de Nvidia Optimus original de la página de Nvidia. En este caso les traigo los comandos necesarios para instalar ese Driver, con un sólo comando en Debian Buster 10:

sudo apt install bumblebee-nvidia primus

lunes, 16 de marzo de 2020

Científicos logran una Teletransportación Cuántica compleja

Científicos logran una Teletransportación Cuántica compleja:

https://www.google.com/amp/s/mundo.sputniknews.com/amp/ciencia/201908241088480112-cientificos-logran-por-primera-vez-realizar-una-teletransportacion-cuantica-compleja/

lunes, 9 de marzo de 2020

PEP8: Reglas de estilo

PEP8: Reglas de estilo.

Pueden descargar el editor spyder desde Debian:

sudo apt install spyder spyder3

Comandos para chequear PEP8, flake8, con pip y pip3:

sudo pip3 install flake8
sudo pip install flake8

flake8 code.py

Fuente: http://diarium.usal.es/inma/?page_id=51

PEP = Python Enhancement Proposal (Propuesta de Mejora de Python)
Las normas de estilo son muy importantes en python, empezamos con ellas. Nuestro editor Spyder nos va a ayudar poniendo una alerta amarilla en cada error de estilo que escribamos.
PEP8
Ya tenemos configurado Spyder para que nos muestre los errores de estilo y los espacios en el editor.
Cada error que escribamos nos mostrará un triangulo amarillo a la izquierda, si pasamos el puntero por encima nos dice cual es el error que estamos cometiendo. En este caso dice que echa de menos un espacio alrededor del operador.
A continuación tienes un listado de normas básicas, si quieres ver algo mas completo accede a http://mundogeek.net/traducciones/guia-estilo-python.htm

Indentación o sangrado

Indentación es un anglicismo que significa mover un bloque de texto a la derecha. En algunos manuales también ves escrito identación.
En muchos lenguajes de programación para crear bloques, se usan llaves, por ejemplo en java:
if (edad < 18){ System.out.println(“El alumno es menor de edad”);
}else{
System.out.println(“El alumno es mayor de edad”);
}
System.out.println(“Fin de la comprobación”);

El indentado o sangrado se suele usar para que el código quede mas legible, sin embargo no es de uso obligado, funciona igual aunque no se indente y todo el código estuviera escrito pegado al inicio de la línea.
En Python los bloques de código se crean mediante el indentado, nos ahorramos las llaves, sin embargo hay que prestar mucha atención al indentado, sería así:
if edad < 18: print(“El alumno es menor de edad”)
else:
print(“El alumno es mayor de edad”)
print(“Fin de la comprobación”)

REGLA DE ESTILO: Usa 4 espacios por cada nivel de indentación. NO usar tabuladores.
ojo Cada ‘nivel de indentado’ se refiere al anidamiento de bloques, por ejemplo: tienes un bloque for si dentro creas un bloque if, este tendrá un indentado de 8 espacios:
for num in (7, 13, 22, 5, 16): if num > 8:
print(num, “Es mayor que 8”)

Espacios en blanco en expresiones y sentencias

  • Rodea siempre operadores de asignación (=) aritméticos (+ * – / % ** ) relacionales o de comparación (== != < > <= >=) y lógicos (and or not) con un espacio en cada lado
    i = i + 1 c = (a + b) * (a - b)
  • Usa siempre un espacio después de una coma
    aulas = (‘aula1′, ‘aula2′, ‘aula3′)

Evita espacios en blanco extra

  • No uses espacios alrededor del signo ‘=’ cuando se use para indicar el valor de un parámetro por defecto.
    def mi_funcion(equipo, aula=1): print(“Hacer algo con el equipo ” + equipo + ” del aula ” + aula)
  • Inmediatamente después de entrar o antes de salir de un paréntesis, corchete o llave.
    print (equipos[1],
    macaddress[1])
  • Inmediatamente antes de abrir un paréntesis o un corchete
    dicccionario['key'] = lista[index] print(dict['key'])
  • Inmediatamente antes de una coma, punto y coma, o dos puntos:
    x = 4; y = 6 if x == 4:
    print(x, y)
  • Más de un espacio alrededor de un operador de asignación (u otro operador) para alinearlo con otro.
  • Evita los típicos espacios al final de cualquier línea. Estos espacios no son fáciles de detectar, spyder te mostrará el error con el triangulo amarillo.

Tamaño máximo de líneas

  • 79 caracteres. (Esta regla me cuesta especialmente cumplirla)

Líneas en blanco

  • Después de definir una función o una clase deja dos líneas en blanco.
  • Las definiciones de métodos dentro de una clase se separan con una línea en blanco
  • Al final del script deja una línea en blanco
  • Generalmente se desaconsejan las sentencias compuestas (varias sentencias en la misma línea). Preferiblemente no escribir:
    if foo == ‘blah’: do_blah_thing() do_one(); do_two(); do_three()

Codificación de caracteres

Para Python 3.0 y superiores, se recomienda UTF-8 en lugar de Latin-1 (también conocida como ISO-8859-1), se escribe la siguiente línea al inicio del script:
# -*- coding: utf-8 -*-

Imports

Para utilizar las librerías estándar de python o de terceros debemos previamente importarlas al inicio del script, con la palabra reservada import seguida del nombre de la librería:
  • Normalmente los imports deberían colocarse en distintas líneas, por ejemplo:
    import os import sys
  • Los imports se colocan siempre en la parte superior del archivo, justo después de cualquier comentario o cadena de documentación del módulo, y antes de las variables globales y las constantes del módulo. Los imports deberían agruparse siguiendo el siguiente orden:
    • imports de la librería estándar
    • imports de proyectos de terceras partes relacionados
    • imports de aplicaciones locales/imports específicos de la librería
  • Deberías añadir una línea en blanco después de cada grupo de imports.

Comentarios

  • De una única línea, deben comenzar con un # y un espacio.
  • Multilínea empiezan y acaban con tres comillas dobles
    “”"Comentario de varias líneas
    bla bla bla
    otra línea
    “”"
    # Comentario de una sola línea

Documentación

Docstrings o cadenas de documentación es una literal de cadena de caracteres que se coloca como primer enunciado de un módulo, clase, método o función, y cuyo propósito es explicar su intención.
Siempre se utiliza “”" para abrir y cerrar el docstring aunque sean de una sola línea.
Escribe docstrings para todos los módulos, funciones, clases, y métodos públicos.

Como nombrar variables funciones o clases

  • minusculas_con_guiones para variables, funciones, métodos y atributos
  • minusculas_con_guiones oTODO_MAYUSCULAS para las constantes
  • PalabrasEnMayusculas para las clases
  • Atributos: interfaz, _interno, __privado

Ejercicio 1.1

Objetivo: ser consciente de la importancia de los espacios y líneas en blanco en nuestro código
  1. Copia este script en un archivo usando vim, o gedit, No uses todavía spyder, que te daría muchas pistas. (Repasa las comillas seguro que tienes que escribirlas de nuevo)
  2. Nómbralo como e1_1_pep8.py
  3. Ejecutalo en una consola con el comando: ~$python3 e1_1_pep8.py
  4. ¿Da algún error o aparentemente todo es correcto?
  5. Abre de nuevo el archivo, en el mismo editor que lo creaste, busca los errores de estilo y corrígelos
  6. ¿Cuántos errores has encontrado?
  7. Abre el archivo ya corregido en spyder, y observa si aún hay algún triangulo amarillo en el lateral izquierdo.
  8. ¿Cuántos errores has dejado sin corregir?

# -*- coding: utf-8 -*- import os,sys
def mifuncion( arg1 ,arg2 = 8):
“”" Esta función imprimirá sus dos parámetros, sólo el primero es obligatorio “”"
print (“Primer argumento=”,arg1)
print(“Segundo argumento=”,arg2)
#Mostrar archivo que se está ejecutando y en que directorio estamos
print( “El nombre de este script es:”,sys.argv[0 ])
print(“Estamos en el directorio:”, os.getcwd())
var1= 4
var2 =”FELIZ AÑO 2018″
mifuncion(var1,var2)
var3, var4 = (3,4)
mifuncion(var3)

Ejercicio 1.1 Solución

# -*- coding: utf-8 -*- import os
import sys
def mifuncion(arg1, arg2=8):
“”" Esta función imprimirá sus dos parámetros, sólo el primero es
obligatorio “”"
print(“Primer argumento=”, arg1)
print(“Segundo argumento=”, arg2)
# Mostrar archivo que se está ejecutando y en que directorio estamos
print(“El nombre de este script es:”, sys.argv[0])
print(“Estamos en el directorio:”, os.getcwd())
var1 = 4
var2 = “FELIZ AÑO 2018″
mifuncion(var1, var2)
var3, var4 = (3, 4)
mifuncion(var3)

Ejercicio 1.1 – Observaciones

  • En total había 21 errores de estilo, solo de espacios en blanco mal colocados y de líneas en blanco
  • Si te acostumbras a escribir código con un editor como spyder que te muestra rápidamente los errores que vas cometiendo, veras que pronto automáticamente escribes código en modo pythonic.
  • Algunas cosas que puedes ver en este sencillo código:
    • Como se importan librerías estándar con import
    • Como se crea y se llama a una función
    • Como se asignan valores a variables, incluso utilizando una tupla con dos valores para ser asignados a dos variables distintas: var3 y var4
    • Observa que el tipo de las variables no se declara y no es inmutable: el parámetro arg2, su valor por defecto es un entero, sin embargo llamamos a la función con la cadena var2

jueves, 5 de marzo de 2020

¿Cómo hacer una Distribución basada en Debian?


¿Cómo hacer una Distribución basada en Debian?.

Una distribución es un compendio de Softwares, para realizar tareas específicas, para una población en particular.

Debes primero hacer entrevistas a la población, para ver cuales son las necesidades que tienen, y cómo las cumplirás con la distribución. Luego, debes buscar los Softwares que cumplan con esas necesidades. Utilizas la herramienta live-build para construirlo.

Con los siguientes comandos en Debian 10, podrás construir una distribución con parámetros por defecto:

Code:
    https://github.com/rockcesar/python_code/blob/master/How-to-debian-live.txt

Imagen resultante:
    live-image-amd64.hybrid.iso

Ver el siguiente link, para ver las variantes:
    https://live-team.pages.debian.net/live-manual/html/live-manual/the-basics.es.html#169

Manual completo:
    https://live-team.pages.debian.net/live-manual/html/live-manual/index.es.html

Me pueden consultar al siguiente correo:
    cr-innova.negocio.site

Mi Tesis de pregrado fue hacer una Distribución de GNU/Linux basada en Debian para estudiantes de Computación de la Universidad del Zulia, en Venezuela, hace 10 años.

domingo, 1 de marzo de 2020

Lenguajes de Programación

Lenguajes de Programación:


Criptomonedas

Criptomonedas:


Algunos canales de Youtube de TV en Venezuela

Algunos canales de Youtube de TV en Venezuela:


Cómo crear video de Youtube con poco ancho de banda


Cómo crear video de Youtube con poco ancho de banda:




Cómo minar en Venezuela

Cómo minar en Venezuela:


Links más importantes sobre el Petro

Links más importantes sobre el Petro:


Y exchanges del Petro:


Todos merecen vivir

El cerebro de las Ballenas es el más grande del mundo y por consiguiente, tienen más neuronas que los Humanos. El segundo cerebro más grande es el de los Elefantes.

Por esto mismo creo que los Dinosaurios tenían cerebros grandes.

Las moscas y las hormigas también tienen cerebros.

Es decir, todos son seres vivos con cerebro y merecen vivir.

Ballena: https://ofwhale.com/es/que-tan-grande-es-el-cerebro-de-una-ballena/

Elefante: http://www.elefantepedia.com/el-cerebro-del-elefante/

Humano: https://es.wikipedia.org/wiki/Cerebro_humano

Mosca: https://www.levante-emv.com/sociedad/2018/07/22/cerebro-mosca/1747673.html

Hormiga: http://biotech-spain.com/es/articles/investigar-el-cerebro-de-las-hormigas-permitir-conocer-mejor-como-nos-organizamos-/

Merecen vivir: https://twitter.com/ambienteeuropeo/status/1226965276874465281

Video:

 

Visita nuestras apps, Youtube y tiendas online.

César OpenSource Expert, Videos. Youtube channel: https://youtube.com/@rockcesar85 Visita nuestra tienda online: https://shop.latin-chai...