Skip to main content

Value networks

Project description

Value network (wip)

Exploration into some new research surrounding value networks

Install

$ pip install value-network

Usage

First, organize your videos (trajectories). The videos should have a suffix .1 for success and .0 for failure.

.
├── data
│   ├── traj_0.1.mp4
│   ├── traj_1.0.mp4
│   └── traj_2.1.mp4
└── ...

1. Train

Train the SigLIP value network by passing the folder containing the videos. The tool will automatically handle the conversion.

$ value-network-cli train --trajectories-folder ./data --max-steps 1000 --model_output_path ./model.pt

You can also opt to use the HL-Gauss loss, which has been shown to be more scalable for value learning.

$ value-network-cli train --trajectories-folder ./data --loss-module hlgauss --hl-gauss-min -2 --hl-gauss-max 2 --hl-gauss-num-bins 100

2. Predict

Use the trained model to predict the value of any image

$ value-network-cli predict ./model.pt ./frame.png

If you trained with HL-Gauss or Beta-NLL, you must specify the loss module and any non-default parameters during prediction as well.

$ value-network-cli predict ./model.pt ./frame.png --loss-module hlgauss --hl-gauss-num-bins 100
$ value-network-cli predict ./model.pt ./frame.png --loss-module beta-nll --beta 0.5

3. Visualize

To visualize the predicted values over a video, you can use the visualize command. First, generate the .npy file using predict on a video, then run visualize.

$ value-network-cli predict ./model.pt ./video.mp4 --output-path ./values.npy
$ value-network-cli visualize ./video.mp4 ./values.npy

4. Python

Programmatic usage is also straightforward.

import torch
from value_network import SigLIPValueNetwork

# forward

model = SigLIPValueNetwork.init_and_load('./model.pt')

images = torch.randn(3, 3, 224, 224)
value = model(images)

assert value.shape == (3,)

5. Research

Researchers are invited to explore custom loss modules by using the register_loss_module helper.

from torch.nn import Module
import torch.nn.functional as F

from value_network import SigLIPValueNetwork, register_loss_module

class HuberLoss(Module):
    def __init__(self, dim):
        super().__init__()
        self.to_value = nn.Linear(dim, 1)

    def forward(self, x, target = None):
        value = self.to_value(x).squeeze(-1)
        if target is None: return value
        return F.huber_loss(value, target)

register_loss_module('huber', HuberLoss)

model = SigLIPValueNetwork(loss_module_name = 'huber', ...)

Citations

@inproceedings{Imani2018ImprovingRP,
    title   = {Improving Regression Performance with Distributional Losses},
    author  = {Ehsan Imani and Martha White},
    booktitle = {International Conference on Machine Learning},
    year    = {2018},
    url     = {https://api.semanticscholar.org/CorpusID:48365278}
}
@article{Farebrother2024StopRT,
    title   = {Stop Regressing: Training Value Functions via Classification for Scalable Deep RL},
    author  = {Jesse Farebrother and Jordi Orbay and Quan Ho Vuong and Adrien Ali Taiga and Yevgen Chebotar and Ted Xiao and Alex Irpan and Sergey Levine and Pablo Samuel Castro and Aleksandra Faust and Aviral Kumar and Rishabh Agarwal},
    journal = {ArXiv},
    year   = {2024},
    volume = {abs/2403.03950},
    url    = {https://api.semanticscholar.org/CorpusID:268253088}
}
@misc{lee2025banelexplorationposteriorsgenerative,
    title    = {BaNEL: Exploration Posteriors for Generative Modeling Using Only Negative Rewards}, 
    author   = {Sangyun Lee and Brandon Amos and Giulia Fanti},
    year     = {2025},
    eprint   = {2510.09596},
    archivePrefix = {arXiv},
    primaryClass = {cs.LG},
    url      = {https://arxiv.org/abs/2510.09596}, 
}
@misc{ma2024visionlanguagemodelsincontext,
    title   = {Vision Language Models are In-Context Value Learners}, 
    author  = {Yecheng Jason Ma and Joey Hejna and Ayzaan Wahid and Chuyuan Fu and Dhruv Shah and Jacky Liang and Zhuo Xu and Sean Kirmani and Peng Xu and Danny Driess and Ted Xiao and Jonathan Tompson and Osbert Bastani and Dinesh Jayaraman and Wenhao Yu and Tingnan Zhang and Dorsa Sadigh and Fei Xia},
    year    = {2024},
    eprint  = {2411.04549},
    archivePrefix = {arXiv},
    primaryClass = {cs.RO},
    url     = {https://arxiv.org/abs/2411.04549}, 
}
@misc{yang2026riseselfimprovingrobotpolicy,
    title   = {RISE: Self-Improving Robot Policy with Compositional World Model}, 
    author  = {Jiazhi Yang and Kunyang Lin and Jinwei Li and Wencong Zhang and Tianwei Lin and Longyan Wu and Zhizhong Su and Hao Zhao and Ya-Qin Zhang and Li Chen and Ping Luo and Xiangyu Yue and Hongyang Li},
    year    = {2026},
    eprint  = {2602.11075},
    archivePrefix = {arXiv},
    primaryClass = {cs.RO},
    url     = {https://arxiv.org/abs/2602.11075}, 
}
@misc{hafner2024masteringdiversedomainsworld,
    title   = {Mastering Diverse Domains through World Models}, 
    author  = {Danijar Hafner and Jurgis Pasukonis and Jimmy Ba and Timothy Lillicrap},
    year    = {2024},
    eprint  = {2301.04104},
    archivePrefix = {arXiv},
    primaryClass = {cs.AI},
    url     = {https://arxiv.org/abs/2301.04104}, 
}
@inproceedings{Seitzer2022Pitfalls,
    title   = {On the Pitfalls of Heteroscedastic Uncertainty Estimation with Probabilistic Neural Networks},
    author  = {Maximilian Seitzer and Abdul-Saboor Sheikh and Georg Martius},
    booktitle = {International Conference on Learning Representations},
    year    = {2022},
    url     = {https://openreview.net/forum?id=9O_xF9y7A-}
}

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

value_network-0.0.42.tar.gz (115.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

value_network-0.0.42-py3-none-any.whl (118.9 kB view details)

Uploaded Python 3

File details

Details for the file value_network-0.0.42.tar.gz.

File metadata

  • Download URL: value_network-0.0.42.tar.gz
  • Upload date:
  • Size: 115.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.17

File hashes

Hashes for value_network-0.0.42.tar.gz
Algorithm Hash digest
SHA256 d853951e858068a51c4fcef999c301dd27782ecb30f859da729f1d70da2a13ca
MD5 9587908b511e3d69b9c285fe3cc8f4d8
BLAKE2b-256 20e9343530f37d317229086a03aacc9f23974be728897b55378507634cef565f

See more details on using hashes here.

File details

Details for the file value_network-0.0.42-py3-none-any.whl.

File metadata

File hashes

Hashes for value_network-0.0.42-py3-none-any.whl
Algorithm Hash digest
SHA256 74805dea86d04a83012c14f53b4d5bc3e60ad66f5fd6a45f297ed7662b9cd975
MD5 2db22ba379842431ffc4e549a21772d2
BLAKE2b-256 0ff61c26fb4b7e2ae80da6f5f6736940c18f23185fcf821e736c2a2d08dfda89

See more details on using hashes here.

Supported by

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