• We have updated our Community Code of Conduct. Please read through the new rules for the forum that are an integral part of Paradox Interactive’s User Agreement.

Stellaris Dev Diary #372 - Modding: Pop Groups and Jobs

Hi everyone!

This week, @Gruntsatwork will discuss the technical details of pop group scripting. This topic is likely to be of most interest to the modding community.

The systems we’re implementing now are just scratching the surface of where we want to go with them - we’re looking forward to some of the things we’ll be able to do with these tools over the next few years as well as seeing what you do with them.

As with all of these dev diaries, some of this is still subject to change during implementation and during the beta.

Pop Groups and Jobs​

Hello everyone, @Gruntsatwork here! Let us talk about some of the script changes that are coming with 4.0 when it comes to pops and jobs…

As Eladrin already mentioned in Dev Diary 370, we are changing the way we look at Pops by grouping them together into Pop Groups. These groups are defined by their species, traits, ethics, and factions but NOT their jobs. It is entirely possible and likely for a pop group to have pops working different jobs.

The goal is that for most purposes in the game, you will reference pop groups instead of pops, which should hopefully save us from iterating through every single pop in our empire whenever a modifier needs to be re-calculated.

This allows us to tone down or remove some of the most performance-intensive actions we used before and replace them with far more performance-friendly variations instead.

For example, that means that both “random_owned_pop” or “any_owned_pop” have been relegated to the dark corners of history and replaced with “random_owned_pop_group” and “any_owned_pop_group”.

The same holds true for many of the effects used on those pops, like create_pop or kill_pop, or move_pop. Going forward, we will now create, move and kill pop groups, either in their entirety or through percentages. And for the eagle-eyed among you, YES, that means you no longer have to loop through singular pops to do unspeakable things to them, you can nicely target their pop group and let it do the math for you.

Thanks to the tireless efforts of our programmers, who have given us some new functionality for scripted triggers like comparators, other old tools, like num_pops, will see a resurgence as a scripted trigger. We expect the modding folks to find a lot of use in that, even as we slightly dread what you will come up with.

As also mentioned by Eladrin, this means we no longer have a constant contact between pops and their job.

Instead, there is a single moment of assignment when the pop group briefly knows which job it is supplying and with how much workforce. From then on, the job only knows that it has been supplied with workforce and thus must produce the associated resource. As long as the assignment stands, we have no need to check on the pop again.

This brings us to one of our biggest changes: removing all production modifiers on species traits and replacing them with bonus workforce. Simply put, because the workforce assigned to a job does not know which species it came from during most checks, production bonuses from species (modifiers like +10% Research from Jobs from the Psionic trait) cannot be applied. Instead, species traits now provide modifiers like “+10% Bonus Workforce for Researcher Jobs”, which means 100 Psionic Pops working 100 Physicist jobs will have the job upkeep and output of 110 Physicist jobs. In other words, we only pay upkeep on 100 Pops, but we get the output of 110 Researchers! This also has the side effect of the modifiers for job output from species traits are now multiplicative with other modifiers.

As an example, in 3.14 if we had 1 Psionic (+10% Research from Jobs) Pop working a Researcher job in an empire with the Meritocracy civic (+10% Specialist Job Output) on a Relic world with a Central Spire (+15% Research from Jobs), the total output would be 3 × (1 + 0.1 + 0.1 + 0.15) = 3 × 1.35 = 4.05 of each type of research.

In 4.0 if we have 100 Psionic (+10% Bonus Workforce for Researcher Jobs) Pops working 100 Physics jobs in an empire with the Meritocracy civic (+10% Specialist Job Output) on a Relic world with a Central Spire (+15% Research from Jobs), the total output would be 3 × (1 + 0.1) × (1 + 0.1 + 0.15) = 3 × 1.1 × 1.25 = 4.125 physics research.

This brings us beautiful new script entries like this one from the Psionic trait:
A sample of a job that he really made as bad as possible.

It doesn’t have to be like this. But it can be. Grunts made his choice. - E
This is perfectly serviceable - G
I have hopes to refactor this - AS

As a side note, some checks can still query a pop’s job, but only indirectly, by scoping to a job and determining which pop group is filling it. This means we can still ensure functionality for Death Cults and similar targeted kill_pop effects.

