Getting Started with TensorFlow.js in JavaScript

Samrat Kumar Das
3 min readAug 12, 2023

--

TensorFlow.js is a powerful library that enables you to build and train machine learning models directly in the browser or on Node.js using JavaScript. It empowers developers to create machine learning applications without requiring expertise in other programming languages. In this blog, we’ll guide you through the basics of using TensorFlow.js in JavaScript to build and deploy machine learning models.

What is TensorFlow.js?

TensorFlow.js is an open-source library developed by Google that brings the capabilities of TensorFlow to JavaScript. It allows you to build and train machine learning models using high-level APIs similar to the ones in TensorFlow, making it a great choice for both beginners and experienced developers.

Setting Up TensorFlow.js

To get started, you’ll need to include the TensorFlow.js library in your project. You can do this by including the following script tag in your HTML file:

<script src=”https://cdn.jsdelivr.net/npm/@tensorflow/tfjs"></script>

Alternatively, if you’re using Node.js, you can install TensorFlow.js using npm:

npm install @tensorflow/tfjs

Creating and Training a Model

Let’s walk through the process of creating a simple machine learning model using TensorFlow.js. In this example, we’ll create a basic neural network to classify handwritten digits from the MNIST dataset.

1. Loading Data:

First, you need to load the training and testing data. TensorFlow.js provides utilities to load datasets like MNIST.

2. Preprocessing Data:

Prepare the data for training. Typically, this involves normalizing the pixel values of the images to a range between 0 and 1.

3. Building the Model:

Define your model architecture. For this example, let’s use a simple neural network with a few layers.

const model = tf.sequential();
model.add(tf.layers.flatten({ inputShape: [28, 28, 1] }));
model.add(tf.layers.dense({ units: 128, activation: ‘relu’ }));
model.add(tf.layers.dense({ units: 10, activation: ‘softmax’ }));

4. Compiling the Model:

Specify the optimizer, loss function, and metrics for the model.

model.compile({
optimizer: tf.train.adam(),
loss: ‘categoricalCrossentropy’,
metrics: [‘accuracy’]
});

5. Training the Model:

Train the model using the prepared data.

const batchSize = 64;
const epochs = 10;

async function trainModel() {
await model.fit(trainingData, trainingLabels, {
batchSize,
epochs,
validationData: [testingData, testingLabels],
shuffle: true
});
console.log(‘Training complete’);
}

trainModel();

6. Making Predictions:

After training, you can use the model to make predictions.

const predictions = model.predict(someInputData);

Using Pretrained Models

TensorFlow.js also provides pre-trained models that you can use for various tasks, such as image classification, object detection, and more. You can import these models and use them to perform inference in your JavaScript code.

async function loadAndUsePretrainedModel() {
const model = await tf.loadGraphModel(‘model-url/model.json’);
const inputData = tf.tensor(/* your input data */);
const predictions = model.execute(inputData);
predictions.print();
}

loadAndUsePretrainedModel();

Deploying Models

Once you have trained and fine-tuned your model, you can deploy it to the web by saving it in a format that can be loaded by TensorFlow.js. This typically involves saving the model architecture and weights.

Saving the model:

const saveResults = await model.save(‘localstorage://my-model’);

Loading the model

const loadedModel = await tf.loadLayersModel(‘localstorage://my-model/model.json’);

Conclusion

TensorFlow.js opens up exciting possibilities for bringing machine learning to the browser and Node.js applications. From training custom models to using pre-trained ones, TensorFlow.js provides a comprehensive set of tools for developers to harness the power of machine learning in JavaScript. As you continue your journey, be sure to explore the extensive documentation and examples provided by TensorFlow.js to build even more advanced and impactful applications. Happy coding!

--

--

Samrat Kumar Das
Samrat Kumar Das

Written by Samrat Kumar Das

" Is there anything that we cannot achieve ? "

No responses yet