Date: Sun, 16 Dec 2018 22:00:00 -0500
<h3>Summary</h3> <p>Using computers to analyze text can produce useful and inspirational insights. However, when working with multiple languages the capabilities of existing models are severely limited. In order to help overcome this limitation Rami Al-Rfou built Polyglot. In this episode he explains his motivation for creating a natural language processing library with support for a vast array of languages, how it works, and how you can start using it for your own projects. He also discusses current research on multi-lingual text analytics, how he plans to improve Polyglot in the future, and how it fits in the Python ecosystem.</p> <h3>Preface</h3> <ul> <li>Hello and welcome to Podcast.__init__, the podcast about Python and the people who make it great.</li> <li>When you’re ready to launch your next app or want to try a project you hear about on the show, you’ll need somewhere to deploy it, so check out Linode. With 200 Gbit/s private networking, scalable shared block storage, node balancers, and a 40 Gbit/s public network, all controlled by a brand new API you’ve got everything you need to scale up. Go to <a href="https://www.pythonpodcast.com/linode?utm_source=rss&utm_medium=rss">pythonpodcast.com/linode</a> to get a $20 credit and launch a new server in under a minute.</li> <li>And to keep track of how your team is progressing on building new features and squashing bugs, you need a project management system designed by software engineers, for software engineers. Clubhouse lets you craft a workflow that fits your style, including per-team tasks, cross-project epics, a large suite of pre-built integrations, and a simple API for crafting your own. Podcast.__init__ listeners get 2 months free on any plan by going to <a href="https://www.pythonpodcast.com/clubhouse?utm_source=rss&utm_medium=rss">pythonpodcast.com/clubhouse</a> today and signing up for a trial.</li> <li>Visit the <a href="https://www.pythonpodcast.com?utm_source=rss&utm_medium=rss">site</a> to subscribe to the show, sign up for the newsletter, and read the show notes. And if you have any questions, comments, or suggestions I would love to hear them. You can reach me on Twitter at <a href="https://twtiter.com/Podcast__init__?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">@Podcast__init__</a> or email <a href="mailto:hosts@podcastinit.com">hosts@podcastinit.com</a>)</li> <li>To help other people find the show please leave a review on <a href="https://itunes.apple.com/us/podcast/podcast.-init/id981834425?mt=2&uo=6&at=&ct=&utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">iTunes</a>, or <a href="https://play.google.com/music/m/I7ogju4xv6adasgqz6545jndgsy?t=Podcastinit_-_Python_and_the_people_who_make_it_great&utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Google Play Music</a>, tell your friends and co-workers, and share it on social media.</li> <li>Join the community in the new Zulip chat workspace at <a href="https://www.pythonpodcast.com/chat?utm_source=rss&utm_medium=rss">pythonpodcast.com/chat</a></li> <li>Your host as usual is Tobias Macey and today I’m interviewing Rami Al-Rfou about Polyglot, a natural language pipeline with support for an impressive amount of languages</li> </ul> <h3>Interview</h3> <ul> <li>Introductions</li> <li>How did you get introduced to Python?</li> <li>Can you start by describing what Polyglot is and your reasons for starting the project?</li> <li>What are the types of use cases that Polyglot enables which would be impractical with something such as NLTK or SpaCy?</li> <li>A majority of NLP libraries have a limited set of languages that they support. What is involved in adding support for a given language to a natural language tool? <ul> <li>What is involved in adding a new language to Polyglot?</li> <li>Which families of languages are the most challenging to support?</li> </ul> </li> <li>What types of operations are supported and how consistently are they supported across languages?</li> <li>How is Polyglot implemented?</li> <li>Is there any capacity for integrating Polyglot with other tools such as SpaCy or Gensim?</li> <li>How much domain knowledge is required to be able to effectively use Polyglot within an application?</li> <li>What are some of the most interesting or unique uses of Polyglot that you have seen?</li> <li>What have been some of the most complex or challenging aspects of building Polyglot?</li> <li>What do you have planned for the future of Polyglot?</li> <li>What are some areas of NLP research that you are excited for?</li> </ul> <h3>Keep In Touch</h3> <h3>Picks</h3> <ul> <li>Tobias <ul> <li><a href="https://www.duolingo.com/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Duolingo</a></li> </ul> </li> <li>Rami <ul> <li><a href="https://www.penguinrandomhouse.com/books/220698/the-wizard-and-the-prophet-by-charles-c-mann/9780307961693/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">The Wizard and the Prophet</a>: Two Remarkable Scientists and Their Dueling Visions to Shape Tomorrow’s World by Charles C. Mann</li> </ul> </li> </ul> <h3>Links</h3> <ul> <li><a href="https://polyglot.readthedocs.io/en/latest/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Polyglot</a></li> <li><a href="https://sites.google.com/site/rmyeid/projects/polylgot-ner?authuser=0&utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Polyglot-NER</a></li> <li><a href="https://en.wikipedia.org/wiki/Jordan?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Jordan</a></li> <li><a href="https://en.wikipedia.org/wiki/Natural_language_processing?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">NLP (Natural Language Processing)</a></li> <li><a href="https://www.stonybrook.edu/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Stony Brook University</a></li> <li><a href="https://en.wikipedia.org/wiki/Arabic?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Arabic</a></li> <li><a href="https://en.wikipedia.org/wiki/Sentiment_analysis?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Sentiment Analysis</a></li> <li><a href="https://en.wikipedia.org/wiki/Assembly_language?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Assembly Language</a></li> <li><a href="https://en.wikipedia.org/wiki/C_(programming_language)?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">C</a></li> <li><a href="https://dotnet.microsoft.com/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">.NET</a></li> <li><a href="https://stackoverflow.com/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Stack Overflow</a></li> <li><a href="https://en.wikipedia.org/wiki/Deep_learning?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Deep Learning</a></li> <li><a href="https://en.wikipedia.org/wiki/Word_embedding?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Word Embedding</a></li> <li><a href="https://www.wikipedia.org/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Wikipedia</a></li> <li><a href="https://en.wikipedia.org/wiki/Word2vec?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Word2Vec</a></li> <li><a href="https://www.nltk.org/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">NLTK (Python Natural Language Toolkit)</a></li> <li><a href="https://spacy.io/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">SpaCy</a> <ul> <li><a href="https://www.pythonpodcast.com/episode-87-spacy-with-matthew-honnibal/?utm_source=rss&utm_medium=rss">Podcast Episode</a></li> </ul> </li> <li><a href="https://radimrehurek.com/gensim/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Gensim</a> <ul> <li><a href="https://www.pythonpodcast.com/episode-71-gensim-with-radim-rehurek/?utm_source=rss&utm_medium=rss">Podcast Episode</a></li> </ul> </li> <li><a href="https://en.wikipedia.org/wiki/Morphology_(linguistics)?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Morphology</a></li> <li><a href="https://en.wikipedia.org/wiki/Morpheme?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Morpheme</a></li> <li><a href="https://en.wikipedia.org/wiki/Transfer_learning?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Transfer Learning</a></li> <li><a href="https://readthedocs.org/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Read The Docs</a></li> <li><a href="https://github.com/google-research/bert?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">BERT (Bidirectional Encoder Representations from Transformers)</a></li> <li><a href="https://github.com/facebookresearch/fastText?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">FastText</a></li> <li><a href="https://data.world/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">data.world</a> <ul> <li><a href="https://www.dataengineeringpodcast.com/data-dot-world-with-bryon-jacob-episode-9/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Data Engineering Podcast Episode</a></li> </ul> </li> <li><a href="https://quiltdata.com/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Quilt</a> package management for data <ul> <li><a href="https://www.dataengineeringpodcast.com/quilt-data-with-kevin-moore-episode-37/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">Data Engineering Podcast Episode</a></li> </ul> </li> </ul> <p>The intro and outro music is from Requiem for a Fish <a href="http://freemusicarchive.org/music/The_Freak_Fandango_Orchestra/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">The Freak Fandango Orchestra</a> / <a href="http://creativecommons.org/licenses/by-sa/3.0/?utm_source=rss&utm_medium=rss" rel="noopener" target="_blank">CC BY-SA</a><img alt="" height="0" src="https://analytics.boundlessnotions.com/piwik.php?idsite=1&rec=1&url=https%3A%2F%2Fwww.pythonpodcast.com%2Fpolyglot-with-rami-al-rfou-episode-190%2F&action_name=Polyglot%3A+Multi-Lingual+Natural+Language+Processing+with+Rami+Al-Rfou+-+Episode+190&urlref=https%3A%2F%2Fwww.pythonpodcast.com%2Ffeed%2F&utm_source=rss&utm_medium=rss" style="border: 0; width: 0; height: 0;" width="0" /></p>