Commit Graph

3227 Commits (5ed4e5c945446fbeff0f0d81b8561eaee6d4f219)

Author SHA1 Message Date
Tyler Goodlet 5ed4e5c945 Only update last datum graphic(s) on clear ticks
When a new tick comes in but no new time step / bar is yet needed (to be
appended) we can simply adjust **only** the last bar datum
lines-graphic(s) to avoid a redraw of the preceding `QPainterPath` on
every tick. Do this by calling `Viz.draw_last()` on the fast and slow
chart and adjusting the guards around calls to `Viz.update_graphics()`
(which *does* update paths) to only enter when there's a `do_px_step`
condition. We can stop calling `main_viz.plot.vb._set_yrange()` on view
treading cases since the range should have already been adjusted by the
clearing-tick processing mxmn updates.

Further this changes,
- the `chart_maxmin()` helper (which we should eventually just get rid
  of) to take bound in `Viz`s for the ohlc and vlm chart instead of the
  chart widget handles.
- extend the guard around hist viz yranging to only enter when not in
  "axis mode" - the same as for the fast viz.
2023-02-02 16:11:32 -05:00
Tyler Goodlet 84c48f17e2 Ensure full hist OHLC path is drawn on tread
Since we removed the `Viz.update_graphics()` call from the main rt loop
we have to be sure to call it in the history chart incr-loop to avoid
a gap between the  last bar and prior history since startup. We only
need to update on tread since that should be the only time a full redraw
is ever necessary, ow only the last datum is needed.

Further this moves the graphics cycle func's profiler init to the top in
an effort to get more correct latency measures.
2023-02-02 16:11:32 -05:00
Tyler Goodlet ee8e27f256 Use `Viz.update_graphics()` throughout remainder of graphics loop where possible 2023-02-02 16:11:32 -05:00
Tyler Goodlet e06a6c94eb Use `Viz` over charts where possible in display loop
Since `ChartPlotWidget.update_graphics_from_flow()` is more or less just
a call to `Viz.update_graphics()` try to call that directly where
possible.

Changes include:
- calling the viz in the display state specific `maxmin()`.
- passing a viz instance to each `ChartView._set_yrange()` call (in prep
  of explicit group auto-ranging); not that this input is unused in the
  method for now.
- drop `bars_range` var passing since we don't use it.
2023-02-02 16:11:32 -05:00
Tyler Goodlet fdda0c6f77 Set a `PlotItem.viz` for interaction lookup
Inside `._interaction` routines we need access to `Viz` instances.
Instead of doing `CharPlotWidget._vizs: dict` lookups this ensures each
plot can lookup it's (parent) viz without error.

Also, adjusts `Viz.maxmin()` output parsing to new signature.
2023-02-02 16:11:32 -05:00
Tyler Goodlet c9f7083b79 Always cache `read_slc` alongside y-mnmx values 2023-02-02 16:11:32 -05:00
Tyler Goodlet a91664e154 Add back coord-caching to ohlc graphic 2023-02-02 16:11:32 -05:00
Tyler Goodlet 3b773c667b Use (modern) literal type annots in view code 2023-02-02 16:11:32 -05:00
Tyler Goodlet aa4a48cb98 Drop x-range query from `ChartPlotWidget.maxmin()`
Move the `Viz.datums_range()` call into `Viz.maxmin()` itself thus
minimizing the chart `.maxmin()` method to an ultra light wrapper around
the viz call. Also move all profiling into the `Viz` method.

Adjust `Viz.maxmin()` to return both the (rounded) x-range values which
correspond to the range containing the y-domain min and max so that
it can be used for up and coming overlay group maxmin calcs.
2023-02-02 16:11:32 -05:00
Tyler Goodlet cec5ef1d26 Drop multi mxmn from display mod 2023-02-02 16:11:32 -05:00
Tyler Goodlet 1f6ec98790 Only handle hist discrepancies when market is open
We obviously don't want to be debugging a sample-index issue if/when the
market for the asset is closed (since we'll be guaranteed to have
a mismatch, lul). Pass in the `feed_is_live: trio.Event` throughout the
backfilling routines to allow first checking for the live feed being active
so as to avoid breakpointing on false +ves. Also, add a detailed warning
log message for when *actually* investigating a mismatch.
2023-02-02 16:11:31 -05:00
Tyler Goodlet 702a13a278 Passthrough `tractor` kwargs directly 2023-02-02 16:11:31 -05:00
Tyler Goodlet 1aa7b937b9 Fix `open_trade_ledger()` enter value type annot 2023-02-02 16:11:31 -05:00
Tyler Goodlet 81b6cb17de Comment bad x-range bp for now 2023-02-02 16:11:31 -05:00
Tyler Goodlet 36f1edead0 Breakpoint bad (-ve or too large) x-ranges to m4
This should never really happen but when it does it appears to be a race
with writing startup pre-graphics-formatter array data where we get
`x_end` epoch value subtracting some really small offset value (like
`-/+0.5`) or the opposite where the `x_start` is epoch and `x_end` is
small.

