Bemutatjuk a DIET-et: a legmodernebb architektúra, amely felülmúlja a finomhangoló BERT-et és 6x gyorsabb a vonatozásban

A Rasánál örömmel várjuk, hogy az élvonalbeli gépi tanulási technológiák elérhetővé váljanak egy fejlesztőbarát munkafolyamatban. A Rasa 1.8 segítségével kutatócsoportunk új, korszerű könnyű, többfeladatos transzformátor architektúrát bocsát ki az NLU számára: kettős szándékú és entitás transzformátor (DIET).

diet

Ebben a bejegyzésben a DIET funkcióiról és arról, hogyan használhatja a Rasában, hogy nagyobb pontosságot érjen el, mint bármi, ami korábban volt. Kiadunk egy tudományos cikket, amely bemutatja, hogy ez az új architektúra javítja a jelenlegi fejlettséget, felülmúlja a BERT finomhangolását, és hatszor gyorsabb a képzés.

Mi az étrend

A DIET egy többfeladatos transzformátor architektúra, amely a szándék osztályozását és az entitásfelismerést egyaránt kezeli. Lehetőséget nyújt különféle előre betanított beágyazások csatlakoztatására és lejátszására, mint például a BERT, a GloVe, a ConveRT és így tovább. Kísérleteink során nincs egyetlen beágyazási készlet sem, amely következetesen a legjobb a különböző adatkészletek között. A moduláris architektúra ezért különösen fontos.

Miért érdemes használni a DIET-et?

A nagyméretű, előre kiképzett nyelvi modellek nem ideálisak azoknak a fejlesztőknek, akik beszélgető mesterséges intelligencia-alkalmazásokat építenek.

A DIET azért különbözik, mert:

  • Olyan moduláris architektúra, amely illeszkedik egy tipikus szoftverfejlesztési munkafolyamatba
  • Párhuzamba áll a nagyméretű, előre kiképzett nyelvi modellekkel a pontosság és a teljesítmény terén
  • Javul a technika jelenlegi állása szerint, és 6-szor gyorsabban edzhető

A nagyszabású, előre kiképzett nyelvi modellek ígéretes eredményeket mutattak olyan nyelvértési referenciaértékek terén, mint a GLUE és a SuperGLUE, és különösen jelentős előrelépéseket mutattak az egyéb előképzési módszerekhez, például a GloVe és a felügyelt megközelítésekhez képest. Mivel ezek a beágyazások nagyméretű természetes nyelvű szöveges korpuszokra vannak kiképezve, jól felszereltek a feladatok közötti általánosításra.

Tavaly segítettem egy help desk asszisztens felépítésében, amely automatizálta a beszélgetéseket és megismételhető informatikai folyamatokat. Integráltuk az asszisztenst a BERT-szel, mert abban az időben a BERT és más nagy nyelvű modellek csúcsteljesítményt értek el a különböző NLP feladatoknál. Noha segített néhány kérdés megoldásában, a BERT saját kihívásaival is szembenézett; nagyon lassú volt, és GPU-ra volt szüksége az edzéshez.

A nagyméretű modellek általában számításigényesek, időigényesek a képzéssel és gyakorlati kihívásokat jelentenek azoknak a szoftverfejlesztőknek, akik robusztus AI asszisztenseket akarnak felépíteni, amelyek gyorsan képezhetők és iterálhatók. Sőt, ha többnyelvű AI asszisztenseket épít, fontos a magas szintű teljesítmény elérése nagyszabású előképzés nélkül, mivel a legtöbb előre kiképzett modell angol nyelvű szövegre van kiképezve.

A DIET előtt a Rasa NLU csővezetéke egy zacskónyi szómodellt használt, ahol felhasználói üzenetenként egy funkcióvektor volt. Bár ez egy gyors, nehezen verhető alapállás, most már túllépünk rajta.

A DIET olyan szekvenciamodellt használ, amely figyelembe veszi a szórendet, ezáltal jobb teljesítményt nyújtva. Ez egy kompaktabb modell, plug-and-play, moduláris felépítéssel. Például a DIET segítségével megteheti mind a szándék osztályozását, mind az entitás kinyerését; egyetlen feladatot is végrehajthat, például beállíthatja úgy, hogy kikapcsolja a szándék osztályozást, és csak az entitás kinyerésére képezheti.

