New api in a OOP language?

Ideas that are too old (too many things have changed since) and ones which won't be implemented for certain reasons or if there are obviously better suggestions.

Moderator: ickputzdirwech

Bilka
Factorio Staff
Factorio Staff
Posts: 3311
Joined: Sat Aug 13, 2016 9:20 am
Contact:

Re: New api in a OOP language?

Post by Bilka »

yagaodirac wrote: Tue Oct 13, 2020 11:20 am
Bilka wrote: Tue Oct 13, 2020 9:22 am You could use something like https://github.com/TypeScriptToLua/TypeScriptToLua to write code in non-Lua, there is at least one mod on the mod portal that was written this way.
Which mod?
https://github.com/TGNThump/AbandonedRuins

(Just to be clear, this is a possibility, not a recommendation.)
I'm an admin over at https://wiki.factorio.com. Feel free to contact me if there's anything wrong (or right) with it.
User avatar
eradicator
Smart Inserter
Smart Inserter
Posts: 5211
Joined: Tue Jul 12, 2016 9:03 am
Contact:

Re: New api in a OOP language?

Post by eradicator »

yagaodirac wrote: Tue Oct 13, 2020 5:05 am Days ago, someone asked that does ue4 support python. After searching, I found ue4 supports python through a plugin.
So, is it possible to enable factorio to support js or py or anything else through a mod?
https://moonscript.org/ has similar syntax to python and compiles to lua.
Or maybe there's other compilers that can compile native python to lua?
Author of: Belt Planner, Hand Crank Generator, Screenshot Maker, /sudo and more.
Mod support languages: 日本語, Deutsch, English
My code in the post above is dedicated to the public domain under CC0.
yagaodirac
Fast Inserter
Fast Inserter
Posts: 152
Joined: Sun Jun 16, 2019 4:04 pm
Contact:

Re: New api in a OOP language?

Post by yagaodirac »

eradicator wrote: Wed Oct 14, 2020 12:47 am
yagaodirac wrote: Tue Oct 13, 2020 5:05 am Days ago, someone asked that does ue4 support python. After searching, I found ue4 supports python through a plugin.
So, is it possible to enable factorio to support js or py or anything else through a mod?
https://moonscript.org/ has similar syntax to python and compiles to lua.
Or maybe there's other compilers that can compile native python to lua?
I checked the web of moonscript. The last update was 5 years ago. Besides, I don't think the grammar is good enough. At least I'm not gonna give it a try.
yagaodirac
Fast Inserter
Fast Inserter
Posts: 152
Joined: Sun Jun 16, 2019 4:04 pm
Contact:

Re: New api in a OOP language?

Post by yagaodirac »

Bilka wrote: Tue Oct 13, 2020 11:57 am
yagaodirac wrote: Tue Oct 13, 2020 11:20 am
Bilka wrote: Tue Oct 13, 2020 9:22 am You could use something like https://github.com/TypeScriptToLua/TypeScriptToLua to write code in non-Lua, there is at least one mod on the mod portal that was written this way.
Which mod?
https://github.com/TGNThump/AbandonedRuins

(Just to be clear, this is a possibility, not a recommendation.)
Thanks.
yagaodirac
Fast Inserter
Fast Inserter
Posts: 152
Joined: Sun Jun 16, 2019 4:04 pm
Contact:

Re: New api in a OOP language?

Post by yagaodirac »

Bilka wrote: Tue Oct 13, 2020 11:57 am https://github.com/TGNThump/AbandonedRuins
Hi, emm, I think we misunderstood each other. I saw the lualib_bundle.lua file in that mod, but that lib is something like a std::vector. It's not what I care about.
Let's say, I'm gonna code a boss. I need to control the boss to move, shoot some projectile. Even in the very simplest case, the boss doesn't care where the players are, I need to be able to move the boss every tick. In ue4 or unity, all I need to do is that, override the AActor::tick(float) or the prefeb::update(float) respectively. It would look like
class boss: public AActor
{public:
void tick(float delta_time)
{
if (pos.x<100) pos.x+=5;else pos.x-= 5;//emmm, ok, please don't mind.
if (tick%30 == 0)shoot();
}
void shoot(){some code here.}
}
That's all. That's finished. Besides, I need a projectile class
class projectile: public AActor
{public:
void tick(float delta_time)
{
pos.y+=30;
}
}

But for now, in factorio api, I can't do this. And this is the critical reason that now a days factorio mods, scenarios are generally lack of entity movement control.
Normally people code in ue4 or unity don't rely on stl or boost. But they do rely on the infrastructure provided by the engine.
Would you official developers like to provide some framework, or should I do it myself?
blazespinnaker
Filter Inserter
Filter Inserter
Posts: 665
Joined: Wed Sep 16, 2020 12:45 pm
Contact:

Re: New api in a OOP language?

Post by blazespinnaker »

What mods are using Lua threads for doing things?.
Any mod that wishes to take advantage of multiple cores for performance reasons, I imagine. Kind of important these days

factorio is not a browser app that is meant to be restricted to have only a tiny slice of the cpu.
OptimaUPS Mod, pm for info.
posila
Factorio Staff
Factorio Staff
Posts: 5431
Joined: Thu Jun 11, 2015 1:35 pm
Contact:

Re: New api in a OOP language?

Post by posila »

yagaodirac wrote: Wed Oct 14, 2020 2:51 amHi, emm, I think we misunderstood each other. I saw the lualib_bundle.lua file in that mod, but that lib is something like a std::vector. It's not what I care about.
As I said before, you are confusing language (C++'s std::vector is part of C++, but ue4's AActor is not) with engine/API architecture. What you want has nothing to do with a programming language or programming paradigm (like OOP), and everything to do with how the game and its API is architected. And that is not going to change.
User avatar
ssilk
Global Moderator
Global Moderator
Posts: 12889
Joined: Tue Apr 16, 2013 10:35 pm
Contact:

Re: New api in a OOP language?

Post by ssilk »

blazespinnaker wrote: Wed Oct 14, 2020 3:22 am
What mods are using Lua threads for doing things?.
Any mod that wishes to take advantage of multiple cores for performance reasons, I imagine. Kind of important these days
I doubt mods ever become multithreaded. Some suggestions/discussions already about that. There are simple reasons for that.

I think the simplest way to explain it is, that only one process at any time can be enabled to modify the world.

And it really doesn’t matter. Very much cpu power gets lost in the api itself. Converting things, check mistakes etc. the more CPU’s a mod will have, the more it can use the API and the more CPU is used on top.

But for pure calculations in a mod, more power to calculate complex things this would be really nice and a factor of up to 100 is a thing, that really can change mod abilities...
Cool suggestion: Eatable MOUSE-pointers.
Have you used the Advanced Search today?
Need help, question? FAQ - Wiki - Forum help
I still like small signatures...
User avatar
Klonan
Factorio Staff
Factorio Staff
Posts: 5328
Joined: Sun Jan 11, 2015 2:09 pm
Contact:

Re: New api in a OOP language?

Post by Klonan »

yagaodirac wrote: Wed Oct 14, 2020 2:51 am But for now, in factorio api, I can't do this. And this is the critical reason that now a days factorio mods, scenarios are generally lack of entity movement control.
Normally people code in ue4 or unity don't rely on stl or boost. But they do rely on the infrastructure provided by the engine.
Would you official developers like to provide some framework, or should I do it myself?
Its trivially easy to do this using an on_tick event to just loop through all your entities.

The reason why mods don't do it, is because controlling things each tick with script is bad for performance.
No matter how the Lua script is called, either by some internal function override, or by calling it on tick, it is still going to be slow.

Factorio isn't a typical game. You can make 1 of your boss units, and it will be fine.
But in Factorio, scale beats everything. People will expand the map and have 10,000 of your boss units,
Or place 200,000 of your custom solar panels, etc.
Qon
Smart Inserter
Smart Inserter
Posts: 2164
Joined: Thu Mar 17, 2016 6:27 am
Contact:

Re: New api in a OOP language?

