• 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:
If pop groups are not grouped by jobs, how will that interact with jobs that change pop happiness ? For instance, in a dystopian society, enforcer have a different happiness from all other specialists.
How does the new system deal with that ?
 
  • 6
  • 2Like
Reactions:
beautiful new script entries
I hope this will not appear so cluttered on player facing UI.

From dev diary #370 we have
Now (4.0):
  • Instead of tracking individual Pops, we track Workforce filling Jobs.
  • Jobs are now filled by 10,000 Workforce (since Pops are scaled up by 100).
  • 8,000 Workforce comes from regular Pops, while 2,000 Workforce comes from the bonus-earning Pops.
    • The species bonus is now “10% bonus Workforce when working Alloy jobs” - those Pops contribute an extra 200 Workforce, making the total 10,200 Workforce. Bonus Workforce is allowed to go over the required Workforce for a job, yielding extra production.
  • If 100 Workforce still produces 6 Alloys, the planet still produces 612 Alloys - same output, different system.
Will job filling prioritize bonus providing pop_group, or are we forced to accept under-optimized randomness?
I mean given current gameplay experience, it appears far more likely to have more than enough workforce for any specific job category.
I also feel like there are tons of cool design choices here that could really amp up the gameplay vibe for players. Make it policy dependent, perhaps.
 
When it comes to stealing pops, how does that work now? Does it move a chunk of the pop group to another planet, or does it delete a chunk and create a new chunk on another planet?
 
Reading this made me so happy @o@

The sanity damage I've taken over the years of dealing with pops will probably never heal, but it seems that at least the conversion to the new system won't open any new wounds. Me, my therapist and my therapist's therapist are looking forward to this so much!
 
Last edited:
  • 4Haha
  • 1Like
  • 1
