Is your feature request related to a problem? Please describe.
Skill gain is both too fast and too general currently. Building a house teaches you what you need to take up glassblowing, and within a short time you can master every skill in the game.
Describe the solution you'd like
A proficiency system would allow skills to be broken up into different subspecialties, with crossover between related fields handled by overall skill level. It would also provide something to learn and advance in with slower level progression: yeah, fabrication 8 might take three months of game time, but on the way you can learn all kinds of different proficiencies, so you won't feel stagnant.
A proficiency entry in JSON might look like this:
"id": "lockpicking",
"name": "lockpicking",
"description": "You are proficient in picking a mechanical lock using a lockpick.",
"skill": mechanics",
"min_level": 1, //cannot even attempt below this level, don't know where to start.
"learn_level": 3, //cannot learn it until this level but can attempt it with a book
"untrained_multiplier": 10, //time to complete is x10, likelihood of success is /10. The XP gained is divided by this too, so if you spend 100 minutes on a lock because you don't know what you're doing you still only get 10 mins of XP.
"book_multiplier": 5, //as above but you have a book to guide you
"NPC_multiplier": 3, //as above but a mentor NPC is guiding you.
"related": [ "hotwiring": 1.05 ] //experience towards a related proficiency will be multiplied by this factor if you know this proficiency. So knowing lockpicking makes you learn hotwiring 5% faster. Related also reduces the untrained and book multiplier effect by this amount. Lockpicking and hotwiring share very little but some proficiencies, such as "canning" and "pickling" for example, might share a lot, so if you know how to can food you're much better equipped to work your way through pickling on your own.
"requires": "null", //lockpicking doesn't require an existing proficiency to learn, but some proficiencies might. This would allow us to have "better versions" of proficiencies at higher levels potentially, particularly thinking of combat moves here. It could also allow us to have some low level proficiencies like "basic spectroscopy" that are required to learn "mass spectrometry" later.
If a recipe/action requires two proficiencies and the player is not proficient in either, use the harshest penalty of the two. If the player is proficient in one, half the penalty of the other.
XP: all skill XP is expressed in hours of learning here, although the game should measure it in seconds. For crafting skills this is simply the time spent crafting/doing actions related to the skill. Combat skills will need a different conversion that I'm ignoring at the moment.
L1 5 hours
L2 15 hours (20 total)
L3 100 hours (120 total)
L4 200 hours (320 total)
L5 350 hours (670 total)
L6 600 hours (1270 total)
L7 1000 hours (2270 total)
L8 1500 hours (3770 total)
L9 2200 hours (5970 total)
L10 3000 hours (8970 total)
To learn a new proficiency requires an amount of XP equal to (learn_level)虏 in hours, spent using that specific proficiency.
You start the game with a number of proficiencies equal to the number of skill points you've invested.
List of some suggested skills and proficiencies (skipping combat for now)
Computers
-programming
-hacking
Cooking
-canning
-baking
Electronics
-hotwiring
Fabrication
-carpentry
-knapping
-pottery
-glassmaking
Health (formerly first aid)
-wound care
-suturing
-soft tissue infection
--sepsis
-anatomy
Mechanics
-welding
-lockpicking
Science
-basic chemistry
--biochemistry
--basic spectrometry (req basic chem or basic physics)
---mass spectrometry
---nuclear magnetic resonance
-basic physics
Speech
-barter
-persuasion
-intimidation
Survival
-animal trapping
-booby traps
-military traps
-makeshift shelters
-plant identification
the overall list would be a dependency tree, this is just to give a quick idea.
Describe alternatives you've considered
Splitting skills up is inelegant for crossover... but a single master crafting skill with subskills for each crafting type is conceivable (fabrication - blacksmithing).much like marksmanship - archery. I don't think this is easier or better than the boolean "knows blacksmithing".
Additional context
This would require lots of json editing.
This post not done.
In addition to the JSON editing you pointed out, this would require some UI work to ensure that the character sheet doesn't get cluttered and difficult to use.
I think you'd move the cursor over a skill to see a list of what proficiencies you have in that skill, or have partly learned and maybe press a key like "P" to examine the individual proficiencies and their descriptions.
That or we split the @ menu into tabs, which might be just about due
Crafting currently increments time with a step of 5 minutes and takes 1-2 seconds real time per tick on average. That's ~15 real seconds for an hour of activity. 9000 hours of crafting is about 47 REAL HOURS OF PLAYTIME. And, in fact, a lot more than that, because the player has to manually answer hunger/thirst/sleep prompts. This is simply unreasonable.
I understand it's tempting to implement all these long-taking actions to make the game more realistic and whatnot, but unless there are auto-eat, auto-drink, auto-sleep mechanisms and the game can process 1 game week in a minute, it's simply torturing players by forcing them to stare at the screen for hours without doing anything interesting.
https://github.com/CleverRaven/Cataclysm-DDA/issues/30415 auto eat and drink zones should be pretty trivial to set up apparently. Auto sleep shouldn't be too much harder. Practice actions will help to further automate it. There are ways to further speed up automatic time passage, like allowing line of sight calculations to be lazier... These things are all planned at this point, and not really germaine to the subject of proficiencies
Well, you kinda propose 2 things at once: proficiencies and exponential practice time requirements for gaining skill levels. I have no issue and, in fact, welcome the first one, but the second is deeply flawed and I can list a lot of arguments why it's not a great idea.
Lazier LoS calculations are excellent, but I doubt little optimizations like that can speed the game from 1 second per 5 minutes to 1 second per day.
What lazier LoS are you talking about @Amoebka ?
1 second per day is never happening, obviously, nor should it. One of the underscored points of this is to make more things happen within a single level of a skill, so that lateral learning is a bigger thing rather than just pushing to the next level. We're not getting around slower leveling of skills; it's pretty much a foregone conclusion, I'm just mentioning it here for the sake of suggesting a proficiency level up speed in that context.
Seeing the metalworking issue reminded me of this, and also the similar system I thought up.
The idea behind my system is to have three layers of skill - skill, subskill and proficiency.
A skill refers to an encompassing skill that covers a large variety of things, and getting better at it should make the use a little more proficient in the things it encompasses. An example is Cutting Weapons. A crafting example would be Tailoring
A subskill refers to a more specific area within a skill. The subskill has more influence on skill checks than the skill it is under, but less than a proficiency. An example is Short Blades. A crafting example would be Stitching or Sewing
A proficiency isn't really a skill, but a randomly generated measure of how good a player is at a very specific action. It has the most effect on skill checks. An example would be Combat Knife proficiency. A crafting example would be something like Socks creation proficiency
Proficiencies should not need that much JSON definition. My hope is that they would become randomly generated at some point (take the name of the wielded weapon or crafted item, and assign it a skill level depending on how much it has been done)
The effect each level of skill has on skill checks would be soft-capped, and have amounts similar to the following:
Skill - up to 20%
Subskill - up to 35%
Proficiency - up to 45%
It's quite easy to explain with an example. In this case I'll use a player's skill with a combat knife.
A combat knife would use the Cutting Weapons skill (maybe the Piercing Weapons skill as well), the Short Blades subskill, and the Combat Knife proficiency. If a player got better at using a combat knife, they would also get better at using Cutting Weapons and Short Blades, but the skill gain would have diminishing returns as they kept improving Combat Knife proficiency.
If this player switched to using a kitchen knife, they would be much better at using it than a novice; kitchen knives fall under Cutting Weapons and Short Blades as well. However, since kitchen knives and combat knives are different, with different blade shapes, handles, weights, etc., they would not be a proffessional kitchen knife wielder as soon as they pick one up.
This system also solves the crafting system problem; at the moment, crafting a large number of X makes the player good at crafting Y, even if they are somewhat unrelated. With this system, crafting a lot of socks makes the player very good at crafting more socks, and a fair bit better at crafting sweaters, but not as good until they have practiced making sweaters as well. Even if they know how to sew properly, crafting socks and sweaters is quite different; different shapes, different stitches, different methods, etc.
This issue has been mentioned on Cataclysm: Dark Days Ahead. There might be relevant details there:
https://discourse.cataclysmdda.org/t/butchering-should-be-its-own-skill/24086/22
I don't know if this is off topic, or exactly how the process of built in mod creation works, but it might be a good idea to make a mod similar to stats through skills that affects stats through proficiencies, as proficiencies become more functional.
Also adding proficiencies for martial arts would probably be a very good idea, perhaps some professions can know a martial art, but not have the body aspect (the proficiency) from the start of the game, while others such as the black belt have max proficiency in whatever martial art they took from the start of the game.
I feel proficiencies should have a more binary nature to them, representing substantial (and critical!) practice and experience, and thus reducing failure consequences/chances, improving success consequences/chances, etc.
The more a skill is predominantly theoretical, the higher the chance it will have need for proficiencies, to represent familiarity with certain practical applications of the skill. In the case of nigh solely practical skills (like martial skills), there should be as few proficiencies as possible, as all kinds of skill use here should be easily represented solely by the skill level itself.
I have this strange worry that overly relying on proficiencies to hotfix certain issues and unrealisms will eventually lead to a saturation of proficiencies, and that these might infringe on the tried-and-true enjoyable systems based on scalar proficiency (i.e. skill levels).
Moreover, I can't shake the feel that the most elegant solution would be to simply divide up the skills and create dependencies, defaults and bonuses between them. Then adding sparse binary proficiencies on top of that, to represent a degree (or several degrees) of critical _practical_ experience in certain skills, not reachable without actual attempts and practical training.
This way (i.e. having more less generic skills), the framework for adding skills and skill checks might be made more generic and ready until such a time as we hopefully might get more options for skill checks. (E.g. social engineering, engineering/design/invention, scientific research, ritual magic, etc.)
Lastly, I'm not sure there's even a definite need of proficiencies at all, provided sufficiently specialized skills are added, like my suggestion above. Piloting could be its own skill (hard to learn and harder to train!), and glassblowing could be too, if it's not to be gated by recipe. Weaponsmithing and armorsmithing are realistically _very_ different from regular blacksmithing, and practically disciplines in their own right. In my opinion they would work both as proficiencies based on "Smithing" or Blacksmithing, or as skills in their own right, with defaults ties up with any related skill.
As more and more proficiencies get added, this system (in it's current form) feels worse and worse to me.
Sure, the concept of "you gotta know how to foo
- otherwise it'll take longer" sounds great. And it works great if there is a limited number of proficiencies, and a limited penalty for lack of knowledge and easily accessible information for the player.
Currently that is not the case. Take the following example:
That recipe presumable takes _one hundred days of pure crafting time_ to complete (season is left at 91 days). That is fricken insane.
Yes, you don't know cobbling, yes you don't know much about waterproofing, yes you have difficulty with those advanced materials, and yes, you don't really know how to treat leather.
But according to the recipe you are "merely" up-armoring some existing footwear. That should not take 2400 hours.
Even if you are absolutely clueless about the proficiencies... It should not take more than a few days (of 8h crafting) _at most_... and maybe eat some materials and _maybe_ result in a damaged item (due to lack of proficiency).
This feels less like a game system (remember - this is supposed to be _fun_) and more like someone taking the mickey by making things effectively unattainable.
This clearly needs work. A lot of work.
f:xyz
clause to the crafting filter to search for proficiency xyz
.AUTO_PROFICIENT
, put it in a basic mod "Auto-proficient" and have it simply return 100% proficient for every value if active (similar to no npc food).You are choosing the most top tier items in the game, and looking at how they are to make if you have no idea how to do any of the necessary skills. It takes a very long time, quite intentionally. If you want to learn cobbling, leatherworking, plastic molding, and waterproofing, you should do that first and then try to use those skills to make a specialized piece of gear better than anything you could have found pre-cataclysm, including milspec stuff.
If you look at the time to do something like knit a sweater, or even make a pair of boots for a character who doesn't know how to make boots or work with leather, the timeframes are much more sane.
Semi unrelated: Survivor gear performs too well to be upcycled clothing. That is a conversation outside proficiencies really, but I am doing some of the adjustments alongside each other so it's fair game to bring it up here. Either the survivor gear needs a nerf or it needs to be much harder to make to justify what it is. I'm going a bit more towards the latter presently.
Edit: Not to say, by the way, that my timeframes are perfect at the moment. Just that you've based your analysis on a pretty bad example.
I am aware that I'm arguing with a double edge case here. I specifically looked for the item with the highest duration penalty. And I'm only seeing it because it's a migrated savegame where the character did all the "simple" stuff when there were no proficiencies in yet.
If you look at the time to do something like knit a sweater, or even make a pair of boots for a character who doesn't know how to make boots or work with leather, the timeframes are much more sane.
I am in absolute agreement with you here: If there are one or two proficiencies involved, the system is (mostly) sane.
But if there are three or four proficiencies at play, then the penalties just keep multiplying with each other. And that is no longer sane.
I think the penalty aggregation needs tweaking here. Anything above a composite multiplier of 20x feels absolutely insane, above 15x is still really bad, and above 10x is "merely" aggravating.
So maybe the penalties should not be multiplicative but additive. Maybe it can stay multiplicative but any penalty past the first gets a decreasing weight.
Ultimately the system should be tweaked so that the absolutely hardest item with the absolute shittiest skills should end up at (or just beyond) the "really really bad" but not yet ludicrous threshold (which to me felt like a 15x composite multiplier). But then, maybe such "under" proficiency should get a penalty to material loss chance instead.
I'll see if I cant crunch some numbers here to see if I can come up with some formula suggestions.
What you're facing here is what I'd call a soft cap, and that too is intended. After a point, you can't really make survivor boots. You don't know how. If you sit down to make them, you'll just fail and you'll spend more time goofing off reinventing the wheel than you would if you started with something more skill appropriate and worked your way up. The time multipliers aren't the big one, your failure rate on an item like that is going to make it impossible regardless.
We could add special code to make a hard cap saying "after x time and failure multiplier just hide the recipe", but that's just a UI thing. Personally I'd rather have the option to try, because there are going to be edge cases where the attempt is worth it*, and a hard cap will reduce that freedom.
*For example, you could gather the parts, assemble them to an in progress item, and then stop. Then you have them gathered up and won't accidentally use them for something else while you learn the needed proficiencies.
Edit to add:
Thinking on it, there's one thing I dislike about stacking multipliers, which is that learning leatherworking alone drops that time by several months. I might run some numbers and see how badly it would shift things if we did a sum of multipliers (ie actual time = base time x (sum of proficiency multipliers)) instead.
Did some number crunching as promised - I think adding the penalties (not multiplying them) is the way to go. Cumulative penalties top out at 13x (as opposed to 108x) while lower numbers stay significantly closer:
https://gist.github.com/DoctorVanGogh/bd5a1fa2f3869748dee40e563e42f219
PowerShell script to grab results: https://gist.github.com/DoctorVanGogh/b236963ec9e0e529fcb385c334607bc6
Unfortunately I think adding the penalties is quite a bit too soft. Something that takes an experienced professional a half a week of full-time work shouldn't be doable in only a month or two for someone without the foggiest clue where to even start.
We could, at some point, look into diminishing returns, so each subsequent proficiency has a lessened penalty to time, but I suspect it will remain this way for stable, because it is pretty much working as intended with just some fine tuning at the extreme end
See #44302 for my suggestion of an optional "off switch".
Yeah, toggling a feature like this not happening, as usual. Progress marches on. If people turn things off because they're in progress, they will never be tested properly. On the other hand, your passive aggressive approach to me discussing this with you, considering options, and not immediately agreeing has made it so that now I'm unlikely to listen to you in the future. Good job?
I am sorry Erk, that you see this as a passive aggressive attack on you - it was not meant as such. This was me putting my code where my mouth is: If I claim that this needs a switch, then I may better damn well be willing to at least try adding that one.
And since you seem to be the driving (or at least most visible) developer behind that feature here, I don't really expect you to go all "Oh gosh, yes, of course! That random person on the internet who jumped out of that bush 2 days ago is right, I will immediately change my plans". Thus me trying to add an option for some tweaked things while you stuff in your system as you designed.
I realize that the mere _offer_ of an alternative system somewhat steps on your toes here. But I would much rather have tried offering an alternate solution than keep on stomping my foot and going "But I'm riiiiiiiiiiiiight! You should change the default system to what IIIIIIII want."
I was - at least until now - under the impression that options & configurability were the preferred way for this project. Well - seems Kevin thinks otherwise, so my whole argument is probably moot :shrug:
Actually the well-advised decision of not allowing step-back options dates a long back in history of the project.
Requests for toggle-off bail-out options emerged, emerge and will emerge after almost every major feature or shift of paradigms in the game development (and by paradigms I mean entering yet another tier of it's complexity).
I can imagine that if it was an open option, the need for constant support of ever-branching out superimposing "nerf" options would hamper further development. And if "the mainline" features is what you deliberately design, they why even stray off the path by adding a back door. It would be like saying "hey, this feature completes a milestone in a development goal, but lets leave the back door just in case". One year after and you'll have a house of doors to manage and you'd be adding more doors, to allow other doors to open, in order for them to not get into each other's way, as they start to intertwine.
And you end up with inability to obsolete old code (which you are in fact no longer interested in as you developed a new milestone and you want to follow that path) as it supports one of the branches, and now any change to that area and you have two competing branches of codes to update in a single project, and you need to follow every path and interaction on both branches, and if they too branch out, then you end up in a Mandelbrot fractal hell. "What about a back door for mods?" is still not valid in this scope, as a back door is always a back door and falls under the same scrutiny traps.
Options & configurability yes, but along the mainline path of development. You cannot expect to put an equal sign between options & configurability and de facto carrying the baggage of the previous obsoleted features. For that previous game versions are supplied, so one can roll back to the past at the cost of forsaking the future. But you can't have the past and the future in one cake, as you cannot have a cake and eat the cake. Schrodinger's cat option wouldn't work here imho.
Yeah, the option (hah) is between maintainability hell by adding an infinite variety of options, or adding options for stuff and then just stripping them out when something related to them changes so that they don't need to be maintained.
Or just, do neither.
Here's my reasoning on _why_ I think this thing needs options. Some of the maybe temporarily, some maybe permanently:
The in development _Proficiencies_ system is a new[1] game mechanic aimed at adding granularity in player progression, activities & playthrough differentiation.
This is my impression of what it does and where I think it falls short and needs work.
The system was proposed as splitting up tasks into specific knowledge domains where lack of knowledge increases time required to complete the task (or allow otherwise completely unattainable tasks to be executed).
The original proposal suggested a quite lenient penalty system (Maximum of all penalties, reduction in penalty for lack of domain knowledge if the player had _other_ domain knowledge) [2].
The initial draft proposal suggested about 1-6 knowledge domains per existing skill with most skills being split into 2-3 domains.
With the existing number of skills this should end up with about 50-ish non combat proficiencies and possibly another 6-12 combat proficiencies (assuming a lot of combat skill proficiency overlaps - aiming is aiming).
The current (partial) implementation turned out to be somewhat different. So far _tailoring_ is the first skill which has gotten its initial pass at specific knowledge domains. It has recieved ten proficiencies with several interdependencies and prerequisites:
Penalties are not calculated on a _maximum_ basis but all _stack_ on top of (and reinforce) each other. While _most_ touched recipes have gotten one or two involved proficiencies, some have gotten three or four. In the aggregate this can lead up to a activity time penalty multiplier of 108x (!!)[3] - average maximum cumulative penalties are at about 9.4x with a median of about 4x.
The current implementation treats partial domain specific knowledge (anything below 100%) the same as a total lack of knowledge. So a character with 99.99999999% knowledge about a domain acts as clueless (and takes as long) as a character with 0% knowledge.
Knowledge gain is achieved at every 5% of activity. Activity duration is not recalculated for in-activity knowledge gain.
The new system muddles and conflicts with the existing concepts of recipe knowledge & learning and skill/recipe books. So far a player either _knew_ a recipe (memorized) or had a recipe book which allowed them to perform the corresponding crafting activity. With this new proficiencies system, that knowledge suddenly becomes arbitrary. Skill gain may magically pop a new recipe into the players mind, but will not give any knowldge on the component tasks required to achieve the end result: "You know a nuclear reactor can be built out of some belt buckles, shoelaces and a piece of gum - you just don't know _how_".
Also recipe books may contain a recipe for a task, but supposedly do not give any help on the intermediate steps.
As stated in 1.2 the new system can create _very_ large composite penalties due to the stacking of multiple values all reinforcing each other. The current absolute edge case can lead to an activity time of over 100 _pure crafting days_. Only after 5 of those days (or 15 days of 8h shifts) would the character gain any proficiency knowledge - but with that much time spent carfting they should immediately jump to 100% in that proficiency, alas, the task would not recalculate the required duration.
_Almost_ perfect proficiency is treated as no proficiency at all. While the system records like a float, it acts like a boolean. Proficiency is either there or not.
Also I'm seeing some scope creep here. What initially suggested about three proficiencies per skill turned into ten for the first skill with a serious pass. If this pattern keeps up, the system will end up with well above 50 proficiencies. Which will not be an easy thing for the game to display or players to keep track of.
Learning at only 5% intervals may need a look to make that more usable for very long duration activities. Maybe turn the 5% into a "over X time units _or_ 5% total duration".
_Maybe_ perform activity duration recalculation if the activity depends on some prerequisites which may have changed during activity execution.
time_multiplier
field per proficiency, per recipe, but that is somewhat of a maintenance issue. It can become hard to figure out what the intended source values were. Maybe a split of values into "applies to X% of task" and "make _that_ part take x times as long" could be used.[1]
An argument can be made that this system is not new, but just a tweaked re-implementation of the skills system. Except there is no rust and scaling is not from [0-10] but from [0-100].
[[2](https://github.com/CleverRaven/Cataclysm-DDA/issues/31610#issue-457782120)]
If a recipe/action requires two proficiencies and the player is not proficient in either, use the harshest penalty of the two. If the player is proficient in one, half the penalty of the other
[3] See "Multiplicative" column here
[4] See "docs/IN_REPO_MODS.md", "Development mods"
which [...] are [...] there to ease the transition between "incomplete feature" and "complete feature", when a feature in the core game is sufficiently incomplete [...].
So as I said, you've pretty much used up your good will after insulting me for listening but not acquiescing. However, I will briefly address your misconceptions here.
The proficiencies I listed above were a preliminary list, not exhaustive. See "the overall list would be a dependency tree, this is just to give a quick idea."
The original proposal had much lower penalties; however, these didn't work in practice. Were we to go back to that we'd need a different stacking system for proficiencies, where high level proficiencies (eg cobbling if you don't even have basic leatherworking skills) would have very high penalties, like 30x and above. The end result would be similar. This way is much easier to implement.
Again, there is nothing wrong with not knowing enough to be able to craft something.
It is very common to know that a thing can be done, but not how to do it. Use your noggin'. We all know a backpack can be sewn from cloth, that doesn't mean we know how to set it up in a way that will hold together with a zipper that will readily open and close smoothly.
The longest time needed to learn a proficiency is such that most proficiencies will be learned after a small number of basic tasks in that area. If you want to learn leatherworking, don't start by trying to make a full suit of leather armour. Make some basic leather items. This is equivalent to real life. If you try to learn miniature painting by tackling a 2' tall cthulhu statue, you will take months and probably mess it up, and you won't really reach the stages needed to gain basic proficiency because you picked a poor start point.
Several of your concerns are just about planned systems that will be implemented before proficiencies are complete, like proficiencies being in books, or like certain recipes only being autolearn if you have a particular proficiency.
Here's my reasoning on _why_ I think this thing needs options. Some of the maybe temporarily, some maybe permanently:
"i see concerns with the design that could be improved" is a valid argument. erk was even willing to discuss it with you for a time, before you ramped up the hostility.
"i see concerns so i need to be able to turn off the entire work in progress system" is not a valid argument. this will achieve nothing.
every time we've had a work in progress system that was in active development and let people turn it off, it ended up partitioning players and developers, and resulted in the system taking much longer to get complete.
what you asked for will make development more difficult, slow adoption of the mechanic, slow completion of the mechanic, and fragmenting people playing the game.
this is why kevin said "no, not interested". it's a "hard no" from the team because it's an inherently bad plan, and "more choices is always better" is an axiom that the team in general rejects.
i urge you to reconsider your antagonistic approach to interacting with the team, both displayed in this issue and in your pull request. if you continue to behave in this fashion, don't be surprised if you're asked not to participate further.
Wrapping up some issues with your argument that weren't directly addressed.
This isn't being implemented in line with the original proposal
This is irrelevant, this isn't some kind of formal design-by committee thing where a proposal is riddled with compromises before being accepted and is then writ in stone, the implementation evolves continuously as it's being implemented and then afterwards. I.e. the original proposal is not a source of truth, we are.
The new system muddles and conflicts with the existing concepts of recipe knowledge & learning and skill/recipe books. So far a player either knew a recipe (memorized) or had a recipe book which allowed them to perform the corresponding crafting activity. With this new proficiencies system, that knowledge suddenly becomes arbitrary.
There is no conflict, it's an explicit goal of adding proficiencies to separate knowing "what" to make and the details of "how" to make it. It's also not arbitrary, recipes represent knowing the sequence of steps to make something, proficiencies represent knowing how to execute those steps, skills represent ability to execute those steps.
As stated in 1.2 the new system can create very large composite penalties due to the stacking of multiple values all reinforcing each other.
This is the primary point of contention. You've been told several times that this is by design and fully intended. There's no way around it, the goal of this is that certain crafts are practically impossible unless you have the requisite expertise. At the same time we're building facilities into the system for you to gain some of that expertise as you go.
There is very little "fun" for the player in staring at progress bars for the sake of just making things take more time.
You are entirely missing the point here, if you see, "this will take you 1,000 hours to complete", the sensible thing to do is not to just fire it off and grind your way through it, the sensible thing is to do things with lower time investment that will whittle down those penalties until it's achievable. "It's not fun to do it this way" is only a reasonable statement if there are no better alternatives. If grinding away at a huge craft were both boring and highly optimal, you might have a point, but as it is it's just a bad option, so just don't do it.
Maybe perform activity duration recalculation if the activity depends on some prerequisites which may have changed during activity execution.
This isn't completely out of the question, but at the same time even encountering this is a symptom of targeting the largest, most complex crafts with little to no preparation in the first place. The reality is people are told IRL to NEVER do things this way, because it's a terrible way to learn due to the infrequency of feedback and compounding errors.
i.e. if you make something that takes a few hours and there are a few errors, your chances of learning something from it are high. If you make something that takes you a month and it's riddled with thousands of errors, you're unlikely to learn much from it.
@I-am-Erk I would challenge you to point out where the heck I allegedly insulted you. I am pretty sure I did not throw _one single iota of an insult at you_.
I think my harshest words were "The whole system seems half-cocked" and "someone taking the mickey" directed at the current implementation of a certain aspect of the system. (Shortly after finding a recipe suddenly taking 108 times as long as before).
I am also not going to continue to argue this. I had been accused of not having made a case why certain aspect were excessive. That is my case (together with some other side observations about the system).
_If the delays are not a mere by-product of the added complexity but one of - if not the main - reason for the complexity.... I would not expect those to change that much_.
Also... several people seems to be under the impression that I am particularly _invested_ in the "off" option for the system - which might explain why my points are viewed as so antagonistic - I am not. While that was _included_ in my PR it was merely what felt like a natural extension of my tweaking of the aggregation logic. (Because that conceptually started out as a multi-select option of "default", "more lenient"... and "off" felt like the natural third option to that).
This issue has been mentioned on Cataclysm: Dark Days Ahead. There might be relevant details there:
https://discourse.cataclysmdda.org/t/what-are-proficiencies-trying-to-model/24808/2
I've talked about this to others but the proficiency system definitely has potential, it helps mitigate the qualitative transition from chicken fodder to strong survivor that'd you'd expect would take a lot of time and experience. Obviously, it is still flawed, mostly because of the monotony of standing there leveling X proficiency especially since it is only on a few recipes.
From my perspective the system should be tweaked in the following ways:
Make the time to build only part of the process not the entire system, there are already enough waiting games in the game itself instead the actual construction of the weapon or clothing should be a multi-step process itself. Example, you have to make a billet before you make a blade before you attach a handle and sharpen the blade, this is ignoring multiple other steps such as quenching, the use of various lamination techniques such as San Mai. Basically, the proficiences and the time spent would be split up into multiple parts rather then one giant lump of time sank into a pair of boots.
Proficiency and the skills should play a role in the resulting product itself, thus the need to improve your armory overtime and as a result improve your skills. The fact that a blade we made at Fabrication 5 would be the same quality as a blade made by someone with Fabrication 10 coupled with Blacksmithing and Bladesmithing is silly and does contribute to how quickly we go from weak to strong. Such ideas already somewhat exist in the game as is, such as the maces or katana you find in pawn shops often being lower quality compared to the one you craft (because they are cheap knockoffs).
I know this has been discussed already, but I still want to make a comment from a gameplay perspective. Suppose the survivor wants to make an item "I" with normal crafting time "T". Suppose this item requires three proficiencies, with multipliers M1, M2, M3. The current formula says that the crafting time is T*M1*M2*M3.
Clearly, trying to craft "I" directly is not a reasonable strategy. Instead the survivor will find items I1, I2, I3, such that I1 requires M1 alone, etc. Let's say that the crafting times for the items are T1, T2, T3, the recipes are reversible, and the the deconstruct time is at most the construct time. Then, by learning M1 from constructing and deconstucting T1 etc, all three proficiencies can be learned in time 2*(T1*M1+T2*M2+T3*M3), and then the total crafting time for the goal item I is T+2*(T1*M1+T2*M2+T3*M3). Assuming that T1, T2, T3 are at most T, the total time the survivor should take is at most
3*T*(M1+M2+M3).
Would it be possible to make that the formula? Currently any player can craft the item "I" with no extra use of resources in time at most 3T(M1+M2+M3), but the process is quite convoluted. Perhaps I am missing something.
I just wanted to say that I'm completely new to GitHub, so I'm terribly sorry if it's wrong of me to write my thoughts here. I hope no one feels it as a slight or affront to the process in any manner, nor that I'm making a horrible faux pas by writing this here..
Hmm, I have two chief thoughts on this entire idea/system.
I'm wondering if there's a rather sizeable choice the dev team needs to consider here soon:
Here's my personal take on this:
Given that the proposed proficiency system should continue in its current direction (more or less option 1 in my list above), the framework should perhaps enable proficiencies to work in a more generic trait-like manner when involving skill use. Under, I've tried to use various examples to illustrate the particular respective need for a proficiency to affect that certain aspect of skill use.
Having or lacking a proficiency should affect one or more of the following:
Skill success/fail chance, i.e. the roll/calculation involving the skill level as an integer in any action or crafting "check".
Time spent crafting/performing a recipe/action.
Amount of reagent needed, whether ingredients or tools/catalysts for a recipe or action.
Chance of reagent loss/damage, whether it be upon failure or success of the action.
Again, sorry for the large amount of text, and possible error in posting it here. I just feel that this is major subject that will impact the game to a sizeable extent down the line.
Would it be possible to make that the formula? Currently any player can craft the item "I" with no extra use of resources in time at most 3T(M1+M2+M3), but the process is quite convoluted. Perhaps I am missing something.
One of the underlying problems if the system as it exists before proficiencies is that it doesn't resemble the process of learning how to do things in any meaningful way.
The process is the whole point, you need to build out a repertoire of abilities and recipes instead of "find one item per skill level, craft untill you level".
for electronics might I suggest microsoldering as a proficiency, the curcuit boards that do more complex things are likely using more modern chips.
Most helpful comment
Crafting currently increments time with a step of 5 minutes and takes 1-2 seconds real time per tick on average. That's ~15 real seconds for an hour of activity. 9000 hours of crafting is about 47 REAL HOURS OF PLAYTIME. And, in fact, a lot more than that, because the player has to manually answer hunger/thirst/sleep prompts. This is simply unreasonable.
I understand it's tempting to implement all these long-taking actions to make the game more realistic and whatnot, but unless there are auto-eat, auto-drink, auto-sleep mechanisms and the game can process 1 game week in a minute, it's simply torturing players by forcing them to stare at the screen for hours without doing anything interesting.