Post by Qon »

blazespinnaker wrote: Wed Oct 14, 2020 3:22 am
What mods are using Lua threads for doing things?.
Any mod that wishes to take advantage of multiple cores for performance reasons, I imagine. Kind of important these days

factorio is not a browser app that is meant to be restricted to have only a tiny slice of the cpu.
Not a single mod has ever used Lua threads, and even more definitly has it ever been used to increase performance. And never will. JS is also faster singlethreaded than Lua multithreaded so good riddance if we lose Lua and Lua threads in favor of getting a real and fast language like JS.
My mods: Capsule Ammo | HandyHands - Automatic handcrafting | ChunkyChunks - Configurable Gridlines
Some other creations: Combinassembly Language GitHub w instructions and link to run it in your browser | 0~drain Laser
User avatar
Klonan
Factorio Staff
Factorio Staff
Posts: 5328
Joined: Sun Jan 11, 2015 2:09 pm
Contact:

Re: New api in a OOP language?

Post by Klonan »

Qon wrote: Wed Oct 14, 2020 8:08 amJS is also faster singlethreaded than Lua multithreaded
Do you have a source for that?
Qon
Smart Inserter
Smart Inserter
Posts: 2164
Joined: Thu Mar 17, 2016 6:27 am
Contact:

Re: New api in a OOP language?

Post by Qon »

Klonan wrote: Wed Oct 14, 2020 8:15 am
Qon wrote: Wed Oct 14, 2020 8:08 amJS is also faster singlethreaded than Lua multithreaded
Do you have a source for that?
Has already been posted in this thread:
ssilk wrote: Tue Oct 13, 2020 3:55 am - js is really fast, I found benchmark which says up to hundred times https://benchmarksgame-team.pages.debia ... t/lua.html
I even doubt that any other pure script language is that fast.
Unless you think multithreaded programming in Lua can actually give any mods significant speedup to overcome that.

