• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EST 02:11
CET 08:11
KST 16:11
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
RSL Season 3 - Playoffs Preview0RSL Season 3 - RO16 Groups C & D Preview0RSL Season 3 - RO16 Groups A & B Preview2TL.net Map Contest #21: Winners12Intel X Team Liquid Seoul event: Showmatches and Meet the Pros10
Community News
Weekly Cups (Nov 24-30): MaxPax, Clem, herO win2BGE Stara Zagora 2026 announced15[BSL21] Ro.16 Group Stage (C->B->A->D)4Weekly Cups (Nov 17-23): Solar, MaxPax, Clem win3RSL Season 3: RO16 results & RO8 bracket13
StarCraft 2
General
Chinese SC2 server to reopen; live all-star event in Hangzhou Maestros of the Game: Live Finals Preview (RO4) BGE Stara Zagora 2026 announced Weekly Cups (Nov 24-30): MaxPax, Clem, herO win SC2 Proleague Discontinued; SKT, KT, SGK, CJ disband
Tourneys
StarCraft Evolution League (SC Evo Biweekly) RSL Offline Finals Info - Dec 13 and 14! RSL Offline FInals Sea Duckling Open (Global, Bronze-Diamond) $5,000+ WardiTV 2025 Championship
Strategy
Custom Maps
Map Editor closed ?
External Content
Mutation # 502 Negative Reinforcement Mutation # 501 Price of Progress Mutation # 500 Fright night Mutation # 499 Chilling Adaptation
Brood War
General
BW General Discussion Which season is the best in ASL? Data analysis on 70 million replays BGH Auto Balance -> http://bghmmr.eu/ [ASL20] Ask the mapmakers — Drop your questions
Tourneys
[BSL21] RO16 Group D - Sunday 21:00 CET [BSL21] RO16 Group A - Saturday 21:00 CET [Megathread] Daily Proleagues [BSL21] RO16 Group B - Sunday 21:00 CET
Strategy
Current Meta Game Theory for Starcraft How to stay on top of macro? PvZ map balance
Other Games
General Games
Stormgate/Frost Giant Megathread ZeroSpace Megathread Nintendo Switch Thread The Perfect Game Path of Exile
Dota 2
Official 'what is Dota anymore' discussion
League of Legends
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Deck construction bug Heroes of StarCraft mini-set
TL Mafia
Mafia Game Mode Feedback/Ideas TL Mafia Community Thread
Community
General
US Politics Mega-thread Things Aren’t Peaceful in Palestine Russo-Ukrainian War Thread The Big Programming Thread Artificial Intelligence Thread
Fan Clubs
White-Ra Fan Club
Media & Entertainment
[Manga] One Piece Movie Discussion! Anime Discussion Thread
Sports
2024 - 2026 Football Thread Formula 1 Discussion NBA General Discussion
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
Where to ask questions and add stream? The Automated Ban List
Blogs
James Bond movies ranking - pa…
Topin
Esports Earnings: Bigger Pri…
TrAiDoS
Thanks for the RSL
Hildegard
Saturation point
Uldridge
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1401 users

The Big Programming Thread - Page 516

