Manualinux
http://www.nvu.com http://www.gimp.org InicioPresentaciónActualizacionesManualesDescargasNoticiasAgradecimientoEnlaces

Entornos GráficosAplicaciones

DesarrolloEmuladoresInternetJuegosMultimediaSistema

GráficosSonidoVídeo

Editores de Vídeo - CinelerraEditores de Vídeo - LiVES

Editores de Vídeo - Flowblade




Editores de Vídeo - Flowblade




Copyright

Copyright © José Luis Lara Carrascal  2014-2017   http://manualinux.eu



Sumario

Introducción
Movit
MLT
WebVfx
Flowblade
Traducción al Español alternativa
Iniciamos Flowblade
Enlaces




Introducción  

Flowblade
es un editor de vídeo no lineal, escrito en Python y GTK+, que utiliza como motor de procesamiento, el conocido software multimedia, MLT, ya utilizado en aplicaciones como Kdenlive y Shotcut. Aprovechando la potencia del motor descrito, podremos realizar todo tipo de composiciones de audio y vídeo, para luego exportarlo a los formatos soportados por MLT. Personalmente, echo en falta el soporte de la librería multimedia Movit, que proporciona filtros de OpenGL a MLT, y cuya instalación incluyo en el manual, como dependencia de MLT. Desde el 11-07-2017 se incluye la instalación del paquete WebVfx, cuya dependencia es requerida para la ejecución del editor de vídeo, Shotcut.



Movit

Instalación

Dependencias

Herramientas de Compilación


Entre paréntesis la versión con la que se ha compilado Movit para la elaboración de este documento.

* GCC - (7.1.0)
* Gawk - (4.1.4)
* M4 - (1.4.18)
* Libtool - (2.4.6)
* Make - (4.2.1)
* Automake - (1.15.1)
* Autoconf - (2.69)
* Pkg-config - (0.29.2)

Librerías de Desarrollo

* Eigen3 - (3.3.4)
Epoxy - (1.4.3)
* Fftw3 - (3.3.6-pl2)
* Google Test - (1.8.0)
* SDL2 - (2.0.5)
* SDL2_image - (2.0.1)



Descarga

movit-1.5.2.tar.gz  |  googletest-release-1.8.0.tar.gz

Optimizaciones

$ export {C,CXX}FLAGS='-O3 -march=amdfam10 -mtune=amdfam10'

Donde pone amdfam10 se indica el procesador respectivo de cada sistema seleccionándolo de la siguiente tabla:
* La opción '-march=' establece el procesador mínimo con el que funcionará el programa compilado, la opción '-mtune=' el procesador específico para el que será optimizado. 

* Los valores separados por comas, son equivalentes, es decir, que lo mismo da poner '-march=k8' que '-march=athlon64'.

