Centipede Speed Up request

Zeosstud
Posts: 104
Joined: Sun Jun 21, 2020 4:56 pm
Has thanked: 2 times
Been thanked: 25 times

Centipede Speed Up request

Unread post by Zeosstud »

Hello,
Anyone interested in trying to update Centipede so the trackball sensitivity could be higher, it goes to 200% currently but several of use seem to agree even more would be helpful..

Thoughts?

Zeosstud

User avatar
jimmystones
Core Developer
Posts: 216
Joined: Sun Nov 22, 2020 1:26 pm
Location: Reading, UK
Has thanked: 32 times
Been thanked: 248 times
Contact:

Re: Centipede Speed Up request

Unread post by jimmystones »

Zeosstud wrote: Fri Jan 27, 2023 4:46 am

Hello,
Anyone interested in trying to update Centipede so the trackball sensitivity could be higher, it goes to 200% currently but several of use seem to agree even more would be helpful..

Thoughts?

Zeosstud

The core is getting a bit flaky and might not enjoy adding another option to the mix, but I'll give it go!

Lex
Posts: 67
Joined: Sat Sep 05, 2020 7:01 pm
Been thanked: 4 times

Re: Centipede Speed Up request

Unread post by Lex »

I think 300% would be close to the original Centipede arcade game otherwise it is working very well. Would be great if this would be implemented.

regards,
Lex

User avatar
jimmystones
Core Developer
Posts: 216
Joined: Sun Nov 22, 2020 1:26 pm
Location: Reading, UK
Has thanked: 32 times
Been thanked: 248 times
Contact:

Re: Centipede Speed Up request

Unread post by jimmystones »

I've just pushed a new version with a 400% speed option, should be available for update within an hour or so...