Ezenkívül a DIET nemcsak jelentősen gyorsabban képezhető, hanem párhuzamba áll a nagyméretű, előre kiképzett nyelvi modellekkel is a teljesítmény terén. Túlteljesíti a BERT finomhangolását és javítja a komplex NLU adatkészlet jelenlegi állását. A legkorszerűbb pontosság elérése már nem jelentheti a hatékonyság feláldozását.

Hogyan kell használni a DIET-et

A DIET előkészítése érdekében frissítettünk a Tensorflow 2.1-re. A TF 2 megkönnyíti a modellek felépítését és betanítását, valamint a problémák intuitív hibakeresését.

A szándék szerinti osztályozás és az entitás kibontása az új DIET architektúra használatával adja hozzá a DIETClassifier összetevőt az NLU csővezeték konfigurációs fájljához.

A rasa init meghívásakor létrehozott konfigurációs fájl: .

Vessünk egy pillantást a DietClassifierre és annak függőségeire. A DIET osztályozó a Featurizer két osztályától függ - sűrű Featurizer és ritka Featurizers. A jellemzés a felhasználói üzenetek numerikus vektorokká alakításának folyamata. A fő különbség a ritka és a sűrű jellemzők között az, hogy a ritka karakterek kompakt jellemző vektorokat tömörítenek, amelyek többnyire nulla értéket tartalmaznak egy memória-hatékony struktúrában. Ha többet szeretne megtudni a ritka funkciók használatáról, nézze meg ezt a bejegyzést.

A ConveRTFeaturizer egy példa egy sűrű jellemzőre, amely a ConveRT modellt használja. A LanguageModelFeaturizer egy másik példa egy sűrű jellemzőre, amely előre kiképzett nyelvi modellt használ, mint például a BERT.

A CountVectorsFeaturizer egy példa egy ritka jellemzőre. Beállítható szó vagy karakter n-gramm használatára. A LexicalSyntacticFeaturizer egy másik példa a ritka jellemzőkre. Funkciókat hoz létre az entitás kibontásához, egy csúszó ablak segítségével egy adott felhasználói üzenet minden tokenje fölött. A LexicalSyntacticFeaturizer összetevő konfigurálható a kibontandó lexikai és szintaktikai jellemzők típusának megadására.

A DIETClassifer finomhangolható különféle hiperparaméterekkel is. Például konfigurálhatja az ideghálózat architektúráját azáltal, hogy megadja a transzformátor méretét, a transzformátor rétegek számát, a használandó figyelő fejek számát és így tovább.

Ha Rasa 1.8-ra frissít, nézze meg az áttelepítési útmutatót. Mint mindig, mindenkit arra bátorítunk, hogy határozza meg saját csővezetékét azáltal, hogy felsorolja a használni kívánt összetevők nevét.

Következő lépések

Nagyon örülünk a DIET-nek, egy új, többfeladatos transzformátor-architektúrának, amelyet mi találtunk ki. Két okból adtuk ki: a teljesítő AI-asszisztensek építése nem mindig igényel nagyszabású, előre kiképzett nyelvi modelleket, és rugalmas, plug-and-play architektúrát szerettünk volna biztosítani a fejlesztők számára. A DIET előremozdítja a technika jelenlegi állását, felülmúlja a BERT finomhangolását, és hatszor gyorsabban edz.

Hamarosan kiadunk róla egy papírt. Addig nézzen meg további információkat a DIET-ről, és nézze meg ezt a videót a működéséről. Próbálja ki, és kérjük, ossza meg eredményeit a fórumban. Kövesse nyomon az új fejleményeket, ha követi Rasát a Twitteren.

A Rasa Blog: Gépi tanulás, nyílt forráskódú

Szerezd meg a legfrissebb Rasa-termékhíreket, kövesse az oktatóanyagokat, hogy megtanulják, hogyan készítsenek saját AI-csevegőrobotot, és ismerkedjenek meg az élvonalbeli AI-kutatással a Rasa Blogon.