* En versiones de GCC 3.2 e inferiores se utiliza la opción '-mcpu=' en lugar de '-mtune='.
Valores CPU
Genéricos
generic Produce un código binario optimizado para la mayor parte de procesadores existentes. Utilizar este valor si no sabemos el nombre del procesador que tenemos en nuestro equipo. Este valor sólo es aplicable en la opción '-mtune=', si utilizamos GCC. Esta opción está disponible a partir de GCC 4.2.
native Produce un código binario optimizado para el procesador que tengamos en nuestro sistema, siendo éste detectado utilizando la instrucción cpuid. Procesadores antiguos pueden no ser detectados utilizando este valor. Esta opción está disponible a partir de GCC 4.2.
Intel
atom Intel Atom con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3 y extensiones 64-bit. Esta opción está disponible desde GCC 4.6, hasta GCC 4.8. A partir de GCC 4.9 se utiliza la definición bonnell.
bonnell Intel Bonnell con soporte de instrucciones MOVBE, MMX, SSE, SSE2, SSE3, SSSE3 y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.9.
broadwell Intel Broadwell con soporte de instrucciones MOVBE, MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AVX, AVX2, AES, PCLMUL, FSGSBASE, RDRND, FMA, BMI, BMI2, F16C, RDSEED, ADCX, PREFETCHW y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.9.
core2 Intel Core2 con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3 y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.3.
core-avx2 Intel Core (Haswell). Esta opción está disponible desde GCC 4.6, hasta GCC 4.8. A partir de GCC 4.9 se utiliza la definición haswell.
core-avx-i Intel Core (ivyBridge) con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, AVX, AES, PCLMUL, FSGSBASE, RDRND, F16C y extensiones 64-bit. Esta opción está disponible desde GCC 4.6, hasta GCC 4.8. A partir de GCC 4.9 se utiliza la definición ivybridge.
corei7 Intel Core i7 con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1 y SSE4.2 y extensiones 64-bit. Soporta también los procesadores Intel Core i3 e i5. Esta opción está disponible desde GCC 4.6, hasta GCC 4.8. A partir de GCC 4.9 se utiliza la definición nehalem.
corei7-avx Intel Core i7 con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, AVX, AES y PCLMUL y extensiones 64-bit. Soporta también los procesadores Intel Core i3 e i5. Esta opción está disponible desde GCC 4.6, hasta GCC 4.8. A partir de GCC 4.9 se utiliza la definición sandybridge.
haswell Intel Haswell con soporte de instrucciones MOVBE, MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AVX, AVX2, AES, PCLMUL, FSGSBASE, RDRND, FMA, BMI, BMI2, F16C y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.9.
i386 Intel i386.
i486 Intel i486.
i586, pentium Intel Pentium sin soporte de instrucciones MMX.
i686 Produce un código binario optimizado para la mayor parte de procesadores compatibles con la serie 80686 de Intel. Todos los actuales lo son.
intel Intel Haswell y Silvermont. Este valor sólo es aplicable en la opción '-mtune='. Esta opción está disponible a partir de GCC 4.9.
ivybridge Intel Ivy Bridge con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AVX, AES, PCLMUL, FSGSBASE, RDRND, F16C y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.9.
knl Intel Knights Landing con soporte de instrucciones MOVBE, MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AVX, AVX2, AES, PCLMUL, FSGSBASE, RDRND, FMA, BMI, BMI2, F16C, RDSEED, ADCX, PREFETCHW, AVX512F, AVX512PF, AVX512ER y extensiones 64-bit. Esta opción está disponible a partir de GCC 5.
lakemont Intel Quark Lakemont MCU, basado en el procesador Intel Pentium. Esta opción está disponible a partir de GCC 6.
nehalem Intel Nehalem con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.9.
nocona Versión mejorada de Intel Pentium4 con soporte de instrucciones MMX, SSE, SSE2, SSE3 y extensiones 64-bit.
pentiumpro Intel PentiumPro.
pentium2 Intel Pentium2 basado en PentiumPro con soporte de instrucciones MMX.
pentium3, pentium3m Intel Pentium3 basado en PentiumPro con soporte de instrucciones MMX y SSE.
pentium4, pentium4m Intel Pentium4 con soporte de instrucciones MMX, SSE y SSE2.
pentium-m Versión de bajo consumo de Intel Pentium3 con soporte de instrucciones MMX, SSE y SSE2. Utilizado por los portátiles Centrino.
pentium-mmx Intel PentiumMMX basado en Pentium con soporte de instrucciones MMX.
prescott Versión mejorada de Intel Pentium4 con soporte de instrucciones MMX, SSE, SSE2 y SSE3.
sandybridge Intel Sandy Bridge con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AVX, AES, PCLMUL y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.9.
silvermont Intel Silvermont con soporte de instrucciones MOVBE, MMX, SSE, MOVBE, MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AES, PCLMU, RDRND y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.9.
skylake Intel Skylake con soporte de instrucciones MOVBE, MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AVX, AVX2, AES, PCLMUL, FSGSBASE, RDRND, FMA, BMI, BMI2, F16C, RDSEED, ADCX, PREFETCHW, CLFLUSHOPT, XSAVEC, XSAVES y extensiones 64-bit. Esta opción está disponible a partir de GCC 6.
skylake-avx512 Intel Skylake Server con soporte de instrucciones MOVBE, MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AVX, AVX2, AES, PCLMUL, FSGSBASE, RDRND, FMA, BMI, BMI2, F16C, RDSEED, ADCX, PREFETCHW, CLFLUSHOPT, XSAVEC, XSAVES, AVX512F, AVX512VL, AVX512BW, AVX512DQ, AVX512CD y extensiones 64-bit. Esta opción está disponible a partir de GCC 6.
westmere Intel Westmere con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, POPCNT, AES, PCLMUL y extensiones 64-bit. Esta opción está disponible a partir de GCC 4.9.
AMD
amdfam10, barcelona Procesadores basados en AMD Family 10h core con soporte de instrucciones x86-64 (MMX, SSE, SSE2, SSE3, SSE4A, 3DNow!, enhanced 3DNow!, ABM y extensiones 64-bit). Esta opción está disponible a partir de GCC 4.3.
athlon, athlon-tbird AMD Athlon con soporte de instrucciones MMX, 3DNow!, enhanced 3DNow! y SSE prefetch.
athlon4, athlon-xp, athlon-mp Versiones mejoradas de AMD Athlon con soporte de instrucciones MMX, 3DNow!, enhanced 3DNow! y full SSE.
bdver1 Procesadores basados en AMD Family 15h core con soporte de instrucciones x86-64 (FMA4, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE, SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones 64-bit). Esta opción está disponible a partir de GCC 4.7.
bdver2 Procesadores basados en AMD Family 15h core con soporte de instrucciones x86-64 (BMI, TBM, F16C, FMA, LWP, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE, SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones 64-bit). Esta opción está disponible a partir de GCC 4.7.
bdver3 Procesadores basados en AMD Family 15h core con soporte de instrucciones x86-64 (FMA4, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE, SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones 64-bit). Esta opción está disponible a partir de GCC 4.8.
bdver4 Procesadores basados en AMD Family 15h core con soporte de instrucciones x86-64 (BMI, BMI2, TBM, F16C, FMA, FMA4, FSGSBASE, AVX, AVX2, XOP, LWP, AES, PCL_MUL, CX16, MOVBE, MMX, SSE, SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones 64-bit). Esta opción está disponible a partir de GCC 4.9.
btver1 Procesadores basados en AMD Family 14h core con soporte de instrucciones x86-64 (MMX, SSE, SSE2, SSE3, SSE4A, CX16, ABM y extensiones 64-bit). Esta opción está disponible a partir de GCC 4.6.
btver2 Procesadores basados en AMD Family 16h core con soporte de instrucciones x86-64 (MOVBE, F16C, BMI, AVX, PCL_MUL, AES, SSE4.2, SSE4.1, CX16, ABM, SSE4A, SSSE3, SSE3, SSE2, SSE, MMX y extensiones 64-bit). Esta opción está disponible a partir de GCC 4.8.
geode AMD integrado con soporte de instrucciones MMX y 3DNow!. Esta opción está disponible a partir de GCC 4.3.
k6 AMD K6 con soporte de instrucciones MMX.
k6-2, k6-3 Versiones mejoradas de AMD K6 con soporte de instrucciones MMX y 3DNow!.
k8, opteron, athlon64, athlon-fx Procesadores basados en AMD K8 core con soporte de instrucciones x86-64 (MMX, SSE, SSE2, 3DNow!, enhanced 3DNow! y extensiones 64-bit).
k8-sse3, opteron-sse3, athlon64-sse3 Versiones mejoradas de AMD K8 core con soporte de instrucciones SSE3. Esta opción está disponible a partir de GCC 4.3.
znver1 Procesadores basados en AMD Family 17h core con soporte de instrucciones x86-64 (BMI, BMI2, F16C, FMA, FSGSBASE, AVX, AVX2, ADCX, RDSEED, MWAITX, SHA, CLZERO, AES, PCL_MUL, CX16, MOVBE, MMX, SSE, SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM, XSAVEC, XSAVES, CLFLUSHOPT, POPCNT y extensiones 64-bit). Esta opción está disponible a partir de GCC 6.
VIA
c3 VIA C3 con soporte de instrucciones MMX y 3DNow! (no se implementa planificación para este chip).
c3-2 VIA C3-2 (Nehemiah/C5XL) con soporte de instrucciones MMX y SSE (no se implementa planificación para este chip).
c7 VIA C7 (Esther) con soporte de instrucciones MMX, SSE, SSE2 y SSE (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
eden-x2 VIA Eden X2 con soporte de instrucciones x86-64, MMX, SSE, SSE2 y SSE3 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
eden-x4 VIA Eden X4 con soporte de instrucciones MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, AVX y AVX2 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
esther VIA Eden Esther con soporte de instrucciones MMX, SSE, SSE2 y SSE3 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
nano VIA Nano genérico con soporte de instrucciones x86-64, MMX, SSE, SSE2, SSE3 y SSSE3 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
nano-1000 VIA Nano 1xxx con soporte de instrucciones x86-64, MMX, SSE, SSE2, SSE3 y SSSE3 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
nano-2000 VIA Nano 2xxx con soporte de instrucciones x86-64, MMX, SSE, SSE2, SSE3 y SSSE3 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
nano-3000 VIA Nano 3xxx con soporte de instrucciones x86-64, MMX, SSE, SSE2, SSE3, SSSE3 y SSE4.1 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
nano-x2 VIA Nano Dual Core con soporte de instrucciones x86-64, MMX, SSE, SSE2, SSE3 y SSSE3 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
nano-x4 VIA Nano Quad Core con soporte de instrucciones x86-64, MMX, SSE, SSE2, SSE3 y SSSE3 (no se implementa planificación para este chip). Esta opción está disponible a partir de GCC 7.
IDT
winchip2 IDT Winchip2, que equivale a un i486 con soporte de instrucciones MMX y 3DNow!.
winchip-c6 IDT Winchip C6, que equivale a un i486 con soporte de instrucciones MMX.

Optimizaciones adicionales

Optimizaciones adicionales
Graphite
$ export {C,CXX}FLAGS+=' -floop-interchange -ftree-loop-distribution -floop-strip-mine -floop-block'
LTO
$ export {C,CXX}FLAGS+=' -fuse-linker-plugin -flto=2'
Donde pone 2 se indica el número de núcleos de nuestro procesador, si sólo tiene uno, utilizar el parámetro -flto

Parámetros adicionales

Establecer el RPATH correspondiente si utilizamos una versión de GCC que no es la principal del sistema
$ export LDFLAGS="-Wl,-rpath,/opt/gcc7/lib -lstdc++"
Sustituir /opt/gcc7/lib por la ruta de instalación de la versión de GCC alternativa que se vaya a utilizar en el proceso de compilación de este paquete.

Extracción e Instalación como root de Google Test

Movit requiere de las cabeceras y partes del código fuente de Google Test, para poder compilar los tests del paquete. Extraeremos los directorios necesarios para esto en el lugar predefinido de ubicación utilizado por Movit.

$ su
# mkdir -p /usr/src/gtest
# tar zxvf googletest-release-1.8.0.tar.gz -C /usr/src/gtest \
googletest-release-1.8.0/googletest/{src,include/gtest} --strip-components=2

Extracción y Configuración  Bloc de Notas Información general sobre el uso de los comandos

$ tar zxvf movit-1.5.2.tar.gz
$ cd movit-1.5.2
$ ./configure --prefix=/usr --disable-static

Explicación de los comandos

--prefix=/usr : Instala la librería en el directorio principal /usr.

--disable-static
: Desactiva la compilación de la librería estática al no ser necesaria para la ejecución de los programas.

Compilación

$ make

Parámetros de compilación opcionales  

V=1 : Muestra más información en el proceso de compilación.

-j2
: Si tenemos un procesador de doble núcleo (dual-core), y el kernel está optimizado para el mismo y es SMP, con este parámetro aumentaremos el número de procesos de compilación simultáneos a un nivel de 2 y aceleraremos el tiempo de compilación del programa de forma considerable.
-j4 : Lo mismo que arriba pero con procesadores de 4 núcleos (quad-core).

Instalación como root

$ su
# make install
# chmod 755 /usr/lib/libmovit.so.7.0.0
# strip --strip-unneeded
/usr/lib/libmovit.so.7.0.0
# ldconfig -v

Estadísticas de Compilación e Instalación de Movit

Estadísticas de Compilación e Instalación de Movit
CPU AMD Athlon(tm) II X2 260 Processor
MHz 3214.610
RAM 2048 MB
Sistema de archivos XFS
Versión de Glibc 2.25
Enlazador dinámico GNU gold (Binutils 2.28) 1.14
Compilador GCC 7.1.0 + Ccache 3.3.4
Parámetros de optimización -03 -march=amdfam10 -mtune=amdfam10 -floop-interchange -ftree-loop-distribution -floop-strip-mine -floop-block -fuse-linker-plugin -flto=2
Parámetros de compilación V=1 -j2
Tiempo de compilación 3' 36"
Archivos instalados 90
Mostrar/Ocultar la lista de archivos instalados
Enlaces simbólicos creados 2
Mostrar/Ocultar la lista de enlaces simbólicos creados
Ocupación de espacio en disco 956 KB

Desinstalación como root

1) MODO TRADICIONAL