In contrast, production bonuses on the planet or the empire are still available since they simply affect everyone.

So for species traits, we encourage the use of these new modifiers

pop_job_bonus_workforce_mult
To increase the bonus workforce a pop generates for a given job.

pop_job_workforce_mult
To increase the workforce a pop generates for a given job, this is not bonus workforce.

job_max_workforce_mult
To increase the maximum workforce a Job can accept

As a reminder, a job's workforce will fill to its maximum allowed but not beyond that. If a pop generates more workforce than usual, fewer pops will be required to fill the job to max, but it will not produce more than its maximum. If a pop generates a bonus workforce, it can go beyond the job's maximum and scale its production up.

In addition, we have also split quite a few of our economic categories that depended on triggered checks of species traits. This also includes the use of triggers to fake an inheritance of economic classes, which we have removed in many cases and only left in the ones we deemed the most reliant on them.

For inheritance, we recommend the normal parent-child structure of economic categories OR, to use static_modifiers to grant the modifiers of any combination of economic_categories.

Most, if not all, of these changes were made to improve performance: reducing calls, loops, and modifier cascades that would otherwise trigger recalculations across every planet and pop in your empire, just in case a deficit check was needed at that moment.

Looking ahead, we see great potential in workforce mechanics, both for us and the modding community. We've hinted at automation – workforce decoupled from pops – and some of you may have already considered new applications for Virtuality. Who knows what other, more extreme variations in the type and number of pops empires require might now be possible?

Simply put, we now have the workforce to power Stellaris for years to come. Pun very much intended.

What’s Next?​

Our planned livestream is going to be delayed a bit, and will likely end up being alongside the Open Beta. Right now our primary focus is on implementation.

Next week we’ll have some more updates on how things have been going.
 
  • 65Like
  • 21
  • 10Love
  • 3
  • 2Haha
  • 2
Reactions:
How does this new system represent people in unlimited jobs?

E.g. space elves chained up in my pleasure-dungeon -- er, I mean, Domestic Servants.


Or people who don't have a job / don't work as such?

E.g. UA unemployed, or maybe FE Hedonists.

I see no reason why you couldn't create a job with no maximum workforce cap (or an unreachable one).

I personally think all the "unlimited" jobs should be in the strata for ordinary residents and citizens; otherwise those pops won't be available for automatic resettlement.
Pops themseleves can still provide yields just from their Stratum alone.

As I understand it, Civilians are like Clerks - except they can migrate and will upgrade to better jobs at every opportunity.
And I see no reason Domestic Servants could not be capped like Civilians. Or even be a subtype of Civilian.

Civilians are overflow storage for unused pops.
 
Civilians are overflow storage for unused pops.
Not only. The design described by the developers suggested that they also produce Trade Value, effectively making them a new version of "Clerks".
 
I still dont get why they want to emigrate comapered to others.
With the unemployed pops it is clear. and when a planet is more suitable - sure.
But why would the civilians want to emigrate en mass?
 
Not only. The design described by the developers suggested that they also produce Trade Value, effectively making them a new version of "Clerks".
Clerks that are so low value, you want them to take proper jobs.

I still dont get why they want to emigrate comapered to others.
With the unemployed pops it is clear. and when a planet is more suitable - sure.
But why would the civilians want to emigrate en mass?
Citizen is a state just barely above unemployed. "Well managed unemployed" basically?
They will take any job over Citzen. Even if they have to move to a new planet to get to it.
 
I still dont get why they want to emigrate comapered to others.
With the unemployed pops it is clear. and when a planet is more suitable - sure.
But why would the civilians want to emigrate en mass?
I'm wondering if we're looking at it backwards. It's not that the government employees want to emigrate less than the civilians, it's that if you're already working in the government run crystal mines then your emigration visa keeps running into "paperwork problems".
 
My understanding is that civillians *are* the unemployed masses - as opposed to the undesirable and unwanted scum you're pushing out or purging. (Like the entire Blorg species.)
 
My understanding is that civillians *are* the unemployed masses - as opposed to the undesirable and unwanted scum you're pushing out or purging. (Like the entire Blorg species.)
I would describe them as "well managed unemployed".

With good living standarts they can probably still give decent yields - but they can do the same and work a job on the next planet over.
 
