Bluetooth client library and protocol specification for the Anova Precision Cooker sous vide.
The original Anova Precision Cooker 1.0 is an 800 watt sous vide which was released in 2014. You can control it with either physical on-device inputs or a phone app over Bluetooth Low Energy. Unlike later models, it does not have a Wi-Fi transceiver. It's a really nice device with high-quality hardware, and it works very well, even though the API design is questionable.
Unfortunately, Anova decided to charge users who create an account after 2024-08-21 $2/month or $10/year (USD) to control their sous vides from the phone app. They also decided to remove the existing Bluetooth connectivity from their app on 2025-09-28, so the only way to use their nonβWi-Fi devices will be with the physical controls. This library and protocol specification were inspired by a reader's objection to this bait-and-switch cash grab:
Some long-time users have pleaded with the company to think of alternative solutions. For example, a commenter called David, who claimed to own three Anova products, asked if the company could "open source the communication protocols and allow the community to take over."
"I suspect there is a strong overlap between people who own sous vides and developers (me for a start)," David said.
To be clear, the ability to remotely control a sous vide is worthless. There is no advantage to starting, monitoring, or stopping cooking with your phone:
- It's far clumsier and slower than the physical dial and button located on the sous vide itself.
- You're going to be near the device when you start it anyway, so you don't need to start it from far away.
- Cooking using the phone app is not better than with the manual inputs because the only relevant parameters are the target water temperature and the signal to begin cooking, so the phone app is not smarter.
- The timer is useless because the entire point of sous vide is that it can run forever, so if you want to know when two hours have elapsed, set a timer on your phone or oven.
- If you want to sous vide as quickly as possible, the only correct solution is to use a continuous thermometer like the Thermoworks Dot.
- Being able to transfer online "recipes" is a waste of time because they are so simplistic that they just set a useless timer and a target water temperature, which you could have easily set yourself, either by looking it up on your handy temperature guide or a quick web search.
- There is no reason to check the water temperature remotely, because it will always be at the target temperature thanks to the fact that the sous vide is running.
- There is no reason to change the water temperature set point remotely, because the point of sous vide is using a constant temperature for the entire cooking duration.
If you still want to control your Anova Precision Cooker over Bluetooth after 2025-09-28, you can try the following techniques until one works.
- Install an older version of the app that still has the Bluetooth functionality.
- Use the sample program in this repository.
- Write your own .NET application using the client library in this repository.
- Write your own application in a programming language of your choice by following the protocol specification in this repository.
- Inspect Bluetooth LE traffic between your phone and sous vide to understand and implement the GATT communication protocol yourself β its design is misguided but simple, just RPC-style string writes and response callbacks used to read and write values and invoke functions.
- Anova sous vide
- Tested on a Precision Cooker 1.0 with Bluetooth (2014,
Anova PC
)
- Tested on a Precision Cooker 1.0 with Bluetooth (2014,
- Bluetooth adapter
- Tested on a USB Asus USB-BT400 and onboard Intel AX211
- .NET Framework 4.6.2, 6.0, or later
- Plug in the sous vide.
- Press its Bluetooth button to enter pairing mode. It will turn blue and start blinking.
- Scan for the sous vide in the Bluetooth settings of your operating system.
- Windows 10 (21H2 or later required because of BLE)
- Go to Settings βΊ Devices βΊ Bluetooth & other devices βΊ Add Bluetooth or other device βΊ Bluetooth.
- Select
Anova
.
- Windows 11
- Go to Settings βΊ Bluetooth & devices βΊ Devices.
- Set Device settings βΊ Bluetooth devices discovery to Advanced, otherwise the device will be hidden.
- Select Add device βΊ Bluetooth.
- Select
Anova
.
- Windows 10 (21H2 or later required because of BLE)
- Enter the PIN
0000
.
This sample program demonstrates Bluetooth connectivity and reference usage of the library.
- Download the
SousVideCtl
ZIP file for your operating system and CPU architecture from the latest release. - Extract the ZIP file.
- On Linux- and Unix-based operating systems, set the executable bit using
chmod +x sousvidectl
. - Run
./sousvidectl
.Current temperature: 73.0 Β°F Target temperature: 135.0 Β°F Start ββ Set temperature Exit
- Press
S
to start and stop the sous vide. - Press
β
andβ
to raise and lower the target temperature. - Press
X
to exit.
- In your .NET project, add a dependency on the NuGet package
SousVide
.dotnet add package SousVide
- When targeting Windows, add a Windows 10 target framework moniker to the
<TargetFrameworks>
in your.csproj
project file, otherwise it will use the Linux implementation if you only target an OS-agnostic TFM likenet8.0
.<TargetFrameworks>net8.0-windows10.0.19041.0</TargetFrameworks>
- Connect to the paired sous vide.
await using ISousVide? sousVide = await AnovaPrecisionCooker.Create();
- Call methods, and read or subscribe to reactive properties, on the
ISousVide
instance.Console.WriteLine(sousVide.IsRunning.Value ? "Running" : "Stopped"); Console.WriteLine($"Desired temperature: {sousVide.DesiredTemperature.Value:N1}"); await sousVide.SetDesiredTemperature(Temperature.FromDegreesFahrenheit(135)); await sousVide.Start(); await Task.Delay(TimeSpan.FromHours(2)); await sousVide.Stop();
ISousVide
is the public interface of this library.
Construct instances by calling await AnovaPrecisionCooker.Create(string? deviceId)
. To connect to any paired Precision Cooker, pass null
to the deviceId
parameter. To connect to a known previous instance, persist its DeviceId
property and pass it to the deviceId
parameter.
The unique ID of this Bluetooth device. Can be persisted and passed to AnovaPrecisionCooker.Create(string?)
later to reconnect to the exact same device, in case there are multiple paired Precision Cookers.
true
if the sous vide is cooking, or false
otherwise. Change this with Start()
and Stop()
.
The current temperature of the water.
The target of the water temperature. Change this with SetDesiredTemperature(Temperature)
.
Change the set point of the water temperature. Changes DesiredTemperature
.
Begin cooking. Changes IsRunning
. Stop with Stop()
.
Stop cooking. Changes IsRunning
.
Start a countdown timer that will stop cooking after the given duration elapses. After calling this method, call Start()
to begin cooking for this duration. Can be cancelled with StopTimer()
.
Cancels any existing countdown timer that was previously started with StartTimer(TimeSpan)
.
To learn about the requests and responses for the Anova Bluetooth LE API, see Communication Protocol.
To learn how to inspect traffic between an Android phone and a Bluetooth LE device, see Bluetooth Low Energy Interception.
- Luke Ma for generously giving me an Anova Precision Cooker as a Christmas present in 2020.