(the reason it's 400% is mainly because x2 or /2 is much easier for the FPGA and causes less stress on the core!)

Hetzen
Posts: 141
Joined: Thu Oct 14, 2021 1:55 pm
Has thanked: 72 times
Been thanked: 43 times

Re: Centipede Speed Up request

Unread post by Hetzen »

Thanks jimmystones. I've just played a few games with the GRS trackball the sensitivity is certainly increased and plays better, but I'm now wandering what 800% would do. It took 3 rolls to get across the screen on 200% it now takes 2.5 rolls on 400%. Moving the ball slowly, you can certainly feel the ball travel a bit to move one pixel on screen, at 400% there is less play, but it's still there.

Is it even possible to go to 800%?

I'm happy to test a non release if that would help.

Hetzen
Posts: 141
Joined: Thu Oct 14, 2021 1:55 pm
Has thanked: 72 times
Been thanked: 43 times

Re: Centipede Speed Up request

Unread post by Hetzen »

Lex wrote: Mon Jan 30, 2023 6:04 pm

I think 300% would be close to the original Centipede arcade game otherwise it is working very well.

I'd be interested in what you think with this update. I can't honestly remember if there was much play at low speed rolling.

Lex
Posts: 67
Joined: Sat Sep 05, 2020 7:01 pm
Been thanked: 4 times

Re: Centipede Speed Up request

Unread post by Lex »

Hello Jimmy!

Thanks so much for giving this a go - you are awesome. I am redesigning my control panel from my self-build arcade machine at the moment and making it perfect. I can´t wait to test this when I am finished. No matter what you do there are two main factors connected - DETAIL and detail takes time (which we believe we don´t have). Nice greetings

User avatar
LamerDeluxe
Top Contributor
Posts: 1160
Joined: Sun May 24, 2020 10:25 pm
Has thanked: 798 times
Been thanked: 257 times

Re: Centipede Speed Up request

Unread post by LamerDeluxe »

The trackball doesn't look very fast in this video: https://youtu.be/ZrSfoG0wY8c

Hetzen
Posts: 141
Joined: Thu Oct 14, 2021 1:55 pm
Has thanked: 72 times
Been thanked: 43 times

Re: Centipede Speed Up request

Unread post by Hetzen »

LamerDeluxe wrote: Mon Jan 30, 2023 10:55 pm

The trackball doesn't look very fast in this video: https://youtu.be/ZrSfoG0wY8c

Good shout finding that. I think at around 3:53 you can see the distance the bug moves with one gesture, it seems further than 400% currently reaches.

User avatar
LamerDeluxe
Top Contributor
Posts: 1160
Joined: Sun May 24, 2020 10:25 pm
Has thanked: 798 times
Been thanked: 257 times

Re: Centipede Speed Up request

Unread post by LamerDeluxe »

Hetzen wrote: Mon Jan 30, 2023 11:19 pm
LamerDeluxe wrote: Mon Jan 30, 2023 10:55 pm

The trackball doesn't look very fast in this video: https://youtu.be/ZrSfoG0wY8c

Good shout finding that. I think at around 3:53 you can see the distance the bug moves with one gesture, it seems further than 400% currently reaches.

I think you mean from 2:53, there you can indeed see the screen in combination with his hand moving. 1:02 and 4:38 are also good, but a bit further away.

Hetzen
Posts: 141
Joined: Thu Oct 14, 2021 1:55 pm
Has thanked: 72 times
Been thanked: 43 times

Re: Centipede Speed Up request

Unread post by Hetzen »

LamerDeluxe wrote: Tue Jan 31, 2023 7:44 am
Hetzen wrote: Mon Jan 30, 2023 11:19 pm
LamerDeluxe wrote: Mon Jan 30, 2023 10:55 pm

The trackball doesn't look very fast in this video: https://youtu.be/ZrSfoG0wY8c

Good shout finding that. I think at around 3:53 you can see the distance the bug moves with one gesture, it seems further than 400% currently reaches.

I think you mean from 2:53, there you can indeed see the screen in combination with his hand moving. 1:02 and 4:38 are also good, but a bit further away.

I pointed out 3:53 to show how it moves with a gesture, ie it's maximum speed with one hand pass. The travel is not quite like the video shows at 3:57. It seems the core at the moment tops out at a clamped speed.

I've attached a video with 400% sensitivity. The front end shows minimum movement on the track ball. It seems it's counting @4 slot pulses from the direction flywheel for one pixel. Then it shows full movement and the top speed the bug can travel atm.

It's all very playable as is and a definite improvement on 200%, so was just wondering if 800% was possible. I could be wrong. Interested in what others think.

Attachments
GRS Trackball 400.mp4
(26.23 MiB) Downloaded 117 times
User avatar
LamerDeluxe
Top Contributor
Posts: 1160
Joined: Sun May 24, 2020 10:25 pm
Has thanked: 798 times
Been thanked: 257 times

Re: Centipede Speed Up request

Unread post by LamerDeluxe »

Hetzen wrote: Tue Jan 31, 2023 2:16 pm
LamerDeluxe wrote: Tue Jan 31, 2023 7:44 am
Hetzen wrote: Mon Jan 30, 2023 11:19 pm

Good shout finding that. I think at around 3:53 you can see the distance the bug moves with one gesture, it seems further than 400% currently reaches.

I think you mean from 2:53, there you can indeed see the screen in combination with his hand moving. 1:02 and 4:38 are also good, but a bit further away.

I pointed out 3:53 to show how it moves with a gesture, ie it's maximum speed with one hand pass. The travel is not quite like the video shows at 3:57. It seems the core at the moment tops out at a clamped speed.

I've attached a video with 400% sensitivity. The front end shows minimum movement on the track ball. It seems it's counting @4 slot pulses from the direction flywheel for one pixel. Then it shows full movement and the top speed the bug can travel atm.

It's all very playable as is and a definite improvement on 200%, so was just wondering if 800% was possible. I could be wrong. Interested in what others think.

Ah, I see. In your video it looks like it moves a really short distance with slow trackball movement. Seems like acceleration is being used. I wonder how well that matches the real machine.

Hetzen
Posts: 141
Joined: Thu Oct 14, 2021 1:55 pm
Has thanked: 72 times
Been thanked: 43 times

Re: Centipede Speed Up request

Unread post by Hetzen »

LamerDeluxe wrote: Tue Jan 31, 2023 2:35 pm

Seems like acceleration is being used. I wonder how well that matches the real machine.

I think you might be right. I wonder if the original was completely linear in its reading of the pulses, where as mouse controllers have acceleration curves. That might explain the 3 spins to 2.5 spins needed to cross the screen with a 2x increase in sensitivity.

I've just read through this Github thread https://github.com/MiSTer-devel/Arcade- ... /issues/23 and now fully appreciate the work that has gone into getting this to work at all. So thanks Jimmystones for getting it to this state.

Hetzen
Posts: 141
Joined: Thu Oct 14, 2021 1:55 pm
Has thanked: 72 times
Been thanked: 43 times

Re: Centipede Speed Up request

Unread post by Hetzen »

I've just compared this to the Atari 50th version running on the PC, man that version is laggy with a mouse or trackball compared to this.

User avatar
LamerDeluxe
Top Contributor
Posts: 1160
Joined: Sun May 24, 2020 10:25 pm
Has thanked: 798 times
Been thanked: 257 times

Re: Centipede Speed Up request

Unread post by LamerDeluxe »

Hetzen wrote: Tue Jan 31, 2023 5:17 pm
LamerDeluxe wrote: Tue Jan 31, 2023 2:35 pm

Seems like acceleration is being used. I wonder how well that matches the real machine.

I think you might be right. I wonder if the original was completely linear in its reading of the pulses, where as mouse controllers have acceleration curves. That might explain the 3 spins to 2.5 spins needed to cross the screen with a 2x increase in sensitivity.

I've just read through this Github thread https://github.com/MiSTer-devel/Arcade- ... /issues/23 and now fully appreciate the work that has gone into getting this to work at all. So thanks Jimmystones for getting it to this state.

Exactly, I was wondering the same thing.

Just read that thread and wow, what a nightmare, wasn't expecting that.

User avatar
jimmystones
Core Developer
Posts: 216
Joined: Sun Nov 22, 2020 1:26 pm
Location: Reading, UK
Has thanked: 32 times
Been thanked: 248 times
Contact:

Re: Centipede Speed Up request

Unread post by jimmystones »

So based on my understanding of the way the original hardware works, it definitely is trying to be linear - but the game only reads the encoder values so many times a second, and that read is in no way synchronised with the rotation, so the results can be a bit weird on occasion.

There is definitely a maximum theoretical speed you can move, as the game could only read up to a rotation speed per frame before it's counters roll over (and if that happens you can get glitchy negative acceleration, which is very unpleasant!)

The difficulty is compounded a bit on MiSTer because we have a mouse/trackball reporting back from the Linux side at one frequency (which is not 100% consistent to be honest!), feeding an emulated trackball encoder being read by the game running on the CPU at a completely different frequency.
As such the trackball emulation I have made is definitely a bit hacky and doesn't 100% replicate the original hardware, and may well inherit some acceleration from the USB device or Linux I suppose (though I don't think I intentionally added any). Regardless I think it's a lot better than what we had before :D

