Pixel Visual Core

Da Wikipedia, l'enciclopedia libera.
Vai alla navigazione Vai alla ricerca

Il Pixel Visual Core (PVC) è una serie di image processors System in Package (SiP) basato su ARM progettato da Google .[1] Il PVC è un'architettura multi-core a dominio specifico per Image, Vision e AI per i dispositivi mobili e in futuro per IoT.[2] È apparso per la prima volta nel Google Pixel 2 e 2 XL introdotto nel 19 Ottobre 2017. È usato anche nel Google Pixel 3 e 3 XL.

Google precedentemente usava le CPU Qualcomm Snapdragon, GPU, IPU, e DSP per gestire l'image processing dei loro dispositivi Google Nexus e Google Pixel. Con la crescente importanza delle tecniche di computational photography, Google ha sviluppato il Pixel Visual Core (PVC). Google afferma che il PVC usa meno potenza di quella usata da CPU e GPU mantenendo la completa programmabilità, diversamente dall'altro application-specific integrated circuit (ASIC), la Tensor Processing Unit (TPU). Infatti i dispositivi mobili classici hanno un image signal processor (ISP) che ha una funzione prefissata di image processing. Invece il PVC ha una funzionalità flessibile e programmabili, non limitata solo all'image processing.

Il PVC nel Google Pixel 2 e 2 XL è marcato come SR3HX X726C502.[3]

Il PVC nel Google Pixel 3 and 3 XL è marcato come SR3HX X739F030.[4]

Grazie al PVC, il Pixel 2 e il Pixel 3 hanno ottenuto un DxOMark mobile di 98[5] e 101.[6] L'ultimo ha ottenuto, a pari merito dell'iPhone XR[7], lo score DxoMark più alto per un telefono a singola fotocamera.

Il software del Pixel Visual Core

[modifica | modifica wikitesto]
Una rappresentazione DAG di kernel per i programmatori del PVC

Un tipico programma di image-processing del PVC è scritto in Halide. Halide è un linguaggio a specifico dominio che permette all'utente di disaccoppiare l'algoritmo dallo scheduling. In questo modo lo sviluppatore può scrivere codice ottimizzato per l'architettura su cui andrà ad eseguire il programma. Attualmente il PVC supporta solo un sottoinsieme del linguaggio, senza operazioni a virgola mobile (floating point) e con pattern di accessi alla memoria limitati.[8]

Pixel Visual Core ISA

[modifica | modifica wikitesto]

Il PVC due tipi Instruction Set Architecture (ISA): uno virtuale e uno fisico. Prima di tutto, il programma ad alto livello è compilato nel virtual ISA (vISA), ispirato da RISC-V ISA[2], che astrae completamente dalla generazione dell'architettura. Poi, il programma in vISA è compilato nel physical ISA (pISA), che è un ISA VLIW. Quest'ultimo passo considera i parametri dell'architettura specifica, come dimensione dell'array di PEs, dimensione dell STP etc., e esplica i trasferimenti di memoria. Il disaccoppiamento del vISA dal pISA rende il primo cross-architetturale e indipendente dalla generazione, mentre il pISA può essere compilato offline o tramite compilazione JIT[8]

L'architettura del Pixel Visual Core

[modifica | modifica wikitesto]
Un esempio di Pixel Visual Core con quattro IPUs

Il Pixel Visual Core è progettato per essere un'architettura multi-core scalabile e efficiente dal punto di vista energetico. Il core di un PVC è la Image Processing Unit (IPU), un'unità programmabile specifica per l'image processing.

Image Processing Unit (IPU)

[modifica | modifica wikitesto]

Il core IPU è composto da uno Stencil Processor (STP), un Line Buffer Pool (LBP) e una NoC. L'STP è principalmente dotato di un array 2-D SIMD di PEs che possono eseguire computazioni stencil, ovvero su una piccola regione di pixels. Sebbene sia simile agli array sistolici e computazioni di tipo wavefront, l'STP ha un trasferimento dati controllato via software.[2]

Line Buffer Pool (LBP)

[modifica | modifica wikitesto]

