TorchJS is a JS binding for PyTorch. Its primary objective is to allow running TorchScript inside Node.js program. Complete binding of libtorch is possible but is out-of-scope at the moment.
This fork is maintained by Techainer
-
Add support for
List
(JavascriptArray
),Dict
(JavascriptObject
),String
,float
(Javascriptnumber
) as inputs and outputs. -
Add CUDA support.
-
Add ops from torchvision.
-
Add async support for
forward
function. -
Add async support for
call_scripted_function(function_name, **inputs)
to call any method of the scripted module. -
Provide prebuild binary for cross NVIDIA GPU from Pascal to Ampere
-
Fixed some weird conversion arround
List[Tensor]
input. -
Updated
libtorch
to1.8.1
andtorchvision
to0.9.1
To install the forked version, you can install it from npm:
yarn add torch-js@npm:@techainer1t/torch-js
In tests/resources/torch_module.py
, you will find the defination of our test module and the code to generate the trace file.
class TestModule(torch.nn.Module):
def __init__(self):
super(TestModule, self).__init__()
def forward(self, input1, input2):
return input1 + input2
Once you have the trace file, it may be loaded into NodeJS like this
const torch = require("torch-js");
const modelPath = `test_model.pt`;
const model = new torch.ScriptModule(testModelPath);
const inputA = torch.rand([1, 5]);
const inputB = torch.rand([1, 5]);
const res = await model.forward(inputA, inputB);
More examples regarding tensor creation, ScriptModule operations, and loading models can be found in our examples folder.