Zeosstud
Posts: 104
Joined: Sun Jun 21, 2020 4:56 pm
Has thanked: 2 times
Been thanked: 25 times

Re: Centipede Speed Up request

Unread post by Zeosstud »

JimmyStones,
Thank You, that update truly made a difference. Do not know how you guys do it, but I certainly appreciate it.

Zeosstud

User avatar
LamerDeluxe
Top Contributor
Posts: 1160
Joined: Sun May 24, 2020 10:25 pm
Has thanked: 798 times
Been thanked: 257 times

Re: Centipede Speed Up request

Unread post by LamerDeluxe »

jimmystones wrote: Tue Jan 31, 2023 8:21 pm

and may well inherit some acceleration from the USB device or Linux I suppose (though I don't think I intentionally added any).

I was wondering if there could be mouse-acceleration options in Linux (like Windows has), that could interfere with the handling of mouse-like devices on MiSTer. So that seems to be a possibility then.

And could past polling make the roll-over problem worse?

User avatar
jimmystones
Core Developer
Posts: 216
Joined: Sun Nov 22, 2020 1:26 pm
Location: Reading, UK
Has thanked: 32 times
Been thanked: 248 times
Contact:

Re: Centipede Speed Up request

Unread post by jimmystones »

Assuming you mean fast polling, then no I don't think that changes the frequency at which the MiSTer framework sends mouse updates to the core, it just increases the frequency with which the number that the framework sends is updated. So it shouldn't affect the actual speed, just more accurately reflect changes in speed. I think....

I hope that makes sense to someone! :lol:

thorr
Top Contributor
Posts: 1100
Joined: Mon Jul 06, 2020 9:37 pm
Has thanked: 537 times
Been thanked: 252 times

Re: Centipede Speed Up request

Unread post by thorr »

I don't think LamerDeluxe meant fast polling (edit: I am wrong). I think in the first statement, he is saying that in Windows for example, you can sometimes adjust sliders for mouse acceleration, and perhaps there is a Linux equivalent and it has some default value. I don't know what the second statement is saying. Edit, now I get it. Past polling was a type-o for Fast polling. I would think that fast polling should not affect anything but input lag.

As a side note, is there a way to hook up a trackball with SNAC? I have a Happ trackball that could be hooked up this way and might theoretically work exactly correct, except I have high resolution encoder wheels (from groovygamegear). I haven't tried the new version of the core yet, so it might be just fine via USB. I am still building my arcade cabinet.

netbeui
Posts: 148
Joined: Fri Jul 31, 2020 5:04 am
Has thanked: 77 times
Been thanked: 23 times

Re: Centipede Speed Up request

Unread post by netbeui »

I compared my Centipede arcade with the MiSTer Centipede core and to me it seems like the core sensitivity setting at 100% is closest to my machine. If it helps I can record a video tomorrow, just let me know :)

