1. Do not share user accounts! Any account that is shared by another person will be blocked and closed. This means: we will close not only the account that is shared, but also the main account of the user who uses another person's account. We have the ability to detect account sharing, so please do not try to cheat the system. This action will take place on 04/18/2023. Read all forum rules.
    Dismiss Notice
  2. For downloading SimTools plugins you need a Download Package. Get it with virtual coins that you receive for forum activity or Buy Download Package - We have a zero Spam tolerance so read our forum rules first.

    Buy Now a Download Plan!
  3. Do not try to cheat our system and do not post an unnecessary amount of useless posts only to earn credits here. We have a zero spam tolerance policy and this will cause a ban of your user account. Otherwise we wish you a pleasant stay here! Read the forum rules
  4. We have a few rules which you need to read and accept before posting anything here! Following these rules will keep the forum clean and your stay pleasant. Do not follow these rules can lead to permanent exclusion from this website: Read the forum rules.
    Are you a company? Read our company rules

FlyPT Mover 3.5.3

Discussion in 'FlyPt Mover' started by pmvcda, May 30, 2019.

  1. hexpod

    hexpod http://heXpod.xyz

    Joined:
    Apr 18, 2016
    Messages:
    1,207
    Location:
    berlin
    Balance:
    7,770Coins
    Ratings:
    +375 / 5 / -0
    My Motion Simulator:
    DC motor, 6DOF
    12CD9C02-AF5F-4A5C-8264-700475DA7632.jpeg

    I would love to see as an addition to this list the 2nd and 3rd order of EMA for HP or at least for LP like you did in “flypt hexapod”
  2. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    What you see there is the basic commands.
    Now you can compose it however you want:

    Sem nome.jpg

    Here's a 3rd order with the first has a high pass.
    You can now make 7th order if you want to. And you can change the number of samples used in each filter.
    You can even use a number of samples that depend on the value received.
    You can now make the most crazy filter on your mind.
    For example add a low pass and a high pass and in the end make a logistic (see sequence text result on the control):

    Sem nome.jpg
    That TRANSLATION could be called ADD. Idea is to translate the signal by adding or subtracting a value.
    Like GAIN could be MULTIPLY.

    All the gains and ranges specified on the interface are there just for help and trying to simplify the use of the interface for those that don't want to go deep.
    On the background, what the program does is to add those parameters as filters to the filter you specify in that field, so all the input signal is treated as a filter from start to end.
    So the end filter text will have a CROP to the range and input and output GAIN.
    This is the change that took more time...
    • Winner Winner x 2
    • Like Like x 1
  3. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    Calculation loop time/precision.

    In the bellow picture, you can see the CPU usage when using the high precision loop:
    hp1.jpg
    Here, CPU usage in my PC can go up to 20%, but we can achieve a really stable and precise loop time.
    This is important for rigs that use high frequencies of data.
    The graphic shows how stable we get the value (here for a selection of 10.0 ms).

    But if the high CPU usage is a problem, then go with the low resolution:
    lp.jpg
    CPU goes down to around 5% in this example.
    But precision is on steps of 1 ms and with an error of 1 ms.
    For rigs that receive data at 10 ms interval this is enough.


    High precision timer allows for even lower calculation rates.
    In my system, I can make a complete calculation loop in less than a 0,1 ms, keeping the value stable.
    Bellow an example with 0.8 ms calculation loop (vertical scale increased):
    hp2.jpg

    The graphic here introduces more CPU usage, so while using Mover in a game, and after setting up everything, just hide all windows to get the best performance.
    Varying the loop time, changes the filters behaviour. So sharing data between users, requires that they are able to use the selected setup for loop time in their system.

    More soon...
    • Like Like x 3
  4. robjos1

    robjos1 Member

    Joined:
    Jun 17, 2018
    Messages:
    51
    Occupation:
    Flying about
    Location:
    United Kingdom
    Balance:
    30Coins
    Ratings:
    +41 / 0 / -0
    My Motion Simulator:
    6DOF
    Excellent work as ever. Is it possible to assign a thread/complete workload to a specific CPU core to spread the work if you have a cpu with many cores?
  5. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    Thank's,

    Some more days and you can test it.
    I'm making it use the minimum possible cores/threads. We want all we can for the games/sims.
    I think it's really lightweight right now.
    There's no big advantage in making code run parallel. We need data from one module to use in the next one, and in reality, there are not many situations where you have more than one module of the same type (and they are really light).

    Can still optimise some parts of the code to be even faster. But let's keep it for the future. There's no big impact.

    On my test's I think it's running OK. But I'm sure that when I release it, there must be something...

    Right now there's only two threads, the interface with the user and the calculation.
    In graphics it's possible to see the load of each one in milliseconds per loop. It's easy to reach 100 ms in the interface, but we just want it to have an easy way of setting the calculation thread.

    Right now I'm finalising the soft start/stop and missing some images and touches for new rigs.
    Also need to review some new sources I might add. They are not finalised (Dirt 2.0, Roller coaster ad XPlane) .

    Also some new outputs to memory mapped file and UDP:
    Sem nome.jpg

    Just some more days.
    • Like Like x 2
    • Winner Winner x 1
  6. baykah

    baykah Active Member

    Joined:
    Sep 1, 2016
    Messages:
    137
    Location:
    Toulouse - France
    Balance:
    414Coins
    Ratings:
    +133 / 0 / -0
    My Motion Simulator:
    6DOF
    Hello,

    Any news ?

    I'm kind of waiting the next stable version to try seting up my rig with your software
  7. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    Yes, almost there!
    One more week maximum.

    It's a big internal change! New sources, rigs, features...
    Forward kinematics have to wait for next update. Having some problems there. But I think it will work.
    Way faster. In my laptop, with my rig, I can make everything work under 1 millisecond.

    Still some small bugs and little things I need to solve before release.

    Sorry for the delay.

    Here's a screenshot:

    Sem nome.jpg

    I'm working on the program right now.
    I was testing graphics on the suspension module.
    • Winner Winner x 3
    • Like Like x 2
  8. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    Running on the laptop:
    Sem nome.jpg

    Look at the cursor on the graphics.
    Sem nome.jpg

    Pointing at the peaks on calculation loop. It's 0.033 milliseconds.
    So right now I'm happy with the results.
    • Like Like x 2
    • Winner Winner x 2
  9. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    Some tuning on the soft start stop:

    Sem nome.jpg

    Also testing some of the new sources.
    Need to go through all to make directions all the same.

    Anyone knows the units used by F1 2019 / Codemasters games on the suspension travel/speed/acceleration?
    They seem strange...
    • Winner Winner x 1
  10. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    A video with some tests I'm making...



    Shows the new filter system.
    • Like Like x 4
    • Winner Winner x 2
  11. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    XPlane will come with two sources (like DCS):

    Sem nome.jpg

    One when grounded and another one when in the air.

    Why?
    You receive data only in one, then generate different poses with different filters for each one (with your preferences).
    In the rig definition we add both poses and the rig uses them sum of the two.

    Sem nome.jpg

    That way, you can define different filters for ground or air.

    New version tomorrow!
    • Like Like x 6
  12. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    FlyPT MOVER 2.0

    Mover2.jpg


    Many changes, to much time to make the release, and it's not perfect...
    Bu I said I would release it today. So let's test and see how it goes.

    ALERT!
    The new version causes sudden changes each time we change the filter. Be aware of that!
    I will try to implement a soft transition, but it's not an easy task.


    General changes
    -Big internal changes in threads.
    Hope we now have a stable code.
    We can now define the calculation loop frequency in the main menu options.
    See explanation there and use the most appropriate method for you.
    Changing the frequency, changes the filters behaviour. So keep that in mind.
    -New advanced filtering system.
    Allows the definition of complex filters with different values for all of them.
    That's the cause of the above alert. Be careful.

    Sources
    -Now we have 3 new values. They are the linear accelerations with gravity.
    So no more option to use gravity.
    -New sources:
    Sources.jpg
    -Directions are not the same for all sources. Please report the ones that are different.
    You can change it in the poses by using negative gains.

    Poses
    -Implemented the new filters.
    -In pose from motion, rollover is active when you select rotations positions.

    Rigs
    -Added more 3DOF rigs.
    rigs.jpg
    Now with 3 linear actuators and 3 rotating actuators.
    -New images with the actuators positions.
    -Now we define for each actuator what is the default position.
    This is used in soft start stop. Each time you connect to the hardware, the actuators transition from the default position to the calculated one.
    Opposite happens if you disconnect.

    Outputs
    -Now we can also send info by memory mapped files and UDP besides serial.
    So now we have 3 types of output modules.
    -We now have soft start/stop.
    When you connect to the hardware, Mover makes a transition from the default position of the actuators (defined in the rig module) to the currently calculated position.
    The time taken on the transition is defined in the main menu "Options".
    -Interval, is now Interval loops.
    The change here is that you are not defining time between each send to the output.
    You are defining the number of calculation loops made between each send.
    So if you have a calculation loop of 2 ms and want to sente data at 10 ms, put here a value of 5.
    That's 5 calculation loops at 2 ms each before each output.
    There's no reason to send the same data multiple times, and that way we are synchronised with calculations.

    3D Viewers
    -Enhanced visual representation of linear actuators.
    -Disabled thin lines that showed the calculated position/last possible position.
    Now actuators just turn red.
    -Representation for new rigs

    Graphics viewer
    -More stable. Info shown is properly scaled.
    -If the interface as a low update time because of load, we start seeing bars. The reason is because we had no time to update the info there.
    Those bars should have the width of the time for each interface update time.
    -More info available in each module.
    -Can now make a graph for interface and calculation loop times.
    -Cursor showing value and at how much time was the value we are seeing.
    -Vertical and horizontal scale.
    Changing scale, makes the old values fade, because those values had different scales.
    Changing scales doesn't change the values already shown in the window.
    -Each time a grey bar appears, it's because the graphic was not update in that space of time or some changes where made in that period (like change scale).


    There's so much more, specially in the internals...
    Need to change guide info for this version and include info on how to config the sources.
    Any question, jus ask. I will be around.

    Go to the first post for download!
    • Winner Winner x 5
    • Like Like x 1
    Last edited: Sep 20, 2019
  13. JAD

    JAD Active Member

    Joined:
    Jan 17, 2016
    Messages:
    205
    Location:
    Australia
    Balance:
    1,446Coins
    Ratings:
    +142 / 3 / -0
    I wake up Saturday morning to find this!
    Now I know what Im doing all weekend.
    Fantastic Work! Well Done!
    I'll give it a good run from a newbie's perspective. I'll let you know how it goes.
  14. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    Thank's.
    There are some problems with some wrong values in sources. (codemaster games)
    I will correct that with a new build tomorrow.
    There might be other errors... Could not test all situations.
    It's 01:00 here and I'm a bit tired. If I start anything, it's just to cause more problems.
  15. hexpod

    hexpod http://heXpod.xyz

    Joined:
    Apr 18, 2016
    Messages:
    1,207
    Location:
    berlin
    Balance:
    7,770Coins
    Ratings:
    +375 / 5 / -0
    My Motion Simulator:
    DC motor, 6DOF
    Not getting values from xplane

    Is your port 4123 ?
  16. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    Yes. Do you use 127.0.0.1 in the IP?
    This is my settings in XPlane:

    Sem nome.jpg

    Checked network via UDP in:
    #3 Speeds
    #17 Pitch, roll and headings
    #37 Engine rpm
    #137 Gear forces
    #135 Motion platform stats

    You need to check those, specially gear forces to get data.
    I have to make a guide for each source.
  17. benmax

    benmax Active Member Gold Contributor

    Joined:
    Oct 15, 2013
    Messages:
    188
    Balance:
    1,552Coins
    Ratings:
    +59 / 0 / -0
    My Motion Simulator:
    2DOF
    Hello,
    First Thanks for your fantastic job !
    For assetto corsa you have for plugin input UDP communication ( I’m noob for this ) . In your other sw you use MMF plugin ? In fact I don’t really know how to setup this . I used your direct plugin with UDP and it doesn’t work or could you tell me how to setup ?
    Thx
  18. pmvcda

    pmvcda aka FlyPT

    Joined:
    Nov 3, 2010
    Messages:
    2,192
    Location:
    Portugal
    Balance:
    15,448Coins
    Ratings:
    +2,624 / 17 / -0
    My Motion Simulator:
    6DOF
    Ouch!
    I was working on the UDP version. And I activated the wrong one...
    MMF is there, but hidden :oops:
    UDP is not working yet. I will post a new version with this corrected.
    Give me some minutes.

    UDP is a network protocol. The advantage is that with UDP you can run the game in a remote PC and send data through network to the PC with FlyPT Mover.
    MMF is like a file but in memory. The game updates that file with the data and we read the data from there. It works only in the same PC, but it's the fastest one when we are on the same machine (game and Mover).
    If we are using a console, then we need UDP. But I don't know if any of the sources I have is compatible with data output from consoles...
  19. hexpod

    hexpod http://heXpod.xyz

    Joined:
    Apr 18, 2016
    Messages:
    1,207
    Location:
    berlin
    Balance:
    7,770Coins
    Ratings:
    +375 / 5 / -0
    My Motion Simulator:
    DC motor, 6DOF
    Should I see the values moving with this config ?
    5886CB76-BC33-4AF3-9BF7-330476981B32.jpeg
  20. hexpod

    hexpod http://heXpod.xyz

    Joined:
    Apr 18, 2016
    Messages:
    1,207
    Location:
    berlin
    Balance:
    7,770Coins
    Ratings:
    +375 / 5 / -0
    My Motion Simulator:
    DC motor, 6DOF
    Aha I got some if I check Nr. 17

    Is it normal that if you don’t check the 17 there is nothing going in ?