Compré dos cpus nuevos E5-2650:
8c * 16t per core = 128 * 2 = 256 - max number of threads
pero parece que ffmpeg no usa la potencia máxima de la CPU aunque lo estoy ejecutando -threads 0
. Desde atop
puedo ver que ffmpeg usa solo 72 subprocesos.
PID RUID EUID THR SYSCPU USRCPU VGROW RGROW RDDSK WRDSK ST EXC S CPUNR CPU CMD 1/9
40919 root root 72 1.37s 20.09s 0K 0K 2688K 768K -- - S 7 1084% ffmpeg
información de la CPU:
vendor_id : GenuineIntel
cpu family : 6
model : 45
model name : Intel(R) Xeon(R) CPU E5-2650 0 @ 2.00GHz
stepping : 7
microcode : 0x70a
cpu MHz : 2001.000
cache size : 20480 KB
physical id : 1
siblings : 16
core id : 7
cpu cores : 8
apicid : 47
initial apicid : 47
fpu : yes
fpu_exception : yes
cpuid level : 13
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc aperfmperf pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm pcid dca sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx lahf_lm ida arat epb xsaveopt pln pts dtherm tpr_shadow vnmi flexpriority ept vpid
bogomips : 3990.40
clflush size : 64
cache_alignment : 64
address sizes : 46 bits physical, 48 bits virtual
power management:
Respuesta1
ElE5-2650Tiene 8 núcleos y puede procesar 2 subprocesos por código. Son 16 hilospor CPU. No 16 por núcleo.
Dos CPU tienen un total de 32 subprocesos. Suponiendo que el resto de la computadora sea lo suficientemente rápido como para seguir alimentando la CPU, entonces el uso óptimo sería cerca de 32 subprocesos. En la práctica esto no es cierto, siempre hay algún que otro retraso, ya sea al leer de la memoria, al leer o escribir en el disco o desde otro lugar. EntoncesóptimoEl uso no siempre es el mismo que el número máximo de subprocesos utilizables.
En su caso, probablemente se utilicen 72 subprocesos porque algunos comenzaron y luego tuvieron que esperar otros datos. Mientras tanto, otros hilos pueden continuar. Entonces, en realidad hay más subprocesos activos que se pueden calcular al mismo tiempo.