Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

AI win rate graph for main branch of demo/review board #2862

Open
JDNdeveloper opened this issue Nov 9, 2024 · 6 comments
Open

AI win rate graph for main branch of demo/review board #2862

JDNdeveloper opened this issue Nov 9, 2024 · 6 comments

Comments

@JDNdeveloper
Copy link
Contributor

Currently the win rate shown in the demo/review board is limited to a single board position, however it would be really useful if the win rate graph could be shown for the entire main/top branch.

My current need for this is from recording live games using a demo board. At the end of the game I'd like to review and see the win rate graph for the entire game, however this isn't possible from within the demo board. My workaround is to download the SGF and then reupload to the SGF library and run an analysis, but I'd prefer to not have a separate history of the game in two places, as well as avoid the manual download/reupload step.

My understanding for why this wasn't included originally is that demo/review boards usually have many branches, so it's not obvious which branch should be used. However, I think the main/top branch is a logical default, and would likely work for most people.

I can help make this change, however from a brief look over the code in AIDemoReview.tsx and AIReview.tsx it wasn't obvious to me how to do this. I also haven't been able to get AI reviews showing in demo boards in my dev account, which will make this harder to test. Is there a way to test that out?

@anoek
Copy link
Member

anoek commented Nov 12, 2024

There's some back end structural changes that'd need to happen to make this work as the way reviews work is fairly different than games. With games, the main line doesn't ever change when we send it off for review, with demos and reviews that's not true at all and can be copy/pasted, added and deleted, and so that flux was troublesome to deal with and a bit worrisome from a server load perspective. I think what we can probably do is do a fast pass update on those kind of changes and update a graph, then do a deeper review when someone is actually looking at a move, but implementing all of that is quite an undertaking and there have been other priorities.

@frostburn
Copy link

I'd like to voice my support for this feature. I recently relayed some championship games and the players were disappointed when the score graph wasn't visible immediately after the game.

I understand that server load is an issue so I'd be happy with an "analyze current branch" button with a 5 minute cooldown as a compromise.

@JDNdeveloper
Copy link
Contributor Author

@frostburn definitely agree with that. I don't need it to be dynamic, I just want to be able to get a graph for the main branch after recording a game.

@JDNdeveloper
Copy link
Contributor Author

@anoek how difficult would it be to add backend support for analyzing a single branch of a demo/review board, like @frostburn suggested? I'd be happy to work on frontend support for the feature.

@anoek
Copy link
Member

anoek commented Jan 21, 2025

I looked through things a bit, I think you could hack something together that does a basic version of what you'd want with the existing API by doing this code a lot: https://github.com/online-go/online-go.com/blob/devel/src/views/Game/AIDemoReview.tsx#L206-L222 but I think for going to production we'd want to probably expand that endpoint to include a strength parameter so you could do a fast pass and get a nice graph quickly as opposed to waiting for minutes for it to pop up, and possibly adding a parameter so you could specify the starting board position and an array of moves that you want to analyze all together so you don't have send 300 of those messages to analyze the main line. Never the less, that could very well get you started today if you want, and then we can figure out how we want things to work longer term.

Should probably test against beta first, you should be able to sign up to be a beta supporter using a test credit card number (for example visa 4111 1111 1111 1111 any future expiration date, any ccv), or just let me know and I'll manually flag your account(s) as beta supporters so that endpoint works for you.

@JDNdeveloper
Copy link
Contributor Author

Thanks, I'll give that a shot!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants