50c1bb5929
Connecting task moved?
2024-08-21 16:18:01 +08:00
6b08720f4f
AsyncIO version Client -> AsyncioClient
2024-08-21 16:18:01 +08:00
b76f5a01fa
Exclusively use the Thermostat object as a medium
...
All calls to the Thermostat should be forwarded by the medium.
2024-08-21 16:18:01 +08:00
4aaadff2ab
Integrate WrappedClient into Thermostat model
2024-08-21 12:28:36 +08:00
1ab5c9e7ee
Should not stop cancelling read if timeout'd
2024-08-21 12:28:36 +08:00
7019bbe004
Fix Autotuner state for forceful disconnect
2024-08-21 12:28:36 +08:00
1b64a88c75
Correct exception catching
...
asyncio.Task.result() is simply going to throw the exception in
asyncio.Task.exception(), there is no need to manually throw it.
2024-08-21 12:28:31 +08:00
fae0c4141d
Make connection loss handling more elegant
...
Show an info box on connection lost informing the user that the
Thermostat was forcefully disconnected.
2024-08-21 12:28:05 +08:00
f387a1e085
================Force connection fix starts here========
2024-08-21 12:28:05 +08:00
9bf0a8bc81
Just catch asyncio.TimeoutError
...
Will just change to TimeoutError once we switch to Python 3.11 in the
flake.
2024-08-21 12:28:05 +08:00
cedb828959
Remove exception too general
2024-08-21 12:28:02 +08:00
aaaef450f3
Formatting
2024-08-21 11:16:15 +08:00
9bdea9d873
flake.nix: nixfmt-rfc-style
2024-08-21 11:16:15 +08:00
30fdcfa879
Use asserts to check for connectivity
2024-08-21 11:16:15 +08:00
e2ea417737
Add back the parent
2024-08-21 11:16:15 +08:00
c3b59c2924
README: Proofread
2024-08-21 11:16:15 +08:00
728a3fb7bd
Swap order arounda bit more
2024-08-21 11:16:15 +08:00
905383428b
Fix method call
2024-08-21 11:16:15 +08:00
870d10b525
Use qtextras
2024-08-21 11:16:15 +08:00
b768d61e39
Merge pull request 'GUI: Text changes' ( #3 ) from gui_dev-str_changes into gui_dev
...
Reviewed-on: linuswck/thermostat#3
2024-07-19 15:36:01 +08:00
d244ba392a
Fix typos
2024-07-19 15:34:31 +08:00
93d6df5e92
Merge pull request 'GUI: Some repo organisation' ( #1 ) from gui_dev-repo_org into gui_dev
...
Reviewed-on: linuswck/thermostat#1
2024-07-12 10:34:23 +08:00
44bea87f03
Thermostat.disconnect -> Thermostat.end_session
...
QObject already has a disconnect method, avoid overriding it.
2024-07-10 15:56:43 +08:00
e6f62e9e19
flake: sha256 -> hash
2024-07-10 15:56:43 +08:00
271fe449ba
Remove duplicated show call
...
MainWindow.show() already called in coro_main
2024-07-10 15:56:43 +08:00
70db0a39eb
Remove duplicated antialias config option
...
Already set in live_plot_view.py
2024-07-10 15:56:43 +08:00
26c7382b1e
Move GUI components and examples into folder
...
For better organisation
2024-07-10 15:56:43 +08:00
c415d9de8a
Use MANIFEST.in
...
Allows for more accurate control over included files in pytec package
2024-07-10 15:56:43 +08:00
7069111e21
Expose frontend scripts exclusively in pytec
2024-07-10 15:56:43 +08:00
1707728c3c
thermostat_data_model.py -> thermostat.py
2024-07-10 15:56:34 +08:00
a16d2e9a9e
Follow CapWords convention for class names
...
Re: PEP8
2024-07-10 15:45:03 +08:00
bc4ac43e0b
Put comments in right place
2024-07-10 13:07:31 +08:00
9acff86547
Restructure GUI Code, Improve and Fix Bugs
...
- Bugs fix:
1. Params Tree user input will not get overwritten
by incoming report thermostat_data_model.
2. PID Autotune Sampling Period is now set according to Thermostat sampling interval
3. PID Autotune won't get stuck in Fail State
4. Various types disconnection related Bugs
5. Number of Samples stored in the plot cannot be set
6. Limit the max settable output current to be 2000mA
- Improvement:
1. Params Tree settings can be changed with external json
2. Use a Tab system to show a single channel of config instead of two
3. Expose PID Autotune lookback params
4. Icon is changed to Artiq logo
- Restructure:
1. Restructure the code to follow Model-View-Delegate Design Pattern
2024-06-06 17:34:15 +08:00
8753f4a0fc
Finish GUI
2024-05-08 14:49:03 +08:00
9a83d6850d
Remove unused as clause
2024-05-08 14:49:03 +08:00
772863f4b2
Add paramtree view, without updates
...
Signed-off-by: Egor Savkin <es@m-labs.hk>
Fix signal blocker argument -atse
2024-05-08 14:49:03 +08:00
44ef2c04e3
Fix bugs, grammar, text, and refactor into class
2024-05-08 14:49:03 +08:00
623011fabb
Change title
2024-05-08 14:49:03 +08:00
400f3a98e8
Stop polling drift
...
Just waiting for the update_s doesn't take into account the time to
execute update_params, and causes time drift.
2024-05-08 14:49:03 +08:00
7dd5d15047
Remove unused 'as' clause
2024-05-08 14:49:03 +08:00
297e589c30
Update docs
2024-05-08 14:49:03 +08:00
65e1f4a146
Finish moving over to qasync
...
Also:
* Add aioclient
The old client is synchronous and blocking, and the only way to achieve
true asynchronous IO is to create a new client that interfaces with
asyncio.
* Finish Nix Flake description and make the GUI available for `nix run`
2024-05-08 14:49:03 +08:00
e0ce14c616
Try move from Qthreads to qasync
...
Signed-off-by: Egor Savkin <es@m-labs.hk>
2024-05-08 14:49:03 +08:00
a79679a074
Create client watcher, that would poll Thermostat for config
...
Signed-off-by: Egor Savkin <es@m-labs.hk>
2024-05-08 14:49:03 +08:00
b9acba69d3
Create basic GUI, that would connect and control thermostat's fan
...
Signed-off-by: Egor Savkin <es@m-labs.hk>
2024-05-08 14:49:03 +08:00
b4b4ec987c
add autotune
2024-05-08 14:49:03 +08:00
8c1cb3117c
README: Add notes on i_tec
& tec_i
readouts
2024-05-02 17:48:47 +08:00
1fcfe41a63
Add averaging filter on the pin_adc readings
...
- Adapted from Kirdy Firmware
- Can reduce the i_tec readings noise dispersion
2024-05-02 16:49:55 +08:00
9fce19a418
Revert "Disable feedback current readout on flawed HW Revs"
...
This reverts commit ae3d8b51d4
.
2024-05-02 14:38:40 +08:00
00d5feaa8d
Limit i_set within range of MAX1968 chip
2024-04-24 18:05:20 +08:00