Institutional Memory and Reverse Smuggling
An anonymous reader writes "Anyone who's worked in a large engineering firm is familiar with institutional amnesia. Things get built, and then forgotten. Documentation is supposed to help, but rots, is lost, or uses obsolete methods and notation nobody understands anymore. I recently found myself in a strange position, rehired as a consultant with the unofficial job of reminding the company how an old plant works. I even have some personal copies of documents they seem to have lost, which I have to awkwardly smuggle back in. I don't find these kinds of experience written about often, but I'm convinced they're more common than you'd think."
A very relevant area where this problem can be readily seen is computer data formats.
But the NDAs keep me and everyone else involved from talking about it. :P
A unnamed corp where I use to work would hire retired employees for contract work at high per hour wages for months due to issues like this.
I have personally witnessed this happen with my former employer. Higher ups seemed to think that there was some benefit to the company "memory" or "team experience" if we almost brought a product to market. People would argue that at least we now had the experience to do this again in the future if we had to. Totally wrong. Teams were broken up and key players re-assigned. Some people left the company or moved to divisions physically remote from their former bosses. Any reports written could not be used to replicate anything useful and, to be honest, who would write a report explaining the history of an unsuccessful product? It never happens. Real knowledge is lost in a barrage of wasteful spending.
Sorry, but gray text on gray background is making my eyes bleed.
Somebody writes the code, doesn't bother to comment it at all and then you come in years after the fact. You look at the code and wonder, "why did he do it that way instead of this way?" Then the big gotcha, you think I could ask him but he left the company 5 years ago(At this point slap your forehead and hope you don't break anything working on the code.)
Did you know 80 to 90% of the moderators on slashdot wouldn't recognize a troll even if one dragged them under a bridge.
I design automated testing systems. I find myself in the position of re-solving problems that were solved as much as 10 years ago in prior automated testing systems. There's an odd tendency of people to simply passively accept whatever the manufacturer of the new system gives us as somehow "better" or more advanced that what we had, even when the new solution is an obvious fail, or (ahem) undeveloped. So I fix things to make up for the shortcomings of the new software, more or less the same way I fixed them 7 to 10 years ago. Things start working again. Everybody is happy.
I seem to have discovered job security by re-inventing the same thing every 7 years or so in a slightly different form using a different programming language. Of course, that sort of describes the entire computer industry, more or less.
Please do not read this sig. Thank you.
Why bother trying to smuggle them back in. Tell them you'll work on figuring out the bits you can't remember and will write a new manual. You get to charge them for time you don't need to spend and avoid getting caught.
One of the courses of my university study was called 'Software Evolution' in which tutors showcased all kinds of problems with legacy software. Software using languages or platforms no one knows about anymore or lost source code of mission critical systems. Especially older banks and insurance companies suffer from this problem, often choosing the 'wrap around the bit that we know that works' instead of a complete overhaul of a system no one really knows what it does but does it really well. I fear everything we build today will cause the same problems, but worse. Perhaps the old idea that readable code should help people understand its function saves us from this scenario...?
More like this, please, and less about the Apple/Andoid/MS/Samsung/**AA suit-of-the-minute. I know, I know, flamewars == pageviews == Step 3, but you've occasionally gotta throw something out there for us old-timers.
Dear Slashdot: next time you want to mess with the site, add a rich-text editor for comments.
I currently work for a company that has instituted an incredibly restrictive development methodology they bought from a big consulting firm. It requires multiple forms be filled out for every program written, every requirement for every program written, every request for every change to every program or application written. All of these reviewed by coworkers who are not about to alienate team members, and reviewed by lower management who want to look good to upper management by having everything go smoothly.
These documents are then stored on the LAN. To never, or rarely ever, be read again.
The one thing it does not enforce or require, is meaningful documentation in the code itself.
It doubles, or more, the time it takes to do everything. But it does nothing to stop the mistakes any better than the procedures that went before. If anything, it finds less errors, because we were not given more time to do this double or more amount of work. So time is so compressed, we do not have time to do anything other than get it working and get it in.
One thing it does do very well, is prevent problems from getting fixed. The only people that will start a change effort are those that notice a problem and are affected by it enough to have it cause them problems. Otherwise no one wants to go through the bureaucracy to kick off any sort of change effort, which leaves a lot of ticking time-bombs in the infrastructure configurations, application designs and application code.
The only place documentation is good, is if it is meaningful, and in the code, where it is readily findable and far less likely to get lost, short of some fool deleting it.
Documentation located anywhere else will be lost, or obsolete many more times than not, before you ever really need it.
If anything, documentation in code should be reviewed by people with absolutely no connection to the application it is for. If it is good enough for them to figure out an understand what is being done, and more importantly why it is being done, only then is it worth anything more than the bytes is written with in storage.
I recently found myself in a strange position, rehired as a consultant with the unofficial job of reminding the company how an old plant works.
I certainly hope that you negotiated a much higher salary than before.
I have known people who were fired in a "chain saw" maneuver who proved to have core corporate competencies in their heads. They negotiated for a much higher rate the second time around...
I'd be very careful in this situation. Even though you are supposedly "doing the company a favor" by smuggling the documents back in, were you even legally allowed to take the documents in the first place? Most employers have contracts or rules that state you can't remove documents from the office or that when you leave the company you must return all property to the company. Furthermore, it is most likely that this documentation was property of the company all along and in that case did you break any laws by removing it from the company and keeping it? IANAL but this is a very tricky situation. You may be doing good for the company now but you are profiting off of documents that you do not own and may not even have a legal right to possess.
Personally, I'd stick with just what's in my head and not keep any documents, files, etc. from a previous employer. It's just asking for trouble.
If the history channel read this story, they would undoubtably conclude that the plant was built with the help of aliens.
Where I work, us, the IT teams that program and support the applications, often have to tell the employees how the business works. So many people retired in the 2000-2010 that a huge chunk of institutional memory walked out the door. The new folks doing the jobs often don't know how to handle the Once Every Five year situation, etc. I know the company keeps buying these Knowledge Sharing portals, but it seems more like oral history is the primary knowledge transfer.
The bitter lessons of a veteran coder: http://bitterprogrammer.blogspot.com
My situation is different, yet similar. I just have so much responsibility for so many things at work, I simply can't remember how everything works. At times it is frightening, especially since year after year there are more things happening and I get older, so it is already inherently more difficult.
I also find myself "protecting" my sanity by almost intentionally forgetting how some things operate, especially those things I don't like.
I think as a manager, one of the most important things to do is learn to effectively document everything. I always knew documentation was important, to the point that I have a log of everything I do at work, every day, that spans 23 years! But those are just "reminders", not proper documentation. It helps to jog memory or memorialize certain facts for reference. Nothing replaces *proper* documentation, though- the kind that is well thought-out, has great detail, and is organized properly. Further, it will have insights into defining the problem and the solution and WHY you selected certain paths and not others.
Proper documentation takes considerable time, and many people think it is a waste of time, especially when one is drowning in projects and deadlines. When you reach the point that you can't handle the load without continuing to document properly, you know you are in trouble. In the short-term, you can "win" by getting more things done. But in the LONG TERM, you are basically screwed, because you will spend a tremendous amount of wasted time later trying to relearn what you did and why. Or worse, trying to defend your decisions and can't because you can't find the information, it doesn't make sense, or it just doesn't exist.
The bean-counters and mindless penny pinchers who run most corporations like to keep everything secret and proprietary without fully appreciating the costs associated with maintaining that level of secrecy. The solution is simple, only keep something secret if you've first: taken the effort to understand what it will cost to do so and second: taken the effort to make sure the secret won't actually be forgotten. In short, keep fewer secrets, and keep them a lot better.
i did so slavishly at first but then my boss pointed out that comments are rarely updated with the actual code. a contrived example:
int foo() // always returns 4
{
return 5;
}
now I have a coding style that the simplest fool can understand. that's quite a different thing than the arrogant coders who feel that their colleagues are incompetent if they cannot follow uncommented code. if someone cannot follow my code then I feel I have done something wrong, not them.
Request your free CD of my piano music.
Primo Levi, "Chrome" in The Periodical Table describes a similar problem with a paint formula at his factory in the 1950s. Evidently, during the war, they had a QC problem, included some chemical to correct for that, and the formula became a cargo cult, long after anyone knew what it was for. Someone changes some other factor, and their batch of paint gets the consistency of liver. So our hero had to reverse-engineer the trade secrets of a previous generation, back when he was working in the lab at Auschwitz.
Until you write it in cobol.
Deleted
if your own employees do the work your company retains the knowledge of how to get it done.
if you outsource you never learn how to do your own work, instead you finance your outsourcing firms efforts to learn how to operate your business. not only do you not gain that institutional memory but that outsourcing firm can now perform that same work for your competitors.
Request your free CD of my piano music.
And a new dark ages are born.
Oh enough hyperbole. Wouldn't worry about it, the companies in question will collapse and be replaced by someone else if the demand is high enough. Or not if it isn't.
Deleted
I work in a library at a large organization and I see this every single day. The short answer to the problem is that it needs to be someone's responsibility to ensure access to KNOWLEDGE (NOT data, documents, etc, but knowledge) in the long term. I get requests from our employees every single day asking for information on project x that was shut down in the 90's. It is my job to track down any information that I can. Unfortunately, I have neither the directive or funding to start gathering and organizing the knowledge in such as way that it is useful a few decades from now. So instead I tell our employees "sorry, you will have to spend a few hundred thousand to recreate the information."
There are lots of people out there that can fix this type of problem, but they are never given the tools to do so.
now one does need to document the expected inputs and results of subroutines. better than commenting is to use assertions as well as unit tests. so for that contrived example, what I would actually do:
int foo()
{
int result = 5;
assert( 4==result);
return result;
}
if you don't maintain the assertions and unit tests with the payload code you'll find out about it right away.
Request your free CD of my piano music.
NASA has lost ALL of it's Saturn V knowledge. The scientist have died, the documents have rotten and been lost. The parts were SOLD AS SCRAP. NASA is currently trying to buy up all the lost parts from scrap dealers. All this old knowledge is for the 'new' space program. Yes, we are indeed regressing.
The only place documentation is good, is if it is meaningful, and in the code, where it is readily findable and far less likely to get lost, short of some fool deleting it.
Deleting documentation is far more important than writing it. There is nothing worse than documentation that is clear, concise, convincing and that assumes something that is ever-so-subtly wrong due to the code base having been changed since the documentation was written. It's better to update the wrong documentation, but deleting it is far better than leaving it in in most cases. So no, people deleting comments are not necessarily fools, especially not if working to a deadline.
It costs money to maintain secrets. If there is no reason to keep it secret anymore it is cheaper not to guard it.
Request your free CD of my piano music.
Management don't care, why should you? It really can't be all that much of a problem. More a perception than a problem.
By all means go ahead and create/use a documentation system for your group but clearly there just isn't a requirement for anything more comprehensive.
Deleted
Something like this would never happen in private enterprise, where the invisible hand of the free market weeds out such inefficiencies.
Oh, wait ...
The correlation between ignorance of statistics and using "correlation is not causation" as an argument is close to 1.
I have a situation a liitle more strange. A customer of a former employer (now twice aquired) has asked me to act as a customer advocate on a system I wrote as they have "limited" confidence in my former employer being able to maintain the system and the NDA/Non-Competes/IP Ownership prevent me working on the system for the customer.
I had a similar experience, from the other side of the spectrum. I was the summer intern doing a project that required digging through the paper archives to find some hardware data that was to be entered into a computer simulation.
It was nowhere to be found. What was documented for this perticular plant was little more than the type of equipment used. Not it's technical ratings or anything. Just what was there. And good luck finding any of that documentation only.
I also found full documentation for a plant that'd been shut down decades ago. Then demolished. And was now a blank wasteland. "In the hope they would be useful"
So there I was, scribbling down some notes off the PC screen by hand, when I reached for the keyboard and Ctrl-S'd.
Speaking from experience, corporations are unable to give themselves just one name. They have to change their names regularly (because it obviously makes things better, like go faster stripes) and more, they have to change the names of departments even more regularly (again because it improves everything). The result is that any documentation system which is created rapidly becomes fragmented, out of date and lost as the paths to the documents are changed to match the names.
The conclusion is that using names only makes things worse.
Deleted
They could do one thing, just one thing, but do it well...
Now... Where have I heard that philosophy before?
Deleted
At my institution we routinely buy back equipment from salvage yards it was sold to. But this actually makes sense. We clear out lots of old stuff rather than pack ratting it. It's a small price to pay for the convenience of getting stuff we need back.
Some drink at the fountain of knowledge. Others just gargle.
Years ago people solved this problem but they didn't document their solution well, so here we are again.
One of the uncomfortable truths (uncomfortable for MBA cost minimizers) is that know-how is between the ears. It is not in the manuals or specifications, which merely prove that their writers had the know-how. Even more important is the know-why, which is part of the institutional memory which also resides between the ears.
I have witnessed some "technology transfers" where a set of working products was transferred with documentation, design data, and much background information to a group in another region (mostly EU/US transfers). The first group is then wound down or redeployed. The new group does fine at first, until a new version of a product is needed. Then they always make mistakes the original designers would consider childish or stupid. They don't know the why behind design decisions, and don't know what to avoid. In my experience, it takes 5-10 years to build a decent product design group from scratch. On the other hand, an existing design group will sustain itself by mentoring and guidance of new inductees by experienced members.
The only successful technology transfer which I participated in was one where a few senior designers were transferred with the set of products they were responsible for. It was far from cheap in up-front costs, but it avoided the crises and financial disasters which afflicted the other transfers after a year or two.
Those who can make you believe absurdities can make you commit atrocities. - Voltaire
to do the wiring part so that the tech people have time to do the tech work.
I worked for an organization from day 1 and was involved in every project we ever worked on. After several years there, that organization wound up merging with another organization and I decided it was time for me to move on.
It's been almost a year since I left, and every day I get 2-3 emails asking me for information, and as a way for them to not feel embarrassed for asking, they actually created a 1/10th time paid position for me and the job title is, literally, "Institutional Memory."
I go in for a couple of hours every few weeks and do a data dump with one team or another, and they're slowly starting to amass documentation as to what was done and why it was done that way.
At my new job the first thing I did when I came onboard was to set us up with an internal wiki for every single project we have and everyone puts notes on the projects, why they're doing things the way they are, etc. on that. It's a good way to have as much of a paper trail as possible.
Since I can't tell them apart, I treat all ACs as the same person.
One of the things they do very well is... no, not designing chips, they suck at that, but duplicating fab plants. Down to getting everyone that's gonna work in there up to speed before the plant is finished.
The key is of course not to just build a plant. It's to build at least two plants, at least one in reality and one in the documentation. Fred Brooks (yes, exactly in his book _the mythical man-month_) explains how this works for software and computer hardware. It won't be different for processing plants, except of course that your production numbers are lower. But even with just one physical plant, you need full documentation on how to replicate it, with every task and every job described. And then, of course, you update the documentation along with any updates to the plant, bring it back up to the level where you can xerox the paper into reality again.
The test is exactly that: Can we give this to another engineer and have him duplicate the thing from that? Yes, most software documentation fails that test and is utterly useless as api docs or user manual to boot-- as if those code monkeys don't even read what they wrote, the illiterate bums. And yes, you probably should check every five or ten years if it's still understandable. If that's expensive, well, you get to pay more thirty years down the line. Or you can start from scratch, if you prefer.
Notwithstanding that this documentation archaeology an interesting excercise, but as TFA illustrates, it makes for rather schizophrenic situations, is way out of the usual corporate flow of how things normally go, cost a bundle, takes a lot of time, and is fraught with uncertainty. Care and feeding of the corporate library is future-proofing the IP assets, far more so than filling a war-chest with patents. It's about as sexy as caring for the backup tapes, but you have those too for a very good reason.
Accounting, for instance, has been done the same way for almost 500 years, yet there are thousands of accounting packages available, written in dozens of different languages, even to run on the same hardware. Some programs (Quickbooks, for instance) have been "improved" beyond comprehension while still preserving their deficiencies and shortcomings.
Once a problem is solved in programming, it should never have to be solved again. Most of the underlying code in computer systems is based on programs written back in the early days of digital computers. By adding the basic "components" together, more complex systems problems can be solved at a higher scale of interaction and complexity. So, scaling can be a problem. And, how the heck are we supposed to know where to find the original solution to the problem? (Note: There have been attempts to "hash" the common solutions and create unique, searchable identifiers, but I don't know what ever happened to those experiments. The ACM maintains and makes available a "library" of fundamental algorithims, but it is getting unmanageable.).
Now the person coming in to review or improve legacy code has a "complexity" obstacle that prevents him from easily determining the purpose and scope of the code.
In the digital world, programs work on data. Every digital program relies on sequence, alternation, and repetition. Many researchers (Djikstra, Jacopini, Martin and more) have shown that these are directly comparable to concepts in mathematical logic (sequential proof, decision rule, and quantification) and have demonstrated ways to "prove" programs correct. In today's world, we have the power to actually analyze programs, derive the structures, and prove the validity of the results at a meta-level (giving a nod to Goedel on the way). A meta system of this kind should discover what a program or system does, whether it does it correctly, and whether it does ONLY what it is supposed to. Now the problem becomes one of making the results understandable. The various packages that analyze source code and produce UML documentation are a very good start in that direction. I am concerned, because, (as recent demonstrations of Stuxnet and Duqu show) the interaction of flawed systems can have accumulating ill effects on those of us who have to depend more and more on computer systems to control our cars, our environment and the tools we use in our lives.
Not every industrial process is as easy to analyze as software. And the complexity of modern industrial processes makes it even harder to understand once the process has been analyzed. Much of industrial behavior is analog; much of it is probabilistic; and much of it depends on uncontrollable inputs such as human behavior, and human mis-interpretation of the situation. If I was part of the investigating team trying to preserve lost company know-how, I'd probably go back to anything resembling requirements analysis, and work forward from there.
"The mind works quicker than you think!"
Many companies have a tiny number of people who manage things, and then a sea of consultants who do things. Often the management of the consultant groups are consultants themselves.And even the managers of the managers are often consultants. The result? Corporate Memento syndrome. No long term memories get formed because the people who do the remembering are gone. Stuff is rar'd or stuf'd or tar balled into a series of docs that sit on a server than is run by an bunch of consultants in IT who have no idea what is on the drive.
Then the drive either fails or is dumped into a bigger storage drive and labeled in a folder "management data 2009" or whatever, and there it rots because no one has any idea what's inside, and the people with access are consultants who don't/can't know.
and why? Because it's cheaper to hire a river of consultants for 6 months than it is to hire people and keep them around for years. The result? Permanent amnesia. All of it will be lost, and no one will care. the essence of 21st century culture - digital business - will be erased and forgotten. Forever. Some would say "Good riddance", but I'm enough of an armchair anthropologist to feel the loss.
Shoes for Industry. Shoes for the Dead.
An architecture firm I contract for was trying to submit a handful of their projects for energy efficiency tax credits. This involved assembling a set of drawings and CAD files for a outside consultant to create energy models of the buildings in question. Architects are required to retain these drawings for about ten years for liability reasons, so this should be easy right...?
Haha, wrong! Sure, they retained the drawings... digitally. But nobody bothered to check that all of the cross-referenced CAD files got saved, or that the links inside of them them weren't broken when they got moved to near-line storage, or that consultant drawings were saved, or that Jimmy The Intern hadn't linked in a dozen files from his desktop for the sake of expediency and never got around to moving them to central storage before he went back to college, and then IS wiped his account. What should have been a quick dive into the archives turned into a three-month-long wild goose chase. Let's just say that I got really familiar with the large-format scanner and the AutoCAD Reference Manager tool.
I worked 30 years in astronaut training facility (full-fidelity simulators), and wrote many many documents on software that I wrote. I always kept my own digital copies, of course. Over the years, the contracts changed hands many times, and different document systems were implemented, and "all" documents were "always" converted from old to new. I was never able to later re-locate *any* document I had submitted to *any* of the document systems. So my copies of my documents were the only ones that actually existed that I knew of. This included meeting minutes, peer review notes, design and 'as-delivered' documents. So I think institutional amnesia is more the norm, and actual memory beyond 3-5 years is rare.
Pavlov wouldn't be so famous if he'd used a can opener instead of a bell.
I saw a company lose probably 60% of their IT knowledge base. They announced outsourcing six months in advance, and directed current employees to document their jobs so that offshore workers could take over. Employees instead used the time to find other jobs, as one would expect. Transition was a disaster, and a year later they're still discovering things that the company no longer knows how to do.
One of the mistakes made was to assume that everything the old team did could be described as a procedure that a junior offshore employee could follow. This is a fallacy at a basic level, and shows a basic misunderstanding of IT. Knowledge is more than just memorization of individual procedures, it's information about topology, architecture, the flow of information, how the business works, and where the knowledge points are in the organization. (Who knows what.) Degradation of that knowledge base began on the day outsourcing was announced, and by the time transition arrived, there wasn't much left.
The basic misunderstanding, I believe is thinking that IT is generic procedure-based stuff that anyone could do. There are cases where this is true, but if you are in the business of providing a web based business, your IT *is* your value add, and your success is probably based on in what way your team does things that *aren't* generic.
Oliver's law of assumed responsibility: If you're seen fixing it, you will be blamed for breaking it.
Management don't care, why should you? It really can't be all that much of a problem. More a perception than a problem. By all means go ahead and create/use a documentation system for your group but clearly there just isn't a requirement for anything more comprehensive.
All too true. The sooner you learn not to care, the sooner you will stop feeling the pain. Surrender to mediocrity; obey all rules and your managers without question. Above all, do not let your work interfere with your life. You will be a happier person, and probably get promoted. Listen to me, oh young ones...heed the words of the Ancient One: Despair!
Once upon a time, I worked in a relatively small organization within a Very Large Company. The VLC was renowned for its inventiveness, until a new manager came who felt that inventing things was much too expensive; it would be more profitable to just to put the word "Invent" on the corporate logo, and then re-sell stuff from countries who make things cheaply. Because our corporate logo was on these re-branded products, we must obviously have invented them. Thus, marketing ceased to be a partner of R&D, and instead replaced it. Clever, eh?
One of my contributions to the VLC was a simple document management system (DMS). My boss mentioned that all the engineers in our lab kept complaining that "they can't find anything"—specifically, nobody could find old documentation for code that was written by vanished civilizations of programmers that had previously labored at the lab. In fact, it turned out that this was a general problem among the labs of the VLC, and that they all wished mightily for a solution. Apart from really ancient projects (from, say 10 years ago), it was pretty difficult to find documentation for even recent projects, as each lab had a different way of organizing its documentation, different document formats, and no channels for distributing the documentation to other groups who might have a legitimate interest. So I brought in an easy-to-use and easily maintained DMS, pitched it to the engineers at our lab, and got them to use it. My boss then made me contact a bunch of other labs, and offer them the use of the same DMS. A lot of their engineers liked it, and there was much happiness. I got lots of pats on the back for what was really a pretty simple idea, and my boss loved me for it. A year later, I was laid off.
As I was the only one maintaining this system, and no one ever asked me to train a replacement, I doubt that this DMS—and its contents—survived, save perhaps as digital ghosts on some unlabeled backup media in a faraway storage cave. In a sense, I'm one of the perpetrators of information decay; I caused all the knowledge deposited in "my" DMS to get black-holed. Come to think of it, this is probably not a problem; I'm pretty sure they've laid off all the engineers by now.
I understood very well that simply setting up a DMS was not the cure for the I-can't-find-anything problem. It was a beginning, at best. What was needed was a comittment by the organization as a whole to make sure the information continued to be available for as long as the company exists. Because engineering practices change, so do documentation practices; documentation technologies themselves change—not to mention physical storage media and data encoding. My DMS probably should have been replaced with something better by now (if it had continued in use), and that means someone would have had to plan the transition, and move the old docs to the new system. Maybe the best thing to do is print everything as hard copy from time to time, and hire a librarian to keep track of this backup.
Considering how much has been said and written (and blathered) about "knowledge management", it's amazing how little attention is ever given to the temporal aspect of institutional knowledge. Every engineering company should have an Office of Knowledge that has as part of its responsibility not
Great men are almost always bad men--Lord Acton's Corollary
Sure, it's great to help out the company and as engineers we like to just get things done. The problem is that the legal department doesn't give a fuck and would sooner sue you than allow anything to get done on time. Burning your personal copies of the documents might not help the project get done, but it will save your ass should anyone with malicious intent start asking why you have documents you're not allowed to have. You're a consultant so it's not like a project failure is going to cost you your job. I don't know how risky this is because I don't know the details of the situation, but there's no way I'd risk my neck, and career, over a company I left many years ago that wasn't competent enough to keep its own damn files.
-1 disagree is not a modifier for a reason. -1 troll, flaimbait, redundant, overrated are NOT acceptable substitutes.
There have been a lot of nice and informative comments to this point about the various facets and symptoms of the problem, but here is the problem itself: Corporate Attitudes.
1: Companies don't give you time to write peer-reviewed documentation because that doesn't contribute to Time To Market and overall productivity.
2: Companies seldom ask you to train your replacement in the I.T. world because they don't want you around once you realize that you're about to be laid off/fired. Who in I.T. hasn't had the experience yet of being marched off the property under the watchful eye of somebody (I've had it done where they guy actually carried a gun) within an hour of being told that you don't work here any longer. You find that you passwords were disabled during your 15 minute (at most) exit interview and given a box to clean out your work-area under guard.
3: Most importantly, the corporate belief is that nobody is indispensable, and they're willing to prove it with you no matter how much you know that no one else does because the more senior that you were, the less anyone else was watching over what you did in the first place.
In short, you're gone and they simply don't appreciate or value what they lost with you. And find this far more prevalent in I.T. than in most other areas.
The flip-side is that you've probably also been hired at least once to pick up and complete an undocumented project of someone else that they previously let go. Isn't that fun?
"It's the height of ridiculousness to say for those 9 lines you get hundreds of millions."
I've seen it happen at a software company. They have a Knowledge Base that the technicians recorded every solution, the causes, and any fixes that we could find. There was a bit of duplication of entries due to some issues being described or even experienced improperly, not to mention the occasional insufficient or improper use of keywords and descriptions.
Some higher up got the bright idea of merging the duplicate documents to save storage space. That was fine. Then they decided to expand it to eliminate entries that hadn't been accessed in 6 months or longer. That was moronic. Sure enough, it wasn't long before it turned around and bit us in the backside. But management wouldn't budge. They refused to restore the old documents, even when it was on something we now needed, nor would they stop deleting stuff that hadn't been accessed for a while.
To add insult to injury, they would then use the count of how many documents you had in the KB against you if it wasn't high enough. Well, Soandso, you only have 120 documents, why should I listen to you instead of Otherguy, he's got 14657 documents and is in charge of the KB cleanup.
You see, the guys doing the KB cleanup and deduplication were going through all the documents and replacing the owner/creator names with their own so they could bloat their own credit, and management (at least the part I had to deal with) was too stupid to understand this. I have no idea how they rationalized that somebody who'd only worked for the company for less than 2 years could have written thousands of documents that were over 4 years old.
Yes, in a somewhat different form, this probably affects all companies in one way or another.
Maybe that B.A. in History isn't such a bad degree to have after all. Now all you need to do is convince corporations they need to have a history department to manage all of their documentation in such a way that it is discoverable and accessible.
One of my favorite lines is, "Your data is secure. We just can't access it." In other words, if you are going to use a particular medium as an archive, you need to ensure that the data can be read from that medium, in perpetuity. If the technology is in danger of becoming obsolete, the archived data must be moved forward to new media.
Of course, that isn't enough. The data must be indexed in such a way that the information you need can be found. Finding a needle in a haystack is easy with modern technology; finding a hand-drawn flow chart explaining how a particular "black box" in your manufacturing plant converts X to Y (and why it's painted blue) among hundreds of thousands of pages of poorly indexed documentation is exceedingly difficult.
Give me my freedom, and I'll take care of my own security, thank you.
This reminds me of Pump 6, by Paolo Bacigalupi: "...it made me nervous thinking about all those maintenance warnings glowing down there in the dark: Mercury Extender Seal, Part #5970-34, Damaged, replace. Whatever the hell that meant."
The Leaky Establishment, where the large engineering firm is the Atomic Weapons Establishment and the item to be smuggled back in is a physics package.
For my entire adult life I worked in the medical diagnostic device industry and somewhere in the late late 80's and electronic documentation & email really started to take over. Then following a series of lawsuits the corporate SOP began to change. We went from loose organization in directories to using versioning tools for documents. And we went from what was essentially unlimited email storage to smaller and smaller... eventually ending up in 2005 with mandated culling policies. (mostly as a proactive defensive legal strategy).
By my nature, I am digital packrat. I still have all the email I have ever received or sent, in curated archives. I still have all the documents I have created. I still have all the code I have ever written. I still have all the design docs I have ever created. And I still have the knowledge management system I created to curate all of that data.
So, my nature and corporate policy really began to conflict more and more strongly. For about 12 years I used my own hardware for backups with my management looking the other way. Eventually I was told the backup strategy had to go and to take all my stuff home. That was replaced by corporate supplied laptop which I routinely took home to backup.
I took early retirement in 2009 and in late 2010 was asked back to resolve a thorny problem with some of the in-house equipment I had a hand designing. The current site manager, who I have a lot of disagreements with but is a nice guy, assessed the parts of my personal archive that I brought in with me as "The largest and most frightening example of industrial espionage he had ever seen"... and wanted to buy it from me so he could destroy it.
Nothing in the world is more dangerous than sincere ignorance and conscientious stupidity.
I used to work as a consultant for a very large, global computer manufacturer/consultancy as Solutions Architect. More than once I had to quickly find an available system to implement a customer's outsourcing solution as the normal lead time for a new system was 1 month+! (And before you start yelling "Virtual Servers", these customers required independent physical servers.)
Sometimes I had to go through a list of servers on a specific subnet, match that up with a list of servers from the routine network scans to see if all were accounted for, if not, I would try to find the server in the server room, get its ID from the chassis, go back to the inventory system, try to find the server there and hopefully an owner too.
Occasionally I could either not find the system in the inventory system or no owner was assigned. I would then have a private chat with the hardware people responsible for the area the servers were placed and suddenly the relevant servers would have an "unscheduled network outage", i.e. the operator would unplug the system and we would wait for somebody to start screaming. If that did not happen within a day or so, we would dump the system's data to the backup system and reassign the server. This time properly documented.