My understanding is that civillians *are* the unemployed masses - as opposed to the undesirable and unwanted scum you're pushing out or purging. (Like the entire Blorg species.)
My understanding is that civilians are restraint workers, self-employed individuals, people with personal farms or those who custom make goodies to sell on space Esti. They work as janitors, cooks, and probably in 'doc in the box' type facilities. my understanding is that if every job in the universe was displayed, they'd be on the bottom rung of the worker stratum but produce nothing worth simulating. That's why they produce trade, and that is why they can afford to pay for a ticket to that new colony. Everyone else is two desperate to migrate at levels worth representing.

Unless you think there isn't a single hospital until you've researched 'medical workers' or that no one person has a job making custom 3d printed nick knacks or making informative SpaceTube videos on how hyperdrives work. Those jobs are still employed people. In 4.0 those people would be 'civilians'.
 
I have slightly different understanding, that is simple government job vs not. Wither that be welfare recipients or the ceo+people who work there of a company that makes widgets.
 
I still dont get why they want to emigrate comapered to others.
With the unemployed pops it is clear. and when a planet is more suitable - sure.
But why would the civilians want to emigrate en mass?
In "nice" empires i imagine it works just the same way how europe managed to get their population to mass emigrate to the colonies: Propaganda campaign + you get free land & other benefits, thats a good deal for anyone who's not super happy about their current situation.

In "evil" empires the pathetic servs are going to heel wether they like it or not! Go mine some rocks over there.
 
  • 2
Reactions:
I'm wondering if we're looking at it backwards. It's not that the government employees want to emigrate less than the civilians, it's that if you're already working in the government run crystal mines then your emigration visa keeps running into "paperwork problems".
This is only true for Societies/Empire that would do such things in the first place.
Event the notion that the mines are run by the goverment is/should not be true for all of the different ethics/empires/societies tbh.

My understanding is that civilians are restraint workers, self-employed individuals, people with personal farms or those who custom make goodies to sell on space Esti. They work as janitors, cooks, and probably in 'doc in the box' type facilities. my understanding is that if every job in the universe was displayed, they'd be on the bottom rung of the worker stratum but produce nothing worth simulating. That's why they produce trade, and that is why they can afford to pay for a ticket to that new colony. Everyone else is two desperate to migrate at levels worth representing.

Unless you think there isn't a single hospital until you've researched 'medical workers' or that no one person has a job making custom 3d printed nick knacks or making informative SpaceTube videos on how hyperdrives work. Those jobs are still employed people. In 4.0 those people would be 'civilians'.
But why do they add to stability then? Those "lowlevel" strata dont tend to be the most satisfied ones - esp. when occuring in large relative numbers.


For me all of this just does not add up tbh.
 
But why do they add to stability then? Those "lowlevel" strata dont tend to be the most satisfied ones - esp. when occuring in large relative numbers.
Who says they add stability?
All I got is that they don't tank your stability. Which is very far from "they make things more stable".
 
But why do they add to stability then? Those "lowlevel" strata dont tend to be the most satisfied ones - esp. when occuring in large relative numbers.


For me all of this just does not add up tbh.
Who says they add stability?
All I got is that they don't tank your stability. Which is very far from "they make things more stable".
Also, it makes for a better gaming experience. I mean, the mechanical goal is to have a pull of people who will migrate to newly colonized planets over time. To do that, you need a pull--of possibly thousands--of civilians hanging around for the opportunity to move. Jobs don't open instantly, and low population planets have been said to have extremely slow growth otherwise. So based on this, it cannot be a bad thing to have. Having players thinking its sub optimal to maintain large groups of civilians would be extremely bad for fun.

One of the bigger bonuses to the way they did this is that it acts as a model for the 'civilian economy' that is implied by the 'internal market.' For the market to make any kind of sense, there must be sources of all the resources other than those built by you the player. This is also represented by the civilians producing trade. Which also encourages you to maintain a 'civilian population' that reflects your vision. Those who want a lot more flexibility can do it through civilians--and the market--and also makes things a lot easier when you want to jump into a big expansion.

For those who want monthly incomes will run much smaller civilian populations. Getting new jobs up slower and especially new colonize. That might actually push you towards conquest to handle growth.

If it works as well as suggested, I suspect a lot more differences in development. Especially if buildings like commune housing increase civilian capacity.
 
  • 1Like
Reactions:
Also, it makes for a better gaming experience. I mean, the mechanical goal is to have a pull of people who will migrate to newly colonized planets over time. To do that, you need a pull--of possibly thousands--of civilians hanging around for the opportunity to move.
Above I called Citizens "overflow pop storage" or "well managed unemployed".
Part 5 Indicates that Citizen/Civilian Capacity will be based on City districts, with bonus for the Empire Capital.
I guess population beyond that limit will get uggly.
 
Above I called Citizens "overflow pop storage" or "well managed unemployed".
Part 5 Indicates that Citizen/Civilian Capacity will be based on City districts, with bonus for the Empire Capital.
I guess population beyond that limit will get uggly.
Just build another tenement block Hive City and it'll be fine. :D
 
Above I called Citizens "overflow pop storage" or "well managed unemployed".
Part 5 Indicates that Citizen/Civilian Capacity will be based on City districts, with bonus for the Empire Capital.
I guess population beyond that limit will get uggly.
Something like that. except they can't be totally unemployed because the population produces trade. Though less with shitter living standards.
 
I'm not sure if this should be put in as a bug report or something because I think this was a simple mistake. I recently discovered when adding some higher resolution images for cover art for a mod that the cover art image of the origin for Prosperous Unification has the wrong setup in the text file pointing at something that isn't the origin art but rather the event art instead. Meaning that the file for the art isn't being used and correcting it in a mod makes the game non achievement compatible.

Its currently set

picture = GFX_evt_metropolis

which directs it to the wrong picture where as

picture = GFX_origin_default

would direct it to use the correct image

1741048384330.png
 
I'm wondering if we're looking at it backwards. It's not that the government employees want to emigrate less than the civilians, it's that if you're already working in the government run crystal mines then your emigration visa keeps running into "paperwork problems".

I would describe them as "well managed unemployed".

With good living standarts they can probably still give decent yields - but they can do the same and work a job on the next planet over.
You know, this problem was solved in victoria, by introducing living standars and wealth levels.

What we have with pop strata is the scaled down version of it in Stellaris. I would prefer it to stay like that, because for a game with a focus like stellaris, detailed wealth levels is perhaps too much, espeically with all the performance issues and all the other game layers on top of colonies.

So why do civilians move? For a better tomorrow!
 
I'm not sure if this should be put in as a bug report or something because I think this was a simple mistake. I recently discovered when adding some higher resolution images for cover art for a mod that the cover art image of the origin for Prosperous Unification has the wrong setup in the text file pointing at something that isn't the origin art but rather the event art instead. Meaning that the file for the art isn't being used and correcting it in a mod makes the game non achievement compatible.

Its currently set

picture = GFX_evt_metropolis

which directs it to the wrong picture where as

picture = GFX_origin_default

would direct it to use the correct image

View attachment 1260979
Tthis is 1000% in the wrong place man, put it in the bug report forum.
 
  • 4
Reactions:
This is only true for Societies/Empire that would do such things in the first place.
It were a jape.
Event the notion that the mines are run by the goverment is/should not be true for all of the different ethics/empires/societies tbh.
Mines operated by non-government (or not-directly-owned-by-your-megacorp) industries where the minerals all go into your empire stockpile anyway are functionally identical to government run mines apart from flavour. It's entirely up to you which you choose to be the way your mines are "really" functioning. Though a civic leaning into this could be neat.

Entirely privately operated mining operations where you do not get handed the minerals will be represented by you building cities instead of mines, meaning more civilians, some of whom are "working in privately owned mines" and paying you taxes in the form of trade, which the government/megacorp then uses to buy minerals from the market.
But why do they add to stability then?
They don't.
Dev Diary #370 said:
Unemployed Pops will still exist and downgrade through the strata, with unemployed Worker stratum Pops demoting to Civilians over time. This will have an impact on stability, as Civilians are largely content and non-disruptive.
This doesn't mean civilians usually add to stability. It means that civilians usually do not reduce stability, while unemployed pops in the process of moving to civilian life usually do.

Presumably there will be living standards and civics that cause civilians to impact stability for good or bad, but according to the dev diary your default civilian is just kinda OK with life, no more and no less.
 
Last edited:
  • 3
Reactions: