Cities: Skylines

Cities: Skylines

601 个评价
More CitizenUnits 1.1.3
3
2
2
3
2
2
2
   
奖励
收藏
已收藏
取消收藏
文件大小
发表于
更新日期
182.264 KB
2021 年 11 月 14 日 上午 12:32
2023 年 5 月 24 日 下午 6:48
17 项改动说明 ( 查看 )

订阅以下载
More CitizenUnits 1.1.3

描述


Doubles the number of CitizenUnits (NOT CITIZENS) available in the game (from 524,288 to 1,048,576). Just enable and start a new game, lor load an existing one - no other steps are needed.

IMPORTANT NOTE
It's like using the More Vehicles mod - saves made with this mod active WILL NOT BE RELOADABLE WITHOUT IT. Please use a copy (or throwaway city) for testing before committing to use this on a 'keeper' city (and even then, keep a backup from before you started using this mod, just in case).

THIS IS NOT SOMETHING THAT CAN BE UNDONE. FUNDAMENTALLY. Once you've got a quart, there's just no way of fitting it back into a pint pot.

New in 1.1
  • Add option to retain original vanilla CitizenUnit limit (for access to the mod's cleanup functions without having to commit to the expanded limit)

The mod also (by default) checks for any invalid CitizenUnits when loading a save, and fixes any that are found; some saves can accumulate significant numbers of these invalid units, all of which count towards the limit without actually doing anything useful. This check can be disabled in the mod's options panel.

Specifically-compatible mods
  • Any mod that doesn't touch CitizenUnits will work fine with this mod - this includes the VAST MAJORITY of all mods, specifically including all the 'big names' such as 81 Tiles, Find It, Move It, visual/effects and graphics mods, etc.
  • All of my mods (specifically including Ploppable RICO Revisited, Lifecycle Rebalance Revisited, Realistic Population (Revisited/2), but all others as well) are compatible with this mod.
  • Any mod that does touch CitizenUnits will still be compatible if it at least checks the buffer size at runtime instead of using hardcoded size assumption; this is the case with most modern mods that deal with CitizenUnits.
  • The latest version of the Real Time mod has been updated to be compatible with this mod.
  • Includes a compatibility patch for TM:PE 11.5 (TM:PE 11.6 is fully compatible with this mod without the need for a patch).



Some older and unmaintained (or outright broken anyway) mods that try to work with CitizenUnits directly won't be compatible with this mod, such as the older Realistic Population and Consumption mod and Citizen Lifecycle Rebalance mods (which are out-of-date anyway, have long been deprecated, and are now hidden on the workshop). The older 'Nursing Home' mods (also abandoned) are also incompatible. There won't be a 'fix' for these mods, as (obviously) they should no longer be used anyway.

What are CitizenUnits?
CitizenUnits (not to be confused with Citizens) are the game's internal data structure for 'assigning' citizens to buildings, vehicles, etc. A CitizenUnit is required for each household, and for every five available jobs at a workplace, for every five available customer slots at a commercial building, and for every five visitor places for an entertainment (e.g. park/unique building/park area/stadium/etc.), for every five student places at a school/college/university/library/etc., for every five patients at a clinic/hospital/gym/etc.), for every five spaces in a public transport vehicle, etc.....

These CitizenUnits are assigned whether or not those places are occupied; e.g. even if there's no-one actually visiting that park or attending that school or travelling on that bus, the CitizenUnits still have to be created and ready to receive citizens.

You can see from that that the number of CitizenUnits in the game can easily outpace your actual population, sometimes by many multiples - but the game has a hardcoded limit of 524,287 CitzenUnits. Once this limit is reached, then it just can't allocate any more. It's just a fundamental game limit, like the node limit or segment limit or building limit or path limit or zone block limit or vehicle limit or CitizenInstance limit etc.

What happens when the game reaches the CitizenUnit limit?
Unfortunately, unlike some of the other limits, the game doesn't notify you when you've reached the CitizenUnit limit; it just carries on, quietly failing in the background. Usually the first symptom that people notice is residential buildings with 0/0 households. Other symptoms include workplaces with fewer jobs available than they should have, commercial and/or entertainment buildings with no visitors, public transport vehicles that can't carry passengers, educational buildings that can't take students, just to name a few.

Performance impact
Care has been taken to minimise performance impact. There is some impact, as the game now has to iterate through twice as many CitizenUnits as before. On activation of the mod (without using any of the additional CitizenUnits) drops seen in testing have only been 1-3%, increasing slightly as the new CitizenUnits are occupied (but still typically less than 5%). This will depend on the specifics of both your city and your computer, and as always, YMMV.

Modders
Please don't assume fixed array sizes in your mods; for CitizenUnits, don't use hardocded array sizes (including using CitizenManager.MAX_UNIT_COUNT). Instead, check array sizes at runtime with Singleton<CitizenManager>.instance.m_units.m_size. This is especially important when copy-pasting decompiled game code.

Problems?
This has been tested extensively and no issues have been found - so far (other than the mod partial compatibilities noted above).

If you do encounter an issue, please post it in the discussion below with a link to your output log. Please don't try to copy-paste your error message into the discussion; it's not useful. Remember, an OUTPUT LOG IS REQUIRED TO PROPERLY IDENTIFY AND DIAGNOSE ISSUES.

Meta
As above - permanently changes the savefile. Saves made with this mod will not be readable without it.

This mod uses Harmony[github.com] version 2.0 by Andreas Pardeike via the Cities Harmony mod by boformer.

Special thanks to dymanoid, whose More Vehicles mod inspired this one.


Source code
[github.com]


Translations
[crowdin.com]
Please leave a message below if you'd like me to add another language on CrowdIn.


[ko-fi.com]
热门讨论 查看全部(1)
0
2023 年 2 月 8 日 上午 10:23
Airline Headquarters Building Using Over 700,000 Citizen Units
dboi88
550 条留言
algernon  [作者] 10 月 13 日 下午 3:32 
@slzre That was experimented with, but dropped, as the expanded limit provided already is beyond the game's effective ability to handle in conjunction with other limits. In those cases where somebody had already filled up the expanded capacity, adding more didn't help, because the error they had that was causing the fill-up quickly expanded to fill the additional units.

In short, if you are hitting the limit provided by this mod, you have an issue with your save and you need to fix it - adding more units won't help you.
slzre 10 月 12 日 上午 5:44 
@algernon is it possible to make even more citizenunits?
algernon  [作者] 8 月 21 日 上午 12:13 
@Uight Uhh, no, the More Vehicles approach won't work, as Citizen Instances is already at the ushort max value. More Vehicles just uncaps the artificially lower limit and raises it to the ushort max. Citizen Instances is already there.
Uight 8 月 20 日 下午 1:27 
@algernon i looked at the code of more vehicles and this and id guess combining the approaches would allow to increase the citizen instances too.
Yet that would probably need so many patches and your right the game seems to be mostly bottlenecked by the citizen instances as im allready only running 15 FPS with 61500 instances and 390k pops 18k cars without hitting any of my PCs limits
Lets just hope teh new game gets better so i actually want to build my next big city there....
Norsem 8 月 20 日 下午 12:54 
could you make a more vehicles mod it seems that the one currently out is not functional
Uight 8 月 17 日 下午 12:59 
@algernon ahh too bad. i didnt even really realize im at limit because i think the actual cap is around 61500 instances. I just realized traffic dying down with wider city sprawl and when i finally removed seaguls and then animals i lost 800 and 2500 instances but filled up back to 61500 instantly
algernon  [作者] 8 月 11 日 下午 3:51 
@Uight Citizen Instances? No, unfortunately. I did try, but it was just beyond the game's realistic ability. 65,535 isn't an arbitrary number, but is a fundamental programming limit (the maximum number of instances that can be indexed by a 16-bit binary index).
Uight 8 月 11 日 下午 12:18 
In my newest savegame with around 370k pops i only use 54% of citizen units as the city isnt that big but since im using all industries and around half of the city is low density im actually running out of citizen instances. I guess theres no way to get that up?
Id expect teh game to get way slower but a bump to around 80k would be really nice
algernon  [作者] 7 月 15 日 上午 5:39 
@umran112demir Unfortunately, no. Attempts were made, but failed. The only thing to do is reduce your usage (removing pipes/powerlines, merging segments, replacing decorative networks with props/procedural objects/Intersection Marking Tool lines/etc.)
umran112demir 7 月 14 日 下午 10:04 
Is there a way to increase network limits? I've never encountered anything like this before, even though I've taken many subway and bus trips. I'd appreciate any help, thank you.