• 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:
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...

That pou don't see population doesn't necessarily mean that there are people living there. I imagien that all those space stations, including the ones that just claoim the system, have many peopel living there are keeping it operational. Across all your empire, there are ships flying around and doing their stuff. Even uninhabitable planets probably have occassional habitats where a small few brave peope live.

The game only represents the massive populations, and the populations that affect the game in some way. Dyson Sphere maintenance population doesn't need to be represented. It would at best be a distraction, and at worst something that makes the game more annoying rather than fun or challenging.
 
  • 5Like
Reactions:
I think using the term “workforce” in this way in the game is going to cause a lot of confusion. You can see it in this thread.

In everyday language, “workforce” simply means the number of workers. People are going to be understandably confused by 100 pops creating 110 workforce - as it goes against their general understanding of the term.

I feel like the whole thing could be resolved by changing “workforce” to “work”. It’s much more intuitive that 100 normal pops generate 100 work while 100 strong (or whatever) pops generate 110 work or 100 weak pops generate 90 work.
 
  • 7
  • 2Like
  • 1
Reactions:
That pou don't see population doesn't necessarily mean that there are people living there. I imagien that all those space stations, including the ones that just claoim the system, have many peopel living there are keeping it operational. Across all your empire, there are ships flying around and doing their stuff. Even uninhabitable planets probably have occassional habitats where a small few brave peope live.

The game only represents the massive populations, and the populations that affect the game in some way. Dyson Sphere maintenance population doesn't need to be represented. It would at best be a distraction, and at worst something that makes the game more annoying rather than fun or challenging.
Yep, if a 100% pop represents about a million people you could easily have a thousand people working on each station in a system and it not amounting to even a single 1% pop. I wouldn't be opposed megastructures having pops but I don't think it's bad if they don't.
 
I am curious how the game will fill jobs with workforce.

If you have:
900 pops (no bonus) and 50 pops with +10% bonus to all job types (synthetic trait or something) and 50 pops with +40% (a dark matter trait or something)
1000 workforce required split into 10 different jobs, some needing 50 workforce to fill, some 100, some 200 workforce for 100 jobs.

What happens?
How are mixes of species handled in the new system?

I hope for a clear visual indicator of bonus workforce & open jobs, because its entirely possible to have 1000/1000 miners but to still have space for 200 more.
But i'm sure you'll figure that out too - hyped for the beta <3

At least visually I think this will be handled by having different pop groups underneath the jobs. So in the first example you'd see 50, 50, 900 with the total 1025/1000 workforce (70 from the 50 dark matter pops, 55 from the 50 +10%, 900 for the rest).

For the second example you'd see 800 pops with 1000/1000 workforce.

1739523450989.png
 
I can see the argument either way. On the one hand "Strong: +10% bonus workforce" is accurate to the game mechanics, but on the other it's not an intuitive explanation. If there were a bunch of labourers IRL moving rocks and one guy was doing it faster because of how strong he was no one would say "his strength makes him generate so much bonus workforce!". More likely they'd say something along "his strength makes him more productive".

I'll see how it feels in the beta but tentatively I feel more natural language should be used with nested tooltips. E.g

Strong: +10% productivity to labourer and security jobs

Then when the player hovers their mouse over "productivity" they get an explanation like "generates bonus workforce"
I think this would be a very elegant approach, as 'productivity' would lean more towards implying the work efficiency of every working individual within the Pop, while 'workforce' toward literal availability of working individuals of the Pop at any given time (eg. 9 work hours instead of 8)
 
  • 5
Reactions:
since everything multiplies that means very strong is very stronger now
clearly my warrior species (or genemodded warrior castes) keep winning and are the best workers in the galaxy
 
At least visually I think this will be handled by having different pop groups underneath the jobs. So in the first example you'd see 50, 50, 900 with the total 1025/1000 workforce (70 from the 50 dark matter pops, 55 from the 50 +10%, 900 for the rest).