Este paquete no tiene soporte de desinstalación con el comando 'make uninstall'.

2) MODO MANUALINUX

El principal inconveniente del comando anterior es que tenemos que tener el directorio de compilación en nuestro sistema para poder desinstalar el programa. En algunos casos esto supone muchos megas de espacio en disco. Con el paquete de scripts que pongo a continuación logramos evitar el único inconveniente que tiene la compilación de programas, y es el tema de la desinstalación de los mismos sin la necesidad de tener obligatoriamente una copia de las fuentes compiladas.

movit-1.5.2-scripts.tar.gz

$ su
# tar zxvf movit-1.5.2-scripts.tar.gz
# cd movit-1.5.2-scripts
# ./Desinstalar_movit-1.5.2

Copia de Seguridad como root

Con este otro script creamos una copia de seguridad de los binarios compilados, recreando la estructura de directorios de los mismos en un directorio de copias de seguridad (copibin) que se crea en el directorio /var. Cuando se haya creado el paquete comprimido de los binarios podemos copiarlo como usuario a nuestro home y borrar el que ha creado el script de respaldo, teniendo en cuenta que si queremos volver a restaurar la copia, tendremos que volver a copiarlo al lugar donde se ha creado.

$ su
# tar zxvf movit-1.5.2-scripts.tar.gz
# cd movit-1.5.2-scripts
# ./Respaldar_movit-1.5.2