Forum Index > General Forum
Post a Reply
Prev 1 514 515 516 517 518 1032 Next
Thread Rules
1. This is not a "do my homework for me" thread. If you have specific questions, ask, but don't post an assignment or homework problem and expect an exact solution.
2. No recruiting for your cockamamie projects (you won't replace facebook with 3 dudes you found on the internet and $20)
3. If you can't articulate why a language is bad, don't start slinging shit about it. Just remember that nothing is worse than making CSS IE6 compatible.
4. Use [code] tags to format code blocks.
obesechicken13
Profile Blog Joined July 2008
United States10467 Posts
September 02 2014 02:57 GMT
#10301
On September 02 2014 11:54 icystorage wrote:
Show nested quote +
Like if you're the type who always underestimates try to double your score each time.


doesnt this make you look bad? Time is very valuable to the clients and I believe we are billed by the hour, so therefore the more time the task takes then it'll discourage the client? (just pure speculation, i actually have no idea, I have <1 year worth of experience in my job, also first job)

I don't have much experience either, and yes it will potentially look bad, but I think saying you'll get something done in 1 day and spending 4 days is worse than just saying it'll be done in 4 days and doing it in 4 days.
I think in our modern age technology has evolved to become more addictive. The things that don't give us pleasure aren't used as much. Work was never meant to be fun, but doing it makes us happier in the long run.
icystorage
Profile Blog Joined November 2008
Jollibee19350 Posts
September 02 2014 02:59 GMT
#10302
Hmm, okay thanks I'll think about what you said
LiquidDota StaffAre you ready for a Miracle-? We are! The International 2017 Champions!
Cyx.
Profile Joined November 2010
Canada806 Posts
September 02 2014 04:10 GMT
#10303
On September 02 2014 11:57 obesechicken13 wrote:
Show nested quote +
On September 02 2014 11:54 icystorage wrote:
Like if you're the type who always underestimates try to double your score each time.


doesnt this make you look bad? Time is very valuable to the clients and I believe we are billed by the hour, so therefore the more time the task takes then it'll discourage the client? (just pure speculation, i actually have no idea, I have <1 year worth of experience in my job, also first job)

I don't have much experience either, and yes it will potentially look bad, but I think saying you'll get something done in 1 day and spending 4 days is worse than just saying it'll be done in 4 days and doing it in 4 days.

Not that I know more than you guys after my first internship… but I've always had mega problems with estimating times for myself in all walks of life, and from what I've seen, it looks WAY better to say 'six days' and finish in four than it does to say 'three days' and finish in four. I've started to just try to overestimate everything by 50% - that way you don't look bad if you fuck it up (if you're fucking up by more than 50% then either you didn't know what you had to do or you're just being stupid to try and look good) and you also don't seem like you're incompetent for guessing 3x what everyone else would for that task
icystorage
Profile Blog Joined November 2008
Jollibee19350 Posts
September 02 2014 04:13 GMT
#10304
Incompetent was the word I was looking for rofl
LiquidDota StaffAre you ready for a Miracle-? We are! The International 2017 Champions!
WolfintheSheep
Profile Joined June 2011
Canada14127 Posts
September 02 2014 04:24 GMT
#10305
Isn't it like a Golden Rule that any estimates should be done with the assumption that Life absolutely despises you and everything you do?
Average means I'm better than half of you.
CatNzHat
Profile Blog Joined February 2011
United States1599 Posts
September 02 2014 08:30 GMT
#10306
On September 02 2014 11:24 icystorage wrote:
for the software engineers, how do you deal with estimates? I wasnt taught about it in college (even though i majored in software engineering) but probably because its pretty dynamic? How do you give estimates that doesnt make you look bad (estimating a very huge time for a task)? If you give a pretty short deadline it would also doesnt give you any leeway. What factors should you consider in giving an estimate on a task(s)?

I'm responsible for time estimates for myself and my team, so this is something I do lot of.

Before I give an estimate on a project I break it down into small chunks and give the architecture a bit of thought. Usually we have existing design patterns in place so it's pretty straight forward, and if not I'll grab some of the guys with the relevant experience and we'll figure it out.

After I know what we're building, and how we're building it, I figure out who's doing what. I figure out what engineers on my team are available, and then work with them to figure out who will build what.

Now I know what we're building, how we're building it, and who's doing what. Given that I've worked these guys for 6 months I know how quickly they get things done so it's actually pretty straight forward. Don't forget about test coverage, UAT, and planning for a safe release (with rollback ability).

The most important thing is to communicate changes in the timeline if you run into an un-expected challenge. Sometimes it's as mundane as an engineer not feeling well, other times you discover performance issues and have to re-architect the whole thing.
Encdalf
Profile Joined February 2012
Germany66 Posts
September 02 2014 08:32 GMT
#10307
From my experience (15y now) giving timing estimates is hard, and with more experience it remains difficult.

When being asked how much time will something take, always take your time to reflect upon it, or request time to calulate it. Once your say a number, that number is out. Even if they say "just give us a number, we won't pin you down on that" be damn sure about what you say. And don't be afraid to say "I need more time to calculate that".

E.g. I'm working on a project right now where I got asked how long it will take, as a rough estimate. I said approx. 8 days. The project manager tells the client, hey it will take about 8 days, the client understands it will be done in 8, and 6 days later I got asked if they can start testing and I'm like.. wtf?
In this case the unkown factor was the project manager. I worked with him for the first time, and if I would have know that he tells my estimate as a fact, I would have gone higher.

In the end, stating a higher number isn't bad, as long as you don't overdo it.
If I have problems estimating a task or project, what I usually do is break the task down into smaller chunks and try to calculate that. In the end add it together, and ontop of that, add extra time for testing, debugging, communication & coordination, and if required documentation.
And when you have that number, add the amount of x. And that is the magic number for unknown variables, or unexpected stuff happening. For me that's usually around 10-20%.

The bonus of breaking it down is that you can use that list as your reference and check while working on the project if you meet your estimates. And if you don't, the next time you can change it accordingly and our estimates will get better.
icystorage
Profile Blog Joined November 2008
Jollibee19350 Posts
September 02 2014 09:13 GMT
#10308
Thank you for giving your insights regarding estimation. This has totally fucked up my first project since I blindly estimated it without really breaking it down. I will base my future estimates from what I read here Really helpful
LiquidDota StaffAre you ready for a Miracle-? We are! The International 2017 Champions!
bangsholt
Profile Joined June 2011
Denmark138 Posts
September 02 2014 14:16 GMT
#10309
Estimate each part to your best ability, if you've tried the task before. Otherwise, my rule of thumb is that I multiply the hours by two.

Then I take the full estimate and multiply by pi.

I've had a situation where I had to do a small embedded system which literally was 50 lines of code, which took around 2 hours to write, and then it took 5 days to make it integrate well with the physical system it was controlling. I did *no* coding.

But it's easily transferable to software - you write the software in 2 hours, then you spent 5 days setting up the environment it has to run in... Never forget to factor in things that aren't directly related to your task. If you're working for a client they most likely haven't thought of it either or they have their own convoluted systems you need to integrate into.
obesechicken13
Profile Blog Joined July 2008
United States10467 Posts
September 02 2014 14:45 GMT
#10310
On September 02 2014 17:30 CatNzHat wrote:
Show nested quote +
On September 02 2014 11:24 icystorage wrote:
for the software engineers, how do you deal with estimates? I wasnt taught about it in college (even though i majored in software engineering) but probably because its pretty dynamic? How do you give estimates that doesnt make you look bad (estimating a very huge time for a task)? If you give a pretty short deadline it would also doesnt give you any leeway. What factors should you consider in giving an estimate on a task(s)?

I'm responsible for time estimates for myself and my team, so this is something I do lot of.

Before I give an estimate on a project I break it down into small chunks and give the architecture a bit of thought. Usually we have existing design patterns in place so it's pretty straight forward, and if not I'll grab some of the guys with the relevant experience and we'll figure it out.

After I know what we're building, and how we're building it, I figure out who's doing what. I figure out what engineers on my team are available, and then work with them to figure out who will build what.

Now I know what we're building, how we're building it, and who's doing what. Given that I've worked these guys for 6 months I know how quickly they get things done so it's actually pretty straight forward. Don't forget about test coverage, UAT, and planning for a safe release (with rollback ability).

The most important thing is to communicate changes in the timeline if you run into an un-expected challenge. Sometimes it's as mundane as an engineer not feeling well, other times you discover performance issues and have to re-architect the whole thing.

While the information you provided is valuable, I don't think you answered the question directly. That was a very "political answer". How do you do estimates once you've deconstructed the project?

Since you have project manager experience I would assume you want your estimates to be accurate. How do you deal with cases where people seem to underestimate or overestimate? Do people have to often stay late when they underestimate? Do you/managers ask for an explanation for overestimates?

Also relevant skit:
I think in our modern age technology has evolved to become more addictive. The things that don't give us pleasure aren't used as much. Work was never meant to be fun, but doing it makes us happier in the long run.
Blisse
Profile Blog Joined July 2010
Canada3710 Posts
Last Edited: 2014-09-03 23:38:31
September 03 2014 23:37 GMT
#10311
Lesson I learned is don't be too eager in estimating, I'm just going to triple my initial estimates because I suck at them :') Meeting deadlines late looks really bad, making deadlines earlier looks great.
There is no one like you in the universe.
Detri
Profile Blog Joined February 2011
United Kingdom683 Posts
September 04 2014 00:48 GMT
#10312
On September 02 2014 13:24 WolfintheSheep wrote:
Isn't it like a Golden Rule that any estimates should be done with the assumption that Life absolutely despises you and everything you do?



Yes, yes it is. I recently had an issue where a database wasn't properly loading data on startup, so I had to write a bat file to query the db via a stored proc then stick that into a .csv and type it back out to com(first 5 and last 5 lines). Thought it would take a 20 mins top...


On linux ofc it would be no problem - but it was a wintel host so no head command took me best part of 4 hours to get it to work correctly.


12 times longer than I originally thought it would take... also the hatred of windows grows stronger every day
The poor are thieves, beggars and whores, the rich are politicians, solicitors and courtesans...
berated-
Profile Blog Joined February 2007
United States1134 Posts
September 04 2014 01:06 GMT
#10313
Clean Coder by Uncle Bob touches on a lot of subjects about being a professional, estimation being one. If you haven't read the book, its not a bad read. It's not quite as good as Clean Code, but, it's good enough to be helpful. I especially enjoyed the chapters on saying no.

They discuss using this technique for estimation. I have used it a few times, and it seems okay...if I could just remember to use it more often.
nunez
Profile Blog Joined February 2011
Norway4003 Posts
Last Edited: 2014-09-04 14:11:02
September 04 2014 14:02 GMT
#10314
i wish you could expand parameter packs like this in cpp (the sought after, but invalid, expansion is marked with brackets):
template<class... t_n,class t_i>
some_t function(t_i&& value){
switch(value.index){
case index_of<[t_n],t_n...>::value:{
some_functionality dependant on types in t_n
};[...]
}

result
template<class... t_n,class t_i>
some_t function(t_i&& value){
switch(value.index){
case 0:{
some_functionality dependant on t_0
};
other cases
case i:{
some_functionality dependant on t_i
};
other cases
case (n-1):{
some_functionality dependant on t_(n-1)
};
}


would be so insanely sweet and fast for mux / variant / vistiable type classes.

similarly (only one expansion here, so don't have to mark the one i'm after)
template<int... indexes>
some_t function(){
return some_ndim_array[indexes]...;
}

result
template<int... indexes>
some_t function(){
return some_ndim_array[index_0][other indexes][index_(n-1)];
}


instead of just being invalid.
conspired against by a confederacy of dunces.
Blisse
Profile Blog Joined July 2010
Canada3710 Posts
September 04 2014 14:37 GMT
#10315
What can you do with an Intel Galileo? It doesn't have a case so it's just a pcb o.O
There is no one like you in the universe.
Craton
Profile Blog Joined December 2009
United States17274 Posts
September 04 2014 22:31 GMT
#10316
I've been on agile projects for the last couple years. Basically everything is chunked into a story "as x I want to be able to do y," which is then detailed into tasks. After tasking, it's pointed on a fibonacci scale, where the higher the number the less certain you are about how long it'll take and generally also means it's at higher risk of slipping. How long each point to changes based on the team, but the point is to be consistent.

Once you've done an approach like this for a period of time, it gets relatively easy to approximate how long something will take and how much bandwidth you and your team has. Importantly, by splitting everything into stories and then tasking out each story, it's a lot easier to make an estimation because you've teased out most of the requirements and hurdles.

Underestimating is usually worse than overestimating because it throws off timelines to a greater degree (people end up waiting because they're dependent and expected it to finish days ago, etc), but consistently overestimating is also bad.
twitch.tv/cratonz
scudst0rm
Profile Joined May 2010
Canada1149 Posts
September 05 2014 16:55 GMT
#10317
On September 04 2014 23:37 Blisse wrote:
What can you do with an Intel Galileo? It doesn't have a case so it's just a pcb o.O


Build something with it, it's just an arduino board with an intel chip which I assume is faster then their usual atmel chips.
You're like a one ranger army comin' at me...
Blisse
Profile Blog Joined July 2010
Canada3710 Posts
September 05 2014 17:42 GMT
#10318
On September 06 2014 01:55 scudst0rm wrote:
Show nested quote +
On September 04 2014 23:37 Blisse wrote:
What can you do with an Intel Galileo? It doesn't have a case so it's just a pcb o.O


Build something with it, it's just an arduino board with an intel chip which I assume is faster then their usual atmel chips.


Yeah I know, I'm just not sure since it doesn't have a case so I can't like put it anywhere
There is no one like you in the universe.
bangsholt
Profile Joined June 2011
Denmark138 Posts
September 05 2014 18:11 GMT
#10319
On September 06 2014 02:42 Blisse wrote:
Show nested quote +
On September 06 2014 01:55 scudst0rm wrote:
On September 04 2014 23:37 Blisse wrote:
What can you do with an Intel Galileo? It doesn't have a case so it's just a pcb o.O


Build something with it, it's just an arduino board with an intel chip which I assume is faster then their usual atmel chips.


Yeah I know, I'm just not sure since it doesn't have a case so I can't like put it anywhere


Unless you intend to put it into high humidity or outside, it doesn't really matter.
Blisse
Profile Blog Joined July 2010
Canada3710 Posts
September 05 2014 21:34 GMT
#10320
On September 06 2014 03:11 bangsholt wrote:
Show nested quote +
On September 06 2014 02:42 Blisse wrote:
On September 06 2014 01:55 scudst0rm wrote:
On September 04 2014 23:37 Blisse wrote:
What can you do with an Intel Galileo? It doesn't have a case so it's just a pcb o.O


Build something with it, it's just an arduino board with an intel chip which I assume is faster then their usual atmel chips.


Yeah I know, I'm just not sure since it doesn't have a case so I can't like put it anywhere


Unless you intend to put it into high humidity or outside, it doesn't really matter.


Oh I see. Cool, thanks
There is no one like you in the universe.
Prev 1 514 515 516 517 518 1032 Next
Please log in or register to reply.
Live Events Refresh
Replay Cast
00:00
WardiTV Mondays #62
LiquipediaDiscussion
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
SortOf 119
-ZergGirl 62
StarCraft: Brood War
Stork 941
Tasteless 234
Sacsri 100
Shine 56
Bale 45
ZergMaN 20
Dota 2
febbydoto297
NeuroSwarm165
canceldota1
League of Legends
JimRising 621
Other Games
summit1g11104
WinterStarcraft575
C9.Mang0316
crisheroes189
RuFF_SC298
Mew2King40
Organizations
Other Games
gamesdonequick669
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 13 non-featured ]
StarCraft 2
• Berry_CruncH164
• practicex 34
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
League of Legends
• Lourlo1281
Upcoming Events
The PondCast
2h 49m
OSC
8h 49m
Demi vs Mixu
Nicoract vs TBD
Babymarine vs MindelVK
ForJumy vs TBD
Shameless vs Percival
Replay Cast
16h 49m
Korean StarCraft League
1d 19h
CranKy Ducklings
2 days
WardiTV 2025
2 days
SC Evo League
2 days
BSL 21
2 days
Sziky vs OyAji
Gypsy vs eOnzErG
OSC
2 days
Solar vs Creator
ByuN vs Gerald
Percival vs Babymarine
Moja vs Krystianer
EnDerr vs ForJumy
sebesdes vs Nicoract
Sparkling Tuna Cup
3 days
[ Show More ]
WardiTV 2025
3 days
OSC
3 days
BSL 21
3 days
Bonyth vs StRyKeR
Tarson vs Dandy
Replay Cast
4 days
Wardi Open
4 days
StarCraft2.fi
4 days
Monday Night Weeklies
4 days
Replay Cast
4 days
WardiTV 2025
5 days
StarCraft2.fi
5 days
PiGosaur Monday
5 days
StarCraft2.fi
6 days
Tenacious Turtle Tussle
6 days
Liquipedia Results

Completed

Proleague 2025-11-30
RSL Revival: Season 3
Light HT

Ongoing

C-Race Season 1
IPSL Winter 2025-26
KCM Race Survival 2025 Season 4
YSL S2
BSL Season 21
CSCL: Masked Kings S3
Slon Tour Season 2
Acropolis #4 - TS3
META Madness #9
SL Budapest Major 2025
ESL Impact League Season 8
BLAST Rivals Fall 2025
IEM Chengdu 2025
PGL Masters Bucharest 2025
Thunderpick World Champ.
CS Asia Championships 2025
ESL Pro League S22
StarSeries Fall 2025
FISSURE Playground #2

Upcoming

BSL 21 Non-Korean Championship
Acropolis #4
IPSL Spring 2026
Bellum Gens Elite Stara Zagora 2026
HSC XXVIII
RSL Offline Finals
WardiTV 2025
Kuram Kup
PGL Cluj-Napoca 2026
IEM Kraków 2026
BLAST Bounty Winter 2026
BLAST Bounty Winter Qual
eXTREMESLAND 2025
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2025 TLnet. All Rights Reserved.