Skip to main content

pytorch❤️keras

Project description

Pytorch❤️Keras

The torchkeras library is a simple tool for training neural network in pytorch jusk in a keras style. 😋😋

1, Introduction

With torchkeras, You need not to write your training loop with many lines of code, all you need to do is just

like these two steps as below:

(i) create your network and wrap it and the loss_fn together with torchkeras.KerasModel like this: model = torchkeras.KerasModel(net,loss_fn=nn.BCEWithLogitsLoss()) a metrics_dict parameter is optional.

(ii) fit your model with the training data and validate data.

The main code of use torchkeras is like below.

import torch 
import torchkeras

#use torchkeras.KerasModel 
model = torchkeras.KerasModel(net,
                              loss_fn = nn.BCEWithLogitsLoss(),
                              optimizer= torch.optim.Adam(net.parameters(),lr = 0.03),
                              metrics_dict = {"acc":torchmetrics.metrics.Accuracy()}
                             )
dfhistory=model.fit(epochs=30, train_data=dl_train, 
                    val_data=dl_val, patience=3, 
                    monitor="val_acc",mode="max",
                    ckpt_path='checkpoint.pt')

This project seems somehow powerful, but the source code is very simple.

Actually, less than 200 lines of Python code.

If you want to understand or modify some details of this project, feel free to read and change the source code!!!


2, Features

Besides the basic torchkeras.KerasModel, another much more powerful class torchkeras.LightModel is created to support many other features.

The KerasModel is much simpler, and is recommended for beginner users.

The LightModel borrows many features from the library pytorch_lightning and shows a best practice.

Although different, the usage of torchkeras.KerasModel and torchkeras.LightModel is very similar.

features torchkeras.KerasModel torchkeras.LightModel
progress bar
early stopping
metrics from torchmetrics
gpu training
mac m1 training
multi-gpus training
tensorboard callback
simple source code

3, Basic Examples

You can follow these full examples to get started with torchkeras.

Have fun!😋😋

If you want to understand or modify some details of this project, feel free to read and change the source code!!!

Any other questions, you can contact the author form the wechat official account below:

算法美食屋

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

torchkeras-3.3.1.tar.gz (15.9 kB view details)

Uploaded Source

Built Distribution

torchkeras-3.3.1-py3-none-any.whl (16.6 kB view details)

Uploaded Python 3

File details

Details for the file torchkeras-3.3.1.tar.gz.

File metadata

  • Download URL: torchkeras-3.3.1.tar.gz
  • Upload date:
  • Size: 15.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.0

File hashes

Hashes for torchkeras-3.3.1.tar.gz
Algorithm Hash digest
SHA256 4d5344cb53e07f93707b9339e980ea467b42aa264a9d43f6b8cfb3ce5f1a5663
MD5 bcc3e8330dc30e499cc7244990844221
BLAKE2b-256 fac5267fa781b0cf216b9aeabc4d88db9cd75c80c4a22dec488192c10b3eb654

See more details on using hashes here.

File details

Details for the file torchkeras-3.3.1-py3-none-any.whl.

File metadata

  • Download URL: torchkeras-3.3.1-py3-none-any.whl
  • Upload date:
  • Size: 16.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.0

File hashes

Hashes for torchkeras-3.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 02281f65da630e4d9b27ccdd0ce209659dab3c8405168f501025da5f839a80b6
MD5 5b7ea2611cba053398ebcd56547ffdba
BLAKE2b-256 2608599676912581155872953ebbe94a84e77975ecf79f96df2e5779d72557db

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page