For the second example you'd see 800 pops with 1000/1000 workforce.

View attachment 1259687
I can see how it could work visually... although with many species I can imagine ending up with dozens of tiny pop groups (at least one group per job, per species so they'll be overlapping fairly quickly on a xenophile's ecumenopolis) the picture may end up as a long row of numbers 123, 234, 245, 164, 149, 11, 17, 27, 365... for each job, flickering each month as pops of each species all grow more granularly (I'm still not sure about adding two significant figures to all the displayed numbers).

But my actual question is:
Will there be an equivalent of the old job weights system, balanced around the new pop_job_bonus_workforce_mult?
Where will my dark-matter enchanced workforce be allocated first? (it seems potentially far more complex now with more permutations)

Obviously the new system is trying to reduce calculations but some calculations are needed as I wouldn't want my workforce filling the wrong jobs. And the new system allows for more complex situations that may be harder to optimize. For example:

A DLC or mod expands on the workforce mechanic such that a planet has:
100 Elite politician jobs that each need 100 workforce to fill,
10 Specialist "Megastructural Engineer" jobs that each need 1000 workforce to fill (megastructures are really big to maintain, +1 habitat capacity each job),
10 Worker "Temporal loop" jobs that each need only 10 workforce to fill (pops live an entire lifetime in a year, +build speed and pop decline per job)

Could the game have weights set so that it tries to fill the 10 temporal engineer jobs first because they need less job_max_workforce_mult? or because the pops that can work the jobs have a high pop_job_workforce_mult?
Could the game get stuck trying to fill a job that has unusually large workforce requirements like the Megastructure engineer jobs because they're a higher strata and not employ any workers? Or would it employ these jobs last?

pop_job_bonus_workforce_mult feels like it could directly replace the old job weight multipliers in most calculations and work fine...
But pop_job_workforce_mult and job_max_workforce_mult are a bit more complex to consider, probably on a job-by-job basis.
I'm just trying (and slightly failing) to imagine how it all is supposed to work before we reach the beta, wondering what will be possible, what could be problematic in future and what fun possibilities the new system will have for any future DLC.
 
Last edited:
I can see how it could work visually... although with many species I can imagine ending up with dozens of tiny pop groups (at least one group per job, per species so they'll be overlapping fairly quickly on a xenophile's ecumenopolis) the picture may end up as a long row of numbers 123, 234, 245, 164, 149, 11, 17, 27, 365... for each job, flickering each month as pops of each species all grow more granularly (I'm still not sure about adding two significant figures to all the displayed numbers).
Actually pop groups do not include 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.
I guess there will be a partial exception for Death Cult:
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.
If it was my job I would:
- add a new Stratm called "Sacrifices", that is unlocked by having Death Cult Jobs on the planet.
- make sure only "Sacrifice" Stratum pops work in the Death Cult Jobs
So while you can't select Sacrifices via their Job, you can select them via their custom stratum.
 
  • 1Like
Reactions:
Will there be an equivalent of the old job weights system, balanced around the new pop_job_bonus_workforce_mult?
Where will my dark-matter enchanced workforce be allocated first? (it seems potentially far more complex now with more permutations)

I've also asked this a couple of times in the thread and not got an answer. I assume it must work like that because it seems (to my non-computer science mind) even easier in the new system. Each job will have one basic output and all bonuses are related to workforce. So when a new job opens up the pool of possible workers just needs to be sorted by workforce per pop, and recruited from the highest on down.
 
I can see how it could work visually... although with many species I can imagine ending up with dozens of tiny pop groups (at least one group per job, per species so they'll be overlapping fairly quickly on a xenophile's ecumenopolis) the picture may end up as a long row of numbers 123, 234, 245, 164, 149, 11, 17, 27, 365... for each job, flickering each month as pops of each species all grow more granularly (I'm still not sure about adding two significant figures to all the displayed numbers).
Based on the other mechanics described I would be... let's just say "surprised" if it's flickering and changing every month. Even the very naive optimisation of "If there's no actively empty jobs then dump partial pops into civilians and only recalc and assign in multiples of 50" would prevent what you're describing on mature planets.
 
Last edited:
Actually pop groups do not include jobs:

I guess there will be a partial exception for Death Cult:

If it was my job I would:
- add a new Stratm called "Sacrifices", that is unlocked by having Death Cult Jobs on the planet.
- make sure only "Sacrifice" Stratum pops work in the Death Cult Jobs
So while you can't select Sacrifices via their Job, you can select them via their custom stratum.
I think I'm just a little confused and focusing too much on very work-in-progress pictures.

The mock-up puts species icons on a screen where the game isn't going to be tracking species at that level. The mock-up has multiple human icons under each job slider (indicating different pop groups tracked at the job level) rather than a single unified "Workforce" icon (or normal and bonus workforce icons).

So will pops on the job screen be a mostly cosmetic feature?
(in which case pop icons and numbers may flicker each month as it gets recalculated, randomly picking from all possible species that could supply that workforce).

I think I'd rather have some indication of the ratio of species living on the world on the main planet screen, detached from jobs and that screen if they are no longer as closely linked, for example:

Planet: Blorg
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png

10 icons representing 10% chunks of population. With the biggest of the <10% species/pop groups that wouldn't otherwise be shown rounding up to take the final icon. So I can see clearly who lives there in a way that doesn't take up much space or need as many calculations. (I really want to see who lives on my worlds! ...and not as a pie chart)

Artisans:
326 Pop.png (Workforce 100%)
162
Species right citizenship.png
(Bonus Workforce 110%)
Showing under each job what the game actually "sees" numbers and new icons relating to workforce/bonus workforce/workforce max. Breakdown in the tooltips.

But then the question is how will it sort the workforce into jobs when not all jobs have the same workforce requirements?
I've also asked this a couple of times in the thread and not got an answer. I assume it must work like that because it seems (to my non-computer science mind) even easier in the new system. Each job will have one basic output and all bonuses are related to workforce. So when a new job opens up the pool of possible workers just needs to be sorted by workforce per pop, and recruited from the highest on down.
It's seems like it should be much easier to sort once pops are converted into buckets of workforce. (although the numbers of discrete pops existing and moving from world to world increasing by two orders of magnitude seems potentially counterproductive to any performance improvement efforts).

I just wonder how the new workforce variables are involved in the sorting and allocation of workforce, or if the weighting system still exists at all.
I hope automated jobs will be filled first in each strata when possible and any new inefficient jobs are filled later, regardless of strata - whatever the new clerk/maintenance drone job equivalents will be now they don't exist.

Based on the other mechanics described I would be... let's just say "surprised" if it's flickering and changing every month. Even the very basic and very obvious optimisation of "If there's no actively empty jobs then dump partial pops into civilians and only recalc when you hit multiples of 50" would prevent what you're describing.
The mock-up had nice round numbers (but was from before workforce was implemented by the lack of references to it or bonus workforce) and perhaps it will only recalculate when the pop numbers change in larger numbers like the multiples of 50 you suggest (or groups of 100 we have now), otherwise each month the 100x faster pop growth and migration will cause the UI to be updated to show insignificant changes to output.

I suspect if pops are shown there may be a little flicker of dancing pops under each job each time you click the +/- icons to open and close jobs (we have that now as well), but that isn't really important to me. I'm just not sure what purpose showing the pops only in that location serves if pops aren't tracked there but workforce is.

And if the UI on jobs instead shows "Workforce" and "Bonus workforce" then perhaps pops could be shown more on main screen in some form, like this:

Planet: Blorg
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
 
I think I'm just a little confused and focusing too much on very work-in-progress pictures.

The mock-up puts species icons on a screen where the game isn't going to be tracking species at that level. The mock-up has multiple human icons under each job slider (indicating different pop groups tracked at the job level) rather than a single unified "Workforce" icon (or normal and bonus workforce icons).

So will pops on the job screen be a mostly cosmetic feature?
(in which case pop icons and numbers may flicker each month as it gets recalculated, randomly picking from all possible species that could supply that workforce).

I think I'd rather have some indication of the ratio of species living on the world on the main planet screen, detached from jobs and that screen if they are no longer as closely linked, for example:

Planet: Blorg
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png

10 icons representing 10% chunks of population. With the biggest of the <10% species/pop groups that wouldn't otherwise be shown rounding up to take the final icon. So I can see clearly who lives there in a way that doesn't take up much space or need as many calculations. (I really want to see who lives on my worlds! ...and not as a pie chart)

Artisans:
326 Pop.png (Workforce 100%)
162
Species right citizenship.png
(Bonus Workforce 110%)
Showing under each job what the game actually "sees" numbers and new icons relating to workforce/bonus workforce/workforce max. Breakdown in the tooltips.

But then the question is how will it sort the workforce into jobs when not all jobs have the same workforce requirements?

It's seems like it should be much easier to sort once pops are converted into buckets of workforce. (although the numbers of discrete pops existing and moving from world to world increasing by two orders of magnitude seems potentially counterproductive to any performance improvement efforts).

I just wonder how the new workforce variables are involved in the sorting and allocation of workforce, or if the weighting system still exists at all.
I hope automated jobs will be filled first in each strata when possible and any new inefficient jobs are filled later, regardless of strata - whatever the new clerk/maintenance drone job equivalents will be now they don't exist.


The mock-up had nice round numbers (but was from before workforce was implemented by the lack of references to it or bonus workforce) and perhaps it will only recalculate when the pop numbers change in larger numbers like the multiples of 50 you suggest (or groups of 100 we have now), otherwise each month the 100x faster pop growth and migration will cause the UI to be updated to show insignificant changes to output.

I suspect if pops are shown there may be a little flicker of dancing pops under each job each time you click the +/- icons to open and close jobs (we have that now as well), but that isn't really important to me. I'm just not sure what purpose showing the pops only in that location serves if pops aren't tracked there but workforce is.

And if the UI on jobs instead shows "Workforce" and "Bonus workforce" then perhaps pops could be shown more on main screen in some form, like this:

Planet: Blorg
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
Fungoid massive 12.png
The icons are there because people like to look at their pops and see what they're up to. I'm assuming they're not on the main screen because pulling all the info and visuals and such requires a measurable amount of processing effort. If I'm right then they're leaving all the little goober icons off the main screen because it's not worth the performance hit every time someone just wants to slap down a new building, but it is worth the showing them when someone chooses to open the screen that's specifically for seeing what all your little goobers are doing today.
 
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.
 
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.
Do they get "civilian" job roles maybe (from previous dev diaries)?
 
  • 1Like
Reactions:
The icons are there because people like to look at their pops and see what they're up to. I'm assuming they're not on the main screen because pulling all the info and visuals and such requires a measurable amount of processing effort. If I'm right then they're leaving all the little goober icons off the main screen because it's not worth the performance hit every time someone just wants to slap down a new building, but it is worth the showing them when someone chooses to open the screen that's specifically for seeing what all your little goobers are doing today.
I do like to look at my pops and see what they're up to, it's not that I want to remove them, just group them by the new workforce and bonus workforce stats into clear buckets of normal or special pops (the only thing that will matter in future) and also have pops shown in some form on the main planet screen so I can see who lives there without getting out a magnifying glass and lifting up rocks searching for my cute little bugs.

I could understand animated portraits being a performance hit (the long list for recruiting new leaders has at times been laggy). So if that's been the problem then I'd get around it by turning pop portraits into icons with no more impact than the resource icons. And I'd be happy even with the 28 pixel blorg icon used for species on the Stellaris wiki. Then you'd only have to load the full 3D portrait if you click it for more information (although I'd probably go for 64 pixels as the smallest for at least some detail, maybe increasing to 128 pixels if you have lots of pops on the planet to indicate it's very populous).

So, two things:
1. Pop icons do not have to be animated and full 3D all the time
2. 3D Pop portraits are already displayed on the main planet screen (currently planet and sector governor) so if displaying them is a problem it may be worth looking into ways to display pops more cheaply for performance gains, and freedom to show them more.
 
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 see no reason why you couldn't create a job with no maximum workforce cap (or an unreachable one).

What proportion of planetary workforce would that kind of job get?
 
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.

Those strata could also be split between civilian and military roles/contributions, depending on Economic Policy and other factors.
The default civilian role could be "Clerk", but swapped to Servant, Livestock, Toiler, Hedonist etc. by circumstances.
The default military role could be "Militia", but similarly swapped by circumstances.

Clerks can finally say, "I'm not even supposed to be here today"?

Pop-culture references aside, this looks like a very good opportunity to consider adding "unemployment jobs", i.e. things that Civilians contribute Workforce to - while remaining available for emigration if opportunities arise elsewhere. There are already a couple of such jobs in the current version of Stellaris, i.e. those jobs that are created out of nothing for pops when no other job is available (except that AFAIK those jobs currently block emigration, but this should not be an obstacle if emigration availability is decided by being the Civilian stratum).
  • Servant (Domestic Servitude slavery)
  • Toiler (Thrall-Worlds)
  • Livestock, Grid Amalgamated and Organic Specimen could also fit in here, as they are barred from taking any "real jobs" and get a number of jobs equal to their population size.


One model would be to have a civilian-military split of the Workforce contribution from the Civilian stratum, where pops in the Civilian stratum contribute Workforce to two different "jobs": Clerk (Trade Value) and Militia (Naval Capacity, Planetary Defense Army). These contributions would be on top of whatever contribution pops make by being in the Civilian stratum to begin with.

The ratio of contributions to Clerk and Militia could normally depend on the Economic Policy of the empire; perhaps 50% each at Mixed Economy, 100% Clerk with Civilian Economy, and 100% Militia with Militarized Economy (edit: or perhaps 75/25 with Mixed Economy, 100/0 with Civilian Economy, and 50/50 with Militarized Economy). Special circumstances could, however, override this with other ratios for the affected pop groups.
  • Exempt (from Military Service): 100% societal contribution (Clerk).
  • Domestic Servitude slavery: 100% societal contribution (Clerk).
  • Battle Thralls slavery, Thrall World designation: 100% military contribution (Militia).
  • (Edit: Fortress World designation: 100% military contribution.)
The job assignments could also be swapped by special circumstances.
  • Decadent Lifestyle (from Pleasure Seekers / Corporate Hedonism) swaps Clerk to Hedonist (already exists as a Fallen Empire job - for otherwise unemployed pops).
    • This would pair very nicely with pop upkeep factoring into job competition/demotion. The expensive Decadent Lifestyle pops would eventually be liberated from all jobs that their xeno/robot/zombie/replicant servants can do instead, allowing them to retire into a completely decadent lifestyle of hedonism.
  • Other living standards could add unique assignments of their own (Utopian Abundance, Shared Burdens and Dystopian Society may be candidates for this).
  • Domestic Servitude slavery swaps Clerk to Servant.
  • Thrall-World planetary designation swaps Clerk to Toiler.
  • Penal Colonies could add Prisoner, or just reuse Toiler with a rephrased tooltip.
  • Warrior Culture could swap Militia for a new Warrior assignment.
  • ... and so on...
The one-job slavery types could be integrated into this system by swapping Clerk for their target job, and forcing societal contribution to 100%.
 
  • 2Like
Reactions:
I wonder if exponential pop growth could be a thing now. As well as a concept of growing the empire exponentially and dealing with the problem of real overpopulation which were impossible before