Restaurar la Copia de Seguridad como root

Y con este otro script (que se copia de forma automática cuando creamos la copia de respaldo del programa) restauramos la copia de seguridad como root cuando resulte necesario.

$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_movit-1.5.2



MLT  

Instalación

Dependencias

Herramientas de Compilación


Entre paréntesis la versión con la que se ha compilado MLT para la elaboración de este documento.

* GCC - (7.1.0)
* Swig - (3.0.12)
* Make - (4.2.1)
* Pkg-config - (0.29.2)

Librerías de Desarrollo

* Freir0r - (1.5)
* GLib - (2.52.3)
* GTK+ - (2.24.31)
* JACK - (0.125.0)
* Libavcodec - (56.60.100)
* Libavformat - (56.40.101)
* Libavutil - (54.31.100)
* Libexif - (0.6.21)
* Libjpeg - (9b)
* Libsamplerate - (0.1.9)
* Libswscale - (3.1.101)
* Libxml2 - (2.9.4)
* Movit - (1.5.2)
* Qt5 - (5.9.0)
* SDL - (1.2.15)
* SDL_image - (1.2.12)
* Sox - (14.4.2)
* Swfdec - (0.8.4)
* Vid.stab - (0.98b)



Descarga

mlt-6.4.1.tar.gz