This adds a warning msg and `breakpoint()` as well as guards around the
entire code downsampling code path so that when resumed the downsampling
cycle should just be skipped and avoid a crash.
2023-02-02 16:11:31 -05:00
Tyler Goodlet e1e52e9130 Downthrottle to 16Hz on multi-feed charts 2023-02-02 16:11:31 -05:00
Tyler Goodlet 3b15e76285 Attempt to keep selected item highlighted
This attempt was unsuccessful since trying to (re)select the last
highlighted item on both an "enter" or "click" of that item causes
a hang and then segfault in `Qt`; no clue why..

Adds a `keep_current_item_selected: bool` flag to
`CompleterView.show_cache_entries()` but using it seems to always cause
a hang and crash; we keep all potential use spots commented for now
obviously to avoid this. Also included is a bunch of tidying to logic
blocks in the kb-control loop for readability.
2023-02-02 16:11:31 -05:00
Tyler Goodlet c15a2babc1 Lol, pull hist chart from the display state 2023-02-02 16:11:31 -05:00
Tyler Goodlet 171e5da9f9 Make (cache) search-results a `set` and avoid overlay duplicate entries 2023-02-02 16:11:31 -05:00
Tyler Goodlet 92a609275b Take outer-interval values in `Viz.datums_range()` 2023-02-02 16:11:31 -05:00
Tyler Goodlet 07ee244ca9 Clean a buncha cruft from render mod 2023-02-02 16:11:31 -05:00
Tyler Goodlet 2122c7cbd9 Handle last-in-view time slicing edge case
Whenever the last datum is in view `slice_from_time()` need to always
spec the final array index (i.e. the len - 1 value we set as
`read_i_max`) to avoid a uniform-step arithmetic error where gaps in the
underlying time series causes an index that's too low to be returned.
2023-02-02 16:11:31 -05:00
Tyler Goodlet 888ae26d82 Drop bp blocks from formatters mod 2023-02-02 16:11:31 -05:00
Tyler Goodlet 61d1dd3306 Fix query-mode cursor labels to work with epoch-indexing 2023-02-02 16:11:31 -05:00
Tyler Goodlet 73f1e362bc Use `open_sample_stream()` in display loop 2023-02-02 16:11:31 -05:00
Tyler Goodlet 7208b3a2d2 Drop `Flume.index_stream()`, `._sampling.open_sample_stream()` replaces it 2023-02-02 16:11:31 -05:00
Tyler Goodlet ba8284e73b Add back another panes resize during startup 2023-02-02 16:11:31 -05:00
Tyler Goodlet ad1c9d02fa Always zero-on-step $vlm 2023-02-02 16:11:31 -05:00
Tyler Goodlet bb2d451a37 Mouse interaction tweaks
- adjust zoom focal to be min of the view-right coord or the right-most
  point on the flow graphic in view and drop all the legacy l1-in-view
  focal point cruft.
