Book Image

Machine Learning with Go Quick Start Guide

By : Michael Bironneau, Toby Coleman
Book Image

Machine Learning with Go Quick Start Guide

By: Michael Bironneau, Toby Coleman

Overview of this book

Machine learning is an essential part of today's data-driven world and is extensively used across industries, including financial forecasting, robotics, and web technology. This book will teach you how to efficiently develop machine learning applications in Go. The book starts with an introduction to machine learning and its development process, explaining the types of problems that it aims to solve and the solutions it offers. It then covers setting up a frictionless Go development environment, including running Go interactively with Jupyter notebooks. Finally, common data processing techniques are introduced. The book then teaches the reader about supervised and unsupervised learning techniques through worked examples that include the implementation of evaluation metrics. These worked examples make use of the prominent open-source libraries GoML and Gonum. The book also teaches readers how to load a pre-trained model and use it to make predictions. It then moves on to the operational side of running machine learning applications: deployment, Continuous Integration, and helpful advice for effective logging and monitoring. At the end of the book, readers will learn how to set up a machine learning project for success, formulating realistic success criteria and accurately translating business requirements into technical ones.
Table of Contents (9 chapters)

Clustering

Clustering algorithms are designed to split a dataset up into groups. Once trained, any new data can be assigned to a group when it arrives. Suppose you are working with a dataset of customer information for an e-commerce store. You might use clustering to identify groups of customers, for example, business/private customers. This information can then be used to make decisions about how to best serve those customer types.

You might also use clustering as a preparatory step before applying supervised learning. For example, a dataset of images may require manual labeling, which is often time-consuming and costly. If you can segment the dataset into groups with a clustering algorithm, then you may be able to save time by only labeling a fraction of the images, and then assuming that each cluster contains images with the same label.

Clustering has also been applied to computer...