thorr
Top Contributor
Posts: 1100
Joined: Mon Jul 06, 2020 9:37 pm
Has thanked: 537 times
Been thanked: 252 times

Re: Centipede Speed Up request

Unread post by thorr »

netbeui wrote: Wed Feb 01, 2023 4:43 am

I compared my Centipede arcade with the MiSTer Centipede core and to me it seems like the core sensitivity setting at 100% is closest to my machine. If it helps I can record a video tomorrow, just let me know :)

What kind of trackball are you using with the MiSTer and how is it connected?

User avatar
jimmystones
Core Developer
Posts: 216
Joined: Sun Nov 22, 2020 1:26 pm
Location: Reading, UK
Has thanked: 32 times
Been thanked: 248 times
Contact:

Re: Centipede Speed Up request

Unread post by jimmystones »

No SNAC as yet I'm afraid, no - I would like to give it a try and add it for Centipede and Missile Command some point but I'll need to get my hands on / access to various bits of kit as I'm not really set up for the electronics side.. Wouldn't even know how to wire it up!

Hetzen
Posts: 141
Joined: Thu Oct 14, 2021 1:55 pm
Has thanked: 72 times
Been thanked: 43 times

Re: Centipede Speed Up request

Unread post by Hetzen »

Apparently the bug should move 2.5 mushrooms with the exposed arc of the ball. 200% does this with the GRS trackball. BUT, that depends on how fast you roll the ball. For example, you can move right quickly, then move back slowly (which brings you back short of where you started). So there is some acceleration going on, probably within the mouse driver.

If the exposed portion of the ball is 1/3rd of its circumference and the ball is 2.25 inches (5.625cm) in diameter, the balls surface will have moved roughly 5.89cm.

If the diameter of the spindle the ball rolls against is 0.8cm in og hardware, its circumference will be 2.513cm, meaning the spindle will have revolved 2.34 times after moving the ball 1/3rd of it's full rotation.

There are 24 teeth in Centepede's og hardware, meaning 56.26 teeth have produced pulses to move 2.5 mushrooms. And assuming the mushrooms are 8x8 pixels, the distance travelled on screen is 20 pixels.

So it looks like the arcade machine is interpreting pulses as linear with no acceleration, that means 1 pixel of movement requires @3 pulses from the og hardware trackball.

What then gets complicated is then reverse engineering this to off the shelf trackballs, ball to spindle to tooth ratio to try and get real parity.

Original track ball teardown can be seen here https://www.youtube.com/watch?v=St5C9dzdJZE

netbeui
Posts: 148
Joined: Fri Jul 31, 2020 5:04 am
Has thanked: 77 times
Been thanked: 23 times

Re: Centipede Speed Up request

Unread post by netbeui »

thorr wrote: Wed Feb 01, 2023 6:59 am
netbeui wrote: Wed Feb 01, 2023 4:43 am

I compared my Centipede arcade with the MiSTer Centipede core and to me it seems like the core sensitivity setting at 100% is closest to my machine. If it helps I can record a video tomorrow, just let me know :)

What kind of trackball are you using with the MiSTer and how is it connected?

I'm using a Kensington trackball mouse, this one: https://www.kensington.com/p/products/e ... trackball/. It's a standard USB mouse so it's connected to a regular USB port on my MiSTer.

The ball diameter on the Kensignton is very close to the ball diameter on my Centipede trackball. It feels lighter than the Centipede trackball so the weight is off but the diameter feels very close.

thorr
Top Contributor
Posts: 1100
Joined: Mon Jul 06, 2020 9:37 pm
Has thanked: 537 times
Been thanked: 252 times

Re: Centipede Speed Up request