- flip to not auto-scaling overlays by default.
- change the `._set_yrange()` margin to `0.09`.
- drop `use_vr: bool` usage.
2023-02-02 16:11:31 -05:00
Tyler Goodlet 36c93e8dfe Modernize optional path variable type annots 2023-02-02 16:11:31 -05:00
Tyler Goodlet d68fd8662c Use `Curve.x_last()` for zoom focal point 2023-02-02 16:11:31 -05:00
Tyler Goodlet 58a82e7a3f Make `PlotItemOverlay` add items inwards->out
Before this axes were being stacked from the outside in (for `'right'`
and 'bottom'` axes) which is somewhat non-intuitive for an `.append()`
operation. As such this change makes a symbol list stack a set of
`'right'` axes from left-to-right.

Details:
- rename `ComposeGridLayout.items` -> `.pitems`
- return `(int, list[AxisItem])` pairs from `.insert/append_plotitem()`
  and the down stream `PlotItemOverlay.add_plotitem()`.
- drop `PlotItemOverlay.overlays` and add it back as `@property` around
  the underlying `.layout.pitems`.
2023-02-02 16:11:31 -05:00
Tyler Goodlet 5f5843613e Drop the legacy `relayed_from` cruft from our view box 2023-02-02 16:11:31 -05:00
Tyler Goodlet 42810056c3 Do full marker width after line 2023-02-02 16:00:39 -05:00
Tyler Goodlet c46f0c4a0a Fix indent level 2023-02-02 16:00:39 -05:00
Tyler Goodlet a2b4276cdf Make $vlm axis color same as clears 2023-02-02 16:00:39 -05:00
Tyler Goodlet bf0810ef4f Correctly load order mode for first fqsn in overlay set 2023-02-02 16:00:39 -05:00
Tyler Goodlet 404a34a049 Move $vlm y-axis to LHS 2023-02-02 16:00:39 -05:00
Tyler Goodlet 6b35484bce Better index step value scanning by checking with our expected set 2023-02-02 16:00:39 -05:00
Tyler Goodlet 3e754342de Repair auto-y-ranging to always include L1 spread
Goes back to always adjusting the y-axis range to include the L1 spread
and clearing label in view whenever the last datum is also in view,
previously this was broken after reworking the display loop for
multi-feeds.

Drops a bunch of old commented tick looping cruft from before we started
using tick-type framing. Also adds more stringent guards for ignoring
but error logging quote values that are more then 25% out of range; it
seems particularly our `ib` feed has some issues with strange `price`
values that are way off here and there?
2023-02-02 16:00:39 -05:00
Tyler Goodlet a06ff2fd75 Use static `L1Label._x_br_offset` as l1 label length 2023-02-02 16:00:39 -05:00
Tyler Goodlet 5b6240d167 Drop l1 labels attr from chart widget 2023-02-02 16:00:39 -05:00
Tyler Goodlet 846421bb28 Handle empty `indexes` input edge case.. 2023-02-02 16:00:39 -05:00
Tyler Goodlet 160c177ece TOSQUASH: 84f19308 (l1 rework) 2023-02-02 16:00:39 -05:00
Tyler Goodlet 40e6b5935d Set cursor label color to "bracket" 2023-02-02 16:00:39 -05:00
Tyler Goodlet 5ba472176e Don't set y-axis label colors to curve's, use the default from global scheme 2023-02-02 16:00:39 -05:00
Tyler Goodlet 5c853395bb Simplify L1 labels for multicharts
Instead of having the l1 lines be inside the view space, move them to be
inside their respective axis (with only a 16 unit portion inside the
view) such that the clear price label can overlay with them nicely
without obscuring; this is much better suited to multiple adjacent
y-axes and in general is simpler and less noisy.

Further `L1Labels` + `LevelLabel` style tweaks:
- adjust `.rect` positioning to be "right" (i.e. inside the parent
  y-axis) with a slight 16 unit shift toward the viewbox (using the new
  `._x_br_offset`) to allow seeing each level label's line even when the
  clearing price label is positioned at that same level.
- add a newline's worth of vertical space to each of the bid/ask labels
  so that L1 labels' text content isn't ever obscured by the clear price
  label.
- set a low (10) z-value to ensure l1 labels are always placed
  underneath the clear price label.
- always fill the label rect with the chosen background color.
- make labels fully opaque so as to always make them hide the parent
  axes' `.tickStrings()` contents.
- make default color the "default" from the global scheme.
- drop the "price" part from the l1 label text contents, just show the
  book-queue's amount (in dst asset's units, aka the potential clearing vlm).
2023-02-02 16:00:39 -05:00
Tyler Goodlet b7619e5ea4 Move old label sizing cruft to label mod 2023-02-02 16:00:39 -05:00
Tyler Goodlet ead2e1ed1f Make `FlowGraphic.x_last()` be optionally `None`
In the case where the last-datum-graphic hasn't been created yet, simply
return a `None` from this method so the caller can choose to ignore the
output. Further, drop `.px_width()` since it makes more sense defined on
`Viz` as well as the previously commented `BarItems.x_uppx()` method.
Also, don't round the `.x_uppx()` output since it can then be used when
< 1 to do x-domain scaling during high zoom usage.
2023-02-02 15:54:39 -05:00
Tyler Goodlet de3fd9edbe Add a parent-type for graphics: `FlowGraphic`
Factor some common methods into the parent type:
- `.x_uppx()` for reading the horizontal units-per-pixel.
- `.x_last()` for reading the "closest to y-axis" last datum coordinate
  for zooming "around" during mouse interaction.
- `.px_width()` for computing the max width of any curve in view in
  pixels.

Adjust all previous derived `pg.GraphicsObject` child types to now
inherit from this new parent and in particular enable proper `.x_uppx()`
support to `BarItems`.
2023-02-02 15:54:39 -05:00