Optimizaciones

Optimizaciones adicionales

Optimizaciones adicionales
Graphite
$ export {C,CXX}FLAGS+=' -floop-interchange -ftree-loop-distribution -floop-strip-mine -floop-block'

Parámetros adicionales

Establecer el RPATH correspondiente si utilizamos una versión de GCC que no es la principal del sistema
$ export LDFLAGS="-Wl,-rpath,/opt/gcc7/lib -lstdc++"
Sustituir /opt/gcc7/lib por la ruta de instalación de la versión de GCC alternativa que se vaya a utilizar en el proceso de compilación de este paquete.

Extracción y Configuración  Bloc de Notas Información general sobre el uso de los comandos

$ tar zxvf mlt-6.4.1.tar.gz
$ cd mlt-6.4.1
$ export PKG_CONFIG_PATH="/opt/ffmpeg-2.8/lib/pkgconfig:$PKG_CONFIG_PATH"
$ export LDFLAGS+=" -Wl,-rpath,/opt/ffmpeg-2.8/lib"
$ export PATH=$(pkg-config --variable=host_bins Qt5Core):$PATH
$ ./configure --enable-gpl3 --enable-gpl --qt-libdir=$(pkg-config --variable=libdir Qt5Core) \
--qt-includedir=$(pkg-config --variable=includedir Qt5Core) --swig-languages=python \
--prefix=/usr --linsys-with-jpeg
$ sed -i 's:-O2::' config.mak

Explicación de los comandos

export PKG_CONFIG_PATH="/opt/ffmpeg-2.8/lib/pkgconfig:$PKG_CONFIG_PATH" : Establecemos la variable de entorno correspondiente para que el programa pkg-config, detecte la versión de FFmpeg 2.8, cuya instalación se explica en el manual de FFmpeg, ya que MLT no es compatible con FFmpeg 3.x.

export LDFLAGS+=" -Wl,-rpath,/opt/ffmpeg-2.8/lib" : Le indicamos a ld que busque primero las librerías contra las que se tienen que enlazar los binarios de MLT, en /opt/ffmpeg-2.8/lib, para evitar que durante la instalación del programa, se enlacen contra las librerías de la otra versión de FFmpeg, que tengamos instalada en nuestro sistema.