Unread post by thorr »

jimmystones wrote: Wed Feb 01, 2023 9:00 am

No SNAC as yet I'm afraid, no - I would like to give it a try and add it for Centipede and Missile Command some point but I'll need to get my hands on / access to various bits of kit as I'm not really set up for the electronics side.. Wouldn't even know how to wire it up!

Having a SNAC connection would be awesome, and for Crystal Castles too :-). This might help: http://forum.arcadecontrols.com/index.php?topic=68289.0
and here is a trackball: https://groovygamegear.com/webstore/ind ... cts_id=363

I don't expect anything at all, but thought I would share in case it helps. Thanks!

Zeosstud
Posts: 104
Joined: Sun Jun 21, 2020 4:56 pm
Has thanked: 2 times
Been thanked: 25 times

Re: Centipede Speed Up request

Unread post by Zeosstud »

@thorr Curious if you have gotten to play any yet with the USB connection and your high resolution encoder wheels. Would be interested in your feedback with that setup, Centipede and Missile Command would be the games I cared about most, but any feed back you might have with any of the games or cores would be interesting. I have Happ 3", U-Trak and Happ 2.25" trackballs I will be putting thru their paces soon, they all just have factor parts, not the enhanced stuff from GGG.

Zeosstud

thorr
Top Contributor
Posts: 1100
Joined: Mon Jul 06, 2020 9:37 pm
Has thanked: 537 times
Been thanked: 252 times

Re: Centipede Speed Up request

Unread post by thorr »

Zeosstud wrote: Sun Feb 05, 2023 12:25 am

@thorr Curious if you have gotten to play any yet with the USB connection and your high resolution encoder wheels. Would be interested in your feedback with that setup, Centipede and Missile Command would be the games I cared about most, but any feed back you might have with any of the games or cores would be interesting. I have Happ 3", U-Trak and Happ 2.25" trackballs I will be putting thru their paces soon, they all just have factor parts, not the enhanced stuff from GGG.

Zeosstud

I just tried it. For me, 200% seems the best for both of those games. 400% is too fast in Centipede. 300% would be maybe better than 200%, but I prefer 200% instead of 400%, and it is good enough. In Missile Command, 200% seems about right. I tried Crystal Castles, but I can't even launch it. It is missing a file for some reason.

Hetzen
Posts: 141
Joined: Thu Oct 14, 2021 1:55 pm
Has thanked: 72 times
Been thanked: 43 times

Re: Centipede Speed Up request

Unread post by Hetzen »

Apparently there's a way to switch off acceleration within Linux. Thing is I'm not finding a directory called xorg.conf.d.

To completely disable mouse acceleration, create a file called "50-mouse-acceleration.conf" in xorg.conf.d. The path to xorg.conf.d can vary depending on the Linux distribution you use. For instance, in Ubuntu, Linux Mint, and derivatives, it's /usr/share/X11/xorg.conf.d/. On Arch Linux, it's /etc/X11/xorg.conf.d/.

To open an empty 50-mouse-acceleration.conf file in /usr/share/X11/xorg.conf.d/ with Nano (command line text editor; should be installed by default in most Linux distributions), use the following command:
sudo nano /usr/share/X11/xorg.conf.d/50-mouse-acceleration.conf
And in this file, paste the following:
Section "InputClass"
Identifier "My Mouse"
MatchIsPointer "yes"
Option "AccelerationProfile" "-1"
Option "AccelerationScheme" "none"
Option "AccelSpeed" "-1"
EndSection
Then save the file (to save the file in Nano, use Ctrl + o, then press Enter; to exit, use Ctrl + x). Note that the section just needs an identifier, but the actual name doesn't matter, so you don't have to replace "My Mouse" with anything.

Once you're done, restart the session (logout/login). That's it!

Using this, the Touchpad acceleration is left unchanged.

http://www.webupd8.org/2016/08/how-to-c ... mouse.html

Flandango
Core Developer
Posts: 388
Joined: Wed May 26, 2021 9:35 pm
Has thanked: 41 times
Been thanked: 328 times

Re: Centipede Speed Up request

Unread post by Flandango »

Mouse acceleration is usually handled by the window/desktop manager (Xorg, Gnome, etc...) , which Mister doesn't use.
I could be wrong since it's been ages that I dealt with it, but Linux, at the driver level doesn't do mouse acceleration.
DPI/sensitivity of course is a whole other thing.

Post Reply