Reactions:
Emphasis mine. Does this count as a very slight nerf to the previously output-boosting traits (such as Psionic), as now we have to pay an additional upkeep cost for them which we didn't before?
(Don't get me wrong, though - I still think I prefer this new way, to the current/older one - and as your subsequent numbers demonstrate, it actually raises output even higher - but we as players WILL need to be aware of the upkeep implications)
It's a bit more than a slight nerf, but probably a good one. It means that a +XX% pop trait boost to alloy production isn't also effectively magicing minerals out of mid air which removes the "double dip" aspect that made them hard to balance, while +XX% to minerals is still exactly as good as it was before.

It also means negative pop traits are less harsh since it just means you need additional repugnant pops to fill your amenity-producing jobs rather than your amenity producing jobs always producing fewer amenities.

My concern is in the other direction. This would make any modifier that reduces the workforce needed for a job incredibly powerful since it would reduce the job upkeep similarly. Presumably the teased automation buildings won't actually reduce job workforce requirements but instead do something like provide 20 popless workforce per available job or a +20% workforce multiplier to assigned workforce, which now that I type them out are both way better ways to do automation than reducing workforce requirements would be anyway so actually everything is awesome.
This also seems to contradict "In other words, we only pay upkeep on 100 Pops". Are we paying upkeep on 100, or on 110?
I think they mean job upkeep goes up but you're still saving on pop upkeep (food, amenities, housing, living standard based CG etc).

Edit: I was far too slow!
 
  • 5
  • 2Like
  • 1
Reactions:
With the sheer amount of resource output modifiers currently present on species traits, not just for individual resources but also on all resources from jobs or resources from specific strata, it looks like like we can get some crazy bonus workforce numbers.
 
I hope this will not appear so cluttered on player facing UI.

From dev diary #370 we have

Will job filling prioritize bonus providing pop_group, or are we forced to accept under-optimized randomness?
I mean given current gameplay experience, it appears far more likely to have more than enough workforce for any specific job category.
I also feel like there are tons of cool design choices here that could really amp up the gameplay vibe for players. Make it policy dependent, perhaps.

For the 4.0 release we're planning on having it show as something like "Workforce for Researcher jobs: +10%", where Researcher is a concept with a tooltip that lists all valid jobs. For the open beta, expect a mess.
 
  • 28Like
  • 9Haha
  • 4
  • 3Love
  • 3
Reactions:
Any plans on giving Megastructures like the Dyson Sphere habitable areas? It feels really silly for such a structure to Just Work for eternity without regular maintenance, and for the people (or robots or whatever) not needing food/repair/amenities themselves.

It'd also be really cool for Dyson Sphere workers to suddenly realize they supply their Empire with 3/4 of their energy and get ideas...
 
  • 3
  • 2Like
  • 1
Reactions:
I wonder when the new DLC will be announced because on steamDB there is unknown app added recently
Nice catch!
Considering the pacing of DD, and the upcoming open beta, I would assume it makes the most sense to release it on anniversary (2025-05-09).
This date would seem the most plausible as they still need a few more DD for upcoming changes and DLC announcement, and then open beta stuff, and then final release notes.
 
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!

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.

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.

So which one is it? If we have available 100 Physics Jobs position available, will 100 Psionics work them, providing 110 Researchers? Or will it be 91 Psionics working them providing 100 Researchers?
 
  • 2Like
Reactions:
So which one is it? If we have available 100 Physics Jobs position available, will 100 Psionics work them, providing 110 Researchers? Or will it be 91 Psionics working them providing 100 Researchers?
The first.
The second quote applies to workforce multiplier which is different from bonus workforce multiplier.
Basically any bonus we have right now would be bonus workforce : pops have more than 100% efficiency at their job, but there could be ways to have pops act like the second version you propose : 91 pops would fill 100 workforce if they have 1.1 workforce multiplier.
 
Any plans on giving Megastructures like the Dyson Sphere habitable areas?

We do not plan on adding habitable areas to general Megastructures.

So which one is it? If we have available 100 Physics Jobs position available, will 100 Psionics work them, providing 110 Researchers? Or will it be 91 Psionics working them providing 100 Researchers?

If it's +bonus workforce, then you have 100 pops filling the 100 jobs, but with 110 jobs worth of throughput.

So you'll pay the upkeep for 100 pops, but the upkeep and production of 110 jobs. (My 100 Blorg get +10% bonus workforce so are more efficient than those lazy Humans, but they still need 10% more minerals in order to produce 10% more alloys.)
 
  • 19
  • 13Like
Reactions:
These changes as of late has been amazing to read, and it fills me and friends with excitement whilst trying to speculate how to play with these changes - and what other sections of the game might get changed because of this new Workforce system.

One such speculation is centered around Starbases and Habitats with this system, using the Resource Deficit that Trade will be used as upkeep.
We were wondering if the workforce mechanic could possibly be applied to a starbase rework, where the starbase essentially function as a deep space habitat with workforce working the specific Modules and Buildings in the starbase. Through that implementation, Starbases could become the new Habitat, as they are now population centers. Providing Immigration bonuses to system colonies, allowing planets in the same system to share resources before calculating the deficit and trade upkeep (as in the Starbase acts as a local hub for easy civilian trade). That way, you can still build single-focus planets and not get a severe trade upkeep as another planet in the same system is easily fueling it with resources. As with a Mining planet supplying an Ecu.

Another concept for workforce could be applies to Orbitals, such as mining and research orbitals. Without a local starbase, they are either working with Automation or with a workforce that must travel X jumps from the nearest colony - cutting the output by x jumps as more time is spent on travel than work.
If a starbase or colony is present, the workforce could have no difficulty with travel to their work, and thus provide full output of the Orbitals, or even more. As they spend less time travelling to them.
Civilian transportation finally becomes a mechanic, and makes your systems feel more alive - as you would technically have pops living outside the large population centers.

Another use for the workforce mechanic could be eventually implemented to a Manpower pool. Each year, based on your conscription law, more Manpower is gained from your total workforce - which then can be used to man your fleets.
Yes, fleets could cost manpower.
And Combat Computers could lower the Manpower cost as AI takes over jobs.

Technically, Stellaris is suffering from how much performance is put to visualize each models of ships, as every single Corvette is loaded. Thus the spam of 100 corvettes can be heavy on performance.
But what if Fleets were also affected by a similar mechanic as Workforce? Suddenly you wouldn't need to visualize all 100 corvettes, as they were instead compressed to Squadrons with a pool of corvettes.
---

It may not be conveyed properly in text as it was in speech as we brainstormed the potentials, but my friends and I believe 4.0 can bring a lot of potential with this rework on pops.
Starbases can get more uses, and could serve as Habitats/population centers, adding a softcap on Habitats as the AI was constantly overbuilding them.
Manpower could change how fleet construction work, possibly reducing the amount of ships you could field as your pops is the defacto limiter. Losses become more severe as you are losing "pops" with each battle.
Fleets could be visually downsized with their own form of workforce mechanic affecting compressed groups of ships in the fleet.

All I'm saying is that Stellaris could benefit greatly from this new Workforce rework, and my friends and I look forward to see where similar mechanics could be implemented.
 
  • 2Like
Reactions:
If it's +bonus workforce, then you have 100 pops filling the 100 jobs, but with 110 jobs worth of throughput.

So you'll pay the upkeep for 100 pops, but the upkeep and production of 110 jobs. (My 100 Blorg get +10% bonus workforce so are more efficient than those lazy Humans, but they still need 10% more minerals in order to produce 10% more alloys.)

So like... Does that mean - in theory* - that the +10% job output modifiers are better, because they don't rise the upkeep necessary for the workeep (so you pay upkeep for 100 pops, paying for 100 scientists, but getting output of 110 scientists), while the +10% workforce bonus increase both output and the upkeep of a job, while keeping the general pop upkeep the same (as in you pay upkeep for 100 pops and upkeep 110 scientists, while getting output of 110 scientists)?

*Of course not counting situation with two bonuses at once etc etc.

I just want to clarify, cause the "Bonus Workforce" got me a little confused, since they more or less employ the same number of workforce. Maybe some other term for that would make it clearer? "Workforce specialty"? "Workforce efficiency"?
 
Last edited:
  • 1
Reactions:
Okay, so if I'm understanding this correctly, species traits no longer directly increase resource production but instead increase the workforce into jobs that are relevant to that resource.

The biggest implication from this change that I can see is that food-based economies/Agrarian is gonna be quite a powerful species trait/playstyle after this change if the Baol and Bio-reactors buildings and several civics remain the same.

For example, currently in Stellaris PI version we have this:
Farmers can potentially produce:
Food -> Can be boosted by Agrarians
Consumer Goods (with Baol Organic Plant) -> Can be boosted by Natural Machinists trait
Energy Credits (with Bio-Reactors) -> Can be boosted by Ingenious trait
Exotic Gas (With Advanced Bio-Reactors)
Trade Value (with Anglers civic) -> Can be boosted by Thrifty trait
Amenities (with Agrarian Idyll civic) -> Can be boosted by Charismatic trait
+ Any other ascension/origin traits that do the same i.e. Overtuned and Cybernetics

In 4.0, it looks like:
Agrarians and/or Farm Appendages and/or Proles Pre-Sapient trait and/or Harvesters -> Extra Farmers Workforce -> Increases
Food
Consumer Goods
Energy Credits
Exotic Gas
Trade Value
Amenities

I mean, in terms of narrative flavor it makes sense since it's all stuff that's coming out of the "farmer" job in the first place but it's a little crazy that it's reduced multiple selections of traits down to basically just 3 or 4 to retain all the bonuses of PI version plus the multiplicative bonus from the change. Of course all of this is assuming the buildings and civic bonuses remain the same.

Just some food for thought.
 
  • 7Like
Reactions:
Okay, so if I'm understanding this correctly, species traits no longer directly increase resource production but instead increase the workforce into jobs that are relevant to that resource.

The biggest implication from this change that I can see is that food-based economies/Agrarian is gonna be quite a powerful species trait/playstyle after this change if the Baol and Bio-reactors buildings and several civics remain the same.

For example, currently in Stellaris PI version we have this:
Farmers can potentially produce:
Food -> Can be boosted by Agrarians
Consumer Goods (with Baol Organic Plant) -> Can be boosted by Natural Machinists trait
Energy Credits (with Bio-Reactors) -> Can be boosted by Ingenious trait
Exotic Gas (With Advanced Bio-Reactors)
Trade Value (with Anglers civic) -> Can be boosted by Thrifty trait
Amenities (with Agrarian Idyll civic) -> Can be boosted by Charismatic trait
+ Any other ascension/origin traits that do the same i.e. Overtuned and Cybernetics

In 4.0, it looks like:
Agrarians and/or Farm Appendages and/or Proles Pre-Sapient trait and/or Harvesters -> Extra Farmers Workforce -> Increases
Food
Consumer Goods
Energy Credits
Exotic Gas
Trade Value
Amenities

I mean, in terms of narrative flavor it makes sense since it's all stuff that's coming out of the "farmer" job in the first place but it's a little crazy that it's reduced multiple selections of traits down to basically just 3 or 4 to retain all the bonuses of PI version plus the multiplicative bonus from the change. Of course all of this is assuming the buildings and civic bonuses remain the same.

Just some food for thought.
That is technically correct and yes, that is only IF buildings and civics remain as they are.
So like... Does that mean - in theory* - that the +10% job output modifiers are better, because they don't rise the upkeep necessary for the workeep (so you pay upkeep for 100 pops, paying for 100 scientists, but getting output of 110 scientists), while the +10% workforce bonus increase both output and the upkeep of a job, while keeping the general pop upkeep the same (as in you pay upkeep for 100 pops and upkeep 110 scientists, while getting output of 110 scientists)?

*Of course not counting situation with two bonuses at once etc etc.

I just want to clarify, cause the "Bonus Workforce" got me a little confused, since they more or less employ the same number of workforce. Maybe some other term for that would make it clearer? "Workforce specialty"? "Workforce efficiency"?
Better in the sense of the increase being cheaper? Yes. Better in the sense of total output once everything is multiplied? No. Hopefully more interesting when combined with potential upkeep reductions/production bonuses/automation options from other sources? Perhaps.
 
  • 9Like
  • 3
  • 1
Reactions:
When might we see some screenshots of the the interface for this. I feel like they’d really help me understand how a lot of this is going to work.

Among other things, I’m very unsure about how workforce - automatically and manually - will be allocated to different jobs.