export PATH=$(pkg-config --variable=host_bins Qt5Core):$PATH : Para evitar que el script de configuración, detecte los ejecutables de Qt4 (si lo tenemos instalado y existe una variable de entorno PATH configurada para Qt4), en lugar de los ejecutables de Qt5, establecemos una variable de entorno PATH, que coloca en primer lugar de búsqueda, el directorio bin de la instalación de Qt5.

--enable-gpl : Activa la compilación de los componentes del paquete publicados bajo la GPL2.
--enable-gpl3 : Activa la compilación de los componentes del paquete publicados bajo la GPL3.

--qt-libdir=$(pkg-config --variable=libdir Qt5Core) : Le indicamos la ruta correcta a las librerías de Qt5, en el caso de que hayamos compilado e instalado Qt5 en un directorio diferente al principal del sistema.

--qt-includedir=$(pkg-config --variable=includedir Qt5Core) : Le indicamos la ruta correcta a las cabeceras de Qt5, en el caso de que hayamos compilado e instalado Qt5 en un directorio diferente al principal del sistema.

--swig-languages=python : Activa el soporte de compilación de la adaptación de MLT para Python, requerido para poder ejecutar Flowblade.

--linsys-with-jpeg : Activa el soporte de exportación en formato JPEG en el módulo Linsys de MLT.

--disable-dependency-tracking : Acelera el tiempo de compilación.
--prefix=/usr : Instala el software en el directorio principal /usr.

-sed -i 's:-O2::' config.mak : Borramos la referencia existente en el archivo config.mak al nivel de optimización utilizado por defecto (-O2) para evitar una duplicidad de niveles de optimización aplicados en el proceso de compilación, y sea este último el aplicado por el compilador.

Parámetros de configuración opcionales

--avformat-vdpau : Activa el soporte de la aceleración de vídeo por hardware, VDPAU de NVIDIA, en el módulo Avformat de MLT. Los usuarios de Nouveau procurar no añadir esta opción, por la gran cantidad de problemas de bloqueo del sistema que se producen cuando hacemos uso de este tipo de aceleración.

Compilación

$ make

Parámetros de compilación opcionales

Instalación como root

$ su
# make install
# ldconfig -v

Instalación como root de la adaptación de MLT para Python

# cd src/swig/python
# install -dm755 /usr/lib/python2.7/site-packages/mlt
# install -m755 *.py *.so
/usr/lib/python2.7/site-packages/mlt
# echo mlt > /usr/lib/python2.7/site-packages/mlt.pth

Estadísticas de Compilación e Instalación de MLT

Estadísticas de Compilación e Instalación de MLT
CPU AMD Athlon(tm) II X2 260 Processor
MHz 3214.610
RAM 2048 MB
Sistema de archivos XFS
Versión de Glibc 2.25
Enlazador dinámico GNU gold (Binutils 2.28) 1.14
Compilador GCC 7.1.0 + Ccache 3.3.4
Parámetros de optimización -03 -march=amdfam10 -mtune=amdfam10 -floop-interchange -ftree-loop-distribution -floop-strip-mine -floop-block
Parámetros de compilación -j2
Tiempo de compilación 2' 36"
Archivos instalados 455
Mostrar/Ocultar la lista de archivos instalados
Enlaces simbólicos creados 4
Mostrar/Ocultar la lista de enlaces simbólicos creados
Ocupación de espacio en disco 48,3 MB

Desinstalación como root

1) MODO TRADICIONAL

En el directorio de compilación ejecutamos el siguiente comando:

$ su -c "make uninstall"

2) MODO MANUALINUX

mlt-6.4.1-scripts.tar.gz

$ su
# tar zxvf mlt-6.4.1-scripts.tar.gz
# cd mlt-6.4.1-scripts
# ./Desinstalar_mlt-6.4.1

Copia de Seguridad como root

$ su
# tar zxvf mlt-6.4.1-scripts.tar.gz
# cd mlt-6.4.1-scripts
# ./Respaldar_mlt-6.4.1

Restaurar la Copia de Seguridad como root

$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_mlt-6.4.1



WebVfx  

Instalación

Dependencias

Herramientas de Compilación


Entre paréntesis la versión con la que se ha compilado WebVfx para la elaboración de este documento.

* GCC - (7.1.0)
* Make - (4.2.1)
* Pkg-config - (0.29.2)

Librerías de Desarrollo

* MLT - (6.4.1)
* Qt5 - (5.9.0)
* QtWebKit - (5.9.0)



Descarga

webvfx-git-11072017.tar.xz

Firma Digital  Clave pública PGP

webvfx-git-11072017.tar.xz.asc

Verificar la firma digital del paquete

$ gpg --import manualinux.asc
$ gpg --verify webvfx-git-11072017.tar.xz.asc webvfx-git-11072017.tar.xz

Optimizaciones

Optimizaciones adicionales

Optimizaciones adicionales
Graphite
$ export {C,CXX}FLAGS+=' -floop-interchange -ftree-loop-distribution -floop-strip-mine -floop-block'

Parámetros adicionales

Establecer el RPATH correspondiente si utilizamos una versión de GCC que no es la principal del sistema
$ export LDFLAGS="-Wl,-rpath,/opt/gcc7/lib -lstdc++"
Sustituir /opt/gcc7/lib por la ruta de instalación de la versión de GCC alternativa que se vaya a utilizar en el proceso de compilación de este paquete.

Extracción y Configuración  Bloc de Notas Información general sobre el uso de los comandos

$ tar Jxvf webvfx-git-11072017.tar.xz
$ cd webvfx-git-11072017
$ qmake-qt5 QMAKE_CXXFLAGS_RELEASE="${CXXFLAGS}" QMAKE_LIBDIR_FLAGS="${LDFLAGS}" \
PREFIX=/usr MLT_SOURCE=$(echo $PWD | sed 's:web.*:mlt-6.4.1:')

Explicación de los comandos

CXXFLAGS_RELEASE="${CXXFLAGS}"
: Sincronizamos las variables de entorno de optimización establecidas en el manual con las equivalentes utilizadas por Qmake.

QMAKE_LIBDIR_FLAGS="${LDFLAGS}"
: Sincronizamos la variable de entorno LDFLAGS establecida en el manual, con la equivalente utilizada por Qmake.

PREFIX=/usr : Instala los binarios generados en el directorio principal, /usr.

MLT_SOURCE=$(echo $PWD | sed 's:web.*:mlt-6.4.1:') : Le indicamos la ruta al directorio del paquete de código fuente de MLT que hemos compilado antes, ya que WebVfx lo necesita para poder crear el binario ejecutable, qmelt. Como el comando de configuración no admite rutas relativas, con este comando de tubería establecemos la ruta a dicho directorio, dando por hecho que lo tenemos en el mismo directorio raíz que este paquete.

Compilación

$ make

Parámetros de compilación opcionales

Instalación como root

$ su
# make install
# ldconfig -v

Estadísticas de Compilación e Instalación de WebVfx

Estadísticas de Compilación e Instalación de WebVfx
CPU AMD Athlon(tm) II X2 260 Processor
MHz 3214.610
RAM 2048 MB
Sistema de archivos XFS
Versión de Glibc 2.25
Enlazador dinámico GNU gold (Binutils 2.28) 1.14
Compilador GCC 7.1.0 + Ccache 3.3.4
Parámetros de optimización -03 -march=amdfam10 -mtune=amdfam10 -floop-interchange -ftree-loop-distribution -floop-strip-mine -floop-block
Parámetros de compilación -j2
Tiempo de compilación 51"
Archivos instalados 6
Mostrar/Ocultar la lista de archivos instalados
Enlaces simbólicos creados 3
Mostrar/Ocultar la lista de enlaces simbólicos creados
Ocupación de espacio en disco 404 KB

Desinstalación como root

1) MODO TRADICIONAL

En el directorio de compilación ejecutamos el siguiente comando:

$ su -c "make uninstall"

2) MODO MANUALINUX

webvfx-git-11072017-scripts.tar.gz

$ su
# tar zxvf webvfx-git-11072017-scripts.tar.gz
# cd webvfx-git-11072017-scripts
# ./Desinstalar_webvfx-git-11072017

Copia de Seguridad como root

$ su
# tar zxvf webvfx-git-11072017-scripts.tar.gz
# cd webvfx-git-11072017-scripts
# ./Respaldar_webvfx-git-11072017

Restaurar la Copia de Seguridad como root

$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_webvfx-git-11072017



Flowblade

Instalación

Dependencias


Entre paréntesis la versión con la que se ha instalado Flowblade para la elaboración de este documento.

* D-Bus-Python - (1.2.4)
* MLT - (6.4.1)
* NumPy - (1.13.1)
* Pillow - (4.2.1)
* Py2cairo - (1.10.0)
* PyGobject - (3.24.1)
* Python - (2.7.13)

Aplicaciones

* G'MIC - (1.6.9)
* Convert (ImageMagick) - (7.0.6.0) [1]

[1] Requerido para poder crear los iconos en formato PNG que no proporciona el paquete.



Descarga

flowblade-1.12.2.tar.xz