Any part of code that must run sequentially will of course limit the possible speedup that is possible (Amdahl's law).

For any writing API calls you would have to do that without breaking determinism. This might further limit the usefulness of Lua threads?

I don't know if the Factorio engine serve API calls to concurrent threads in parallel or sequentially. Multithreading might improve performance some anyways even if it doesn't run in parallel but it would also limit the potential for any speedup for mods with Lua threads if those are served sequentially.

So I'm saying that the gap is big enough that JS will be faster in general for pretty much all mods on the portal even with a very conservative estimate of JS being just a few times faster than Lua. Unless your implementation and modification of Lua is multiple orders of magnitude faster the Lua implementation that was benchmarked.

But I was trying to get balzaspinner to actually respond with an actual answer instead of the non-answer that I was given.
My mods: Capsule Ammo | HandyHands - Automatic handcrafting | ChunkyChunks - Configurable Gridlines
Some other creations: Combinassembly Language GitHub w instructions and link to run it in your browser | 0~drain Laser
yagaodirac
Fast Inserter
Fast Inserter
Posts: 152
Joined: Sun Jun 16, 2019 4:04 pm
Contact:

Re: New api in a OOP language?

Post by yagaodirac »

For all of you talking about the multiple thread thing. The problem is that, if you make something fast enough, you definitely benefit from a multi core cpu. But if you host a game with this thing, people would probably have a hard time linking into your game. So, any mods that are design to be able to handle multiplayer situation, should avoid the fastest way of implementation. You basically shouldn't push a 3.6 ghz 2-core cpu to 75% load or even higher.
In this case, keeping everything single threaded is a good idea.
yagaodirac
Fast Inserter
Fast Inserter
Posts: 152
Joined: Sun Jun 16, 2019 4:04 pm
Contact:

Re: New api in a OOP language?

Post by yagaodirac »

Klonan wrote: Wed Oct 14, 2020 8:04 am
yagaodirac wrote: Wed Oct 14, 2020 2:51 am But for now, in factorio api, I can't do this. And this is the critical reason that now a days factorio mods, scenarios are generally lack of entity movement control.
Normally people code in ue4 or unity don't rely on stl or boost. But they do rely on the infrastructure provided by the engine.
Would you official developers like to provide some framework, or should I do it myself?
Its trivially easy to do this using an on_tick event to just loop through all your entities.

The reason why mods don't do it, is because controlling things each tick with script is bad for performance.
No matter how the Lua script is called, either by some internal function override, or by calling it on tick, it is still going to be slow.

Factorio isn't a typical game. You can make 1 of your boss units, and it will be fine.
But in Factorio, scale beats everything. People will expand the map and have 10,000 of your boss units,
Or place 200,000 of your custom solar panels, etc.
I knew this method from the beginning. As I know, this is how the ue4 and unity update their entities. So, the conclusion is clear, I need to make this framework. Yeah, what you worried is very practical. I know I need to limit the amount. Actually very few game design is about a giant amount of entities. Ok, I'm not gonna dig any more in this topic. Thank you for your replies.
blazespinnaker
Filter Inserter
Filter Inserter
Posts: 665
Joined: Wed Sep 16, 2020 12:45 pm
Contact:

Re: New api in a OOP language?

Post by blazespinnaker »

well, you might be right. I'm not familiar with the mods, tbh. and, the factorio folks would have to use thread enabled lua, which they might not be.

another reason to use python, perhaps, which is pretty good at mt.

I am however rather skeptical of the benchmarking. THere's luajit, laua, etc. Lua can get very fast.
OptimaUPS Mod, pm for info.
Hornwitser
Fast Inserter
Fast Inserter
Posts: 214
Joined: Fri Oct 05, 2018 4:34 pm
Contact:

Re: New api in a OOP language?

Post by Hornwitser »

blazespinnaker wrote: Thu Oct 15, 2020 2:15 pm another reason to use python, perhaps, which is pretty good at mt.
Python is not good at multithreading. CPython, the defacto implementation of the Python interpreter, has a something called the Global Interpreter Lock (GIL). Whenever a thread is executing Python code it holds the GIL and prevents any other thread from executing any Python code.
yagaodirac
Fast Inserter
Fast Inserter
Posts: 152
Joined: Sun Jun 16, 2019 4:04 pm
Contact:

Re: New api in a OOP language?

Post by yagaodirac »

Klonan wrote: Wed Oct 14, 2020 8:15 am
Hi, sorry to disturb you again. I hear that you prevented lua in custom mod to call functions in any other code? Means that I can't write any cpp code and call it from control.lua or data.lua? Thanks.
Qon
Smart Inserter
Smart Inserter
Posts: 2164
Joined: Thu Mar 17, 2016 6:27 am
Contact:

Re: New api in a OOP language?

Post by Qon »

yagaodirac wrote: Sat Oct 17, 2020 6:50 am
Klonan wrote: Wed Oct 14, 2020 8:15 am
Hi, sorry to disturb you again. I hear that you prevented lua in custom mod to call functions in any other code? Means that I can't write any cpp code and call it from control.lua or data.lua? Thanks.
Dude are you a troll? This is the third time you ask this question. viewtopic.php?f=25&t=90446
My mods: Capsule Ammo | HandyHands - Automatic handcrafting | ChunkyChunks - Configurable Gridlines
Some other creations: Combinassembly Language GitHub w instructions and link to run it in your browser | 0~drain Laser
blazespinnaker
Filter Inserter
Filter Inserter
Posts: 665
Joined: Wed Sep 16, 2020 12:45 pm
Contact:

Re: New api in a OOP language?

Post by blazespinnaker »

Hornwitser wrote: Thu Oct 15, 2020 8:41 pm
blazespinnaker wrote: Thu Oct 15, 2020 2:15 pm another reason to use python, perhaps, which is pretty good at mt.
Python is not good at multithreading. CPython, the defacto implementation of the Python interpreter, has a something called the Global Interpreter Lock (GIL). Whenever a thread is executing Python code it holds the GIL and prevents any other thread from executing any Python code.
very right. multiprocessing ftw.
OptimaUPS Mod, pm for info.
Post Reply

Return to “Outdated/Not implemented”