Dal momento che una delle operazioni più costose dal punto di vista energetico è l'accesso a DRAM, ogni STP ha dei buffer temporanei per aumentare la località dei dati, ovvero i LBP. Il LBP è una coda FIFO 2-D che permette dimensioni diverse in scrittura e lettura. Il LBP ha un modello single-producer multi-consumer. Ciascun LBP può avere otto LB logici e uno per operazioni di input-output DMA.[8] A causa dell'alta complessità del sistema di memoria, i progettatori del PVC affermano che il controllore del LBP è stato uno dei componenti più difficili da progettare.[2] La NoC ha una topologia ad anello e viene usata solo per comunicare con i core vicini per preservare la natura computazionale per costi energetici.[2]

Stencil Processor (STP)

[modifica | modifica wikitesto]
Una rappresentazione dell'array 2-D di PEs, le PE bianche sono quelle full (16x16), quelle grigie sono dette "halo" (144). Non sono state riportate tutte le connessioni per chiarezza dell'immagine

L'STP ha un array di PEs 2-D, ad esempio 16x16 di full PEs e quattro lane di PEs semplificate dette "halo". L'STP ha un normale processore scalare, detto scalar lane (SCL), che aggiunge le istruzioni di controllo e una piccola memoria istruzioni. L'ultimo componente dell'STP è un'unità di load-store chiamata Sheet Generator (SHG), dove lo "sheet" è un'unità di accesso a memoria del PVC.[2]

Sommario di progettazione dello SR3HX

[modifica | modifica wikitesto]

Il SR3HX PVC ha una CPU ARMv8a ARM Cortex-A53 a 64-bit, 8 core Image Processing Unit (IPU), 512 MB LPDDR4, MIPI, PCIe. I core IPU hanno ciascuno 512 Arithmetic Logic Units (ALUs) di 256 processing elements (PEs) organizzate come un array 16 x 16 2-D con un ISA VLIW personalizzato. Ci sono 2 ALUs a 16-bit per PE che possono operare in tre modalità distinte: indipendenti, combinate, fuse.[9] Il SR3HX PVC è fabbricato come SiP da TSMC usando la loro tecnologia a 28HPM HKMG.[1] È stato progettato per 4 anni in collaborazione con Intel (nome in codice: Monette Hill).[10] Google sostiene che il SR3HX PVC è da 7 a 16x più efficiente dal punto di vista energetico di uno Snapdragon 835[1] e che può eseguire tre miliardi di operazioni al secondo, l'HDR+ può andare 5x più veloce richiedendo meno di un ventesimo di energia dello Snapdragon 835.[11]Supporta Halide per l'image processing e TensorFlow per il machine learning.[11]. Il chip attuale va a 426 MHz[2] e la singola IPU può eseguire più di 1 TeraOPS.[8]

  1. ^ a b c Ian Cutress, Hot Chips 2018: The Google Pixel Visual Core Live Blog (10am PT, 5pm UTC), su anandtech.com. URL consultato il 2 febbraio 2019.
  2. ^ a b c d e f g John Hennessy e David Patterson, Computer architecture : a quantitative approach, Sixthition, Morgan Kaufmann, 2019, ISBN 978-0-12-811905-1.
  3. ^ (EN) Google Pixel 2 XL Teardown, su iFixit, 19 ottobre 2017. URL consultato il 2 febbraio 2019.
  4. ^ (EN) Google Pixel 3 XL Teardown, su iFixit, 16 ottobre 2018. URL consultato il 2 febbraio 2019.
  5. ^ Pixel 2 DxOMark, su dxomark.com.
  6. ^ Pixel 3 DxOMark, su dxomark.com.
  7. ^ iPhone XR DxOMark, su dxomark.com.
  8. ^ a b c d The Pixel Visual Core: Google’s Fully Programmable Image, Vision and AI Processor for Mobile Devices. HotChips2018 (PDF), su hotchips.org. URL consultato il 4 luglio 2019 (archiviato dall'url originale il 2 luglio 2019).
  9. ^ (EN) Pixel Visual Core (PVC) - Google - WikiChip, su en.wikichip.org. URL consultato il 2 febbraio 2019.
  10. ^ (EN) Google Partnered with Intel for the Pixel Visual Core Chip in the Pixel 2, su xda-developers, 25 ottobre 2017. URL consultato il 2 febbraio 2019.
  11. ^ a b (EN) Pixel Visual Core: image processing and machine learning on Pixel 2, su Google, 17 ottobre 2017. URL consultato il 2 febbraio 2019.

Voci correlate

[modifica | modifica wikitesto]

Altri progetti

[modifica | modifica wikitesto]