Firma Digital  Clave pública PGP

flowblade-1.12.2.tar.xz.asc 

Verificar la firma digital del paquete

$ gpg --import manualinux.asc (sólo es necesario si no lo hemos hecho antes)
$ gpg --verify flowblade-1.12.2.tar.xz.asc flowblade-1.12.2.tar.xz

Extracción e Instalación como root  Bloc de Notas Información general sobre el uso de los comandos

$ tar Jxvf flowblade-1.12.2.tar.xz
$ cd flowblade-1.12.2
$ sed -i '38c\    modules_path = "/usr/lib/python2.7/site-packages/Flowblade"' flowblade
$ su
# python setup.py install
# update-mime-database /usr/share/mime &> /dev/null
# for i in /usr/share/icons/hicolor ; do \
install -dm755 $i/{16x16,24x24,32x32,64x64,128x128}/apps ; \
install -m644 installdata/flowblade.png $i/128x128/apps/flowblade.png ; \
convert -resize 64 installdata/flowblade.png $i/64x64/apps/flowblade.png ; \
convert -resize 48 installdata/flowblade.png $i/48x48/apps/flowblade.png ; \
convert -resize 32 installdata/flowblade.png $i/32x32/apps/flowblade.png ; \
convert -resize 24 installdata/flowblade.png $i/24x24/apps/flowblade.png ; \
convert -resize 16 installdata/flowblade.png $i/16x16/apps/flowblade.png ; \
gtk-update-icon-cache -tf $i &> /dev/null ; \
rm -f /usr/share/pixmaps/flowblade.png ; \
done


Explicación de los comandos

sed -i '38c\    modules_path = "/usr/lib/python-2.7/site-packages/Flowblade"' flowblade  : Cambiamos la ruta de instalación del programa del script de ejecución del mismo, ya que éste sólo está configurado para funcionar en Debian y derivados.

python setup.py install : Instalamos el programa en el directorio principal /usr

update-mime-database /usr/share/mime &> /dev/null : Actualizamos los tipos MIME del sistema para que incluyan el formato de archivo de proyecto (*.flb) proporcionado por Flowblade.

for i in /usr/share/icons/hicolor..... : Creamos e instalamos los iconos del programa, en sus diferentes medidas compatibles con el estándar de tamaño de icono de freedesktop.org.

Estadísticas de instalación de Flowblade

Estadísticas de Instalación de Flowblade
Sistema de archivos XFS
Archivos instalados 640
Mostrar/Ocultar la lista de archivos instalados
Ocupación de espacio en disco 20,0 MB

Consumo inicial de CPU y RAM de Flowblade

Consumo inicial de CPU y RAM de Flowblade
Proceso
CPU Memoria física
python 4 % 122,0 MB

Directorio de configuración personal

~/.flowblade Es el directorio de configuración personal de Flowblade en nuestro home.

Desinstalación como root

1) MODO TRADICIONAL

***********************

2) MODO MANUALINUX

flowblade-1.12.2-scripts.tar.gz

$ su
# tar zxvf flowblade-1.12.2-scripts.tar.gz
# cd flowblade-1.12.2-scripts
# ./Desinstalar_flowblade-1.12.2

Copia de Seguridad como root

$ su
# tar zxvf flowblade-1.12.2-scripts.tar.gz
# cd flowblade-1.12.2-scripts
# ./Respaldar_flowblade-1.12.2

Restaurar la Copia de Seguridad como root

$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_flowblade-1.12.2



Traducción al Español alternativa 

Descarga

Flowblade_es-ML0.run

Firma Digital  Clave pública PGP

Flowblade_es-ML0.run.asc 

Verificar la firma digital del paquete

$ gpg --import manualinux.asc (sólo es necesario si no lo hemos hecho antes)
$ gpg --verify Flowblade_es-ML0.run.asc Flowblade_es-ML0.run

Instalación como root

$ su -c "sh Flowblade_es-ML0.run"



Iniciamos Flowblade  

Sólo nos queda teclear en una terminal o en un lanzador el comando flowblade, y el programa aparecerá en la pantalla.


Captura - Flowblade - 1


Captura - Flowblade - 2


Captura - Flowblade - 3


Captura - Flowblade - 4




Enlaces  


http://www.mltframework.org >> La web de MLT.

https://github.com/jliljebl/flowblade >> La web de Flowblade.


Foro Galería Blog


Actualizado el 11-07-2017

Editores de Vídeo - Flowblade

Editores de Vídeo - CinelerraEditores de Vídeo - LiVES