Hacker News new | past | comments | ask | show | jobs | submit login

Bold claims and strong language do not make up for a lack of citations. You prefer static typing because you admit it is the only hope you have of understanding your complex code. However you dismiss other peoples' preferences by claiming they are ignorant of the systems they are building. Are you, perhaps, the one true Scotsman?



It's not possible for anyone to build complex software in a unityped language while having a full, complete, and verifiable understanding of their own system invariants at any given moment.

Claims otherwise are the literal equivalent of making complex mathematical assertions without a single condensed proof.

This isn't opinion, any more than a formal proof is opinion.


You are making an opinion as to the definition of complex software. "Complex software" means different things to different people. Additionally, you've inserted a requirement of understanding one's systems that seems arbitrary and not universally applicable. Whatever happened to each his own?


> You are making an opinion as to the definition of complex software. "Complex software" means different things to different people.

"Complex" math or "complex" engineering means different things to different people, but "mathematical proof" and "deductive reasoning" do not.

> Additionally, you've inserted a requirement of understanding one's systems that seems arbitrary and not universally applicable.

It's not arbitrary, it's how we build systems that work, and work better.

http://en.wikipedia.org/wiki/Engineering#Methodology

"By understanding the constraints, engineers derive specifications for the limits within which a viable object or system may be produced and operated."

Without understanding one's system, it is impossible to understand its relation to one's constraints, and it is impossible to define the specifications within which that system operates.

It's possible to build a car or an engine without understanding the math and science behind them, but it's impossible to build an engine of known specifications, it's impossible to provably assert that it operates within those specifications, and it's impossible to engage in directed design based on those specifications and defined operational limits.

The best you can hope for is purely empirical evidence, and empirical evidence is of limited utility without a theoretical framework in which it can be applied to extrapolate further knowledge.

As a result, systems designed and implemented without concern for understanding the theoretical basis of their operation invariably perform more poorly and cannot compete with systems designed and implemented based on building and applying a theoretically driven specification and understanding of constraints.

To willfully prefer ignorance is objectively worse.

> Whatever happened to each his own?

Applied maths. It's either correct and verifiable or it's not.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: