• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 02:35
CEST 08:35
KST 15:35
  • 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
[ASL21] Ro4 Preview: On Course6Code S Season 1 - RO8 Preview7[ASL21] Ro8 Preview Pt2: Progenitors8Code S Season 1 - RO12 Group A: Rogue, Percival, Solar, Zoun13[ASL21] Ro8 Preview Pt1: Inheritors16
Community News
Maestros of The Game 2 announcement and schedule !7Weekly Cups (April 27-May 4): Clem takes triple0RSL Revival: Season 5 - Qualifiers and Main Event12Code S Season 1 (2026) - RO12 Results12026 GSL Season 1 Qualifiers25
StarCraft 2
General
Code S Season 1 - RO8 Preview Behind the Blue - Team Liquid History Book Weekly Cups (April 27-May 4): Clem takes triple Blizzard Classic Cup @ BlizzCon 2026 - $100k prize pool Code S Season 1 (2026) - RO12 Results
Tourneys
GSL Code S Season 1 (2026) WardiTV Mondays Sparkling Tuna Cup - Weekly Open Tournament Sea Duckling Open (Global, Bronze-Diamond) Maestros of The Game 2 announcement and schedule !
Strategy
Custom Maps
[D]RTS in all its shapes and glory <3 [A] Nemrods 1/4 players
External Content
Mutation # 525 Wheel of Misfortune The PondCast: SC2 News & Results Mutation # 524 Death and Taxes Mutation # 523 Firewall
Brood War
General
[ASL21] Ro4 Preview: On Course Quality of life changes in BW that you will like ? Why there arent any 256x256 pro maps? RepMastered™: replay sharing and analyzer site BGH Auto Balance -> http://bghmmr.eu/
Tourneys
[ASL21] Semifinals A [BSL22] RO16 Group Stage - 02 - 10 May [Megathread] Daily Proleagues [ASL21] Ro8 Day 3
Strategy
Simple Questions, Simple Answers Fighting Spirit mining rates Muta micro map competition What's the deal with APM & what's its true value
Other Games
General Games
Warcraft III: The Frozen Throne Stormgate/Frost Giant Megathread Path of Exile Nintendo Switch Thread Daigo vs Menard Best of 10
Dota 2
The Story of Wings Gaming
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
Vanilla Mini Mafia Mafia Game Mode Feedback/Ideas TL Mafia Community Thread Five o'clock TL Mafia
Community
General
Russo-Ukrainian War Thread US Politics Mega-thread UK Politics Mega-thread The Letting Off Steam Thread European Politico-economics QA Mega-thread
Fan Clubs
The IdrA Fan Club
Media & Entertainment
Anime Discussion Thread [Manga] One Piece [Req][Books] Good Fantasy/SciFi books
Sports
2024 - 2026 Football Thread McBoner: A hockey love story Formula 1 Discussion
World Cup 2022
Tech Support
streaming software Strange computer issues (software) [G] How to Block Livestream Ads
TL Community
The Automated Ban List
Blogs
How EEG Data Can Predict Gam…
TrAiDoS
ramps on octagon
StaticNine
Funny Nicknames
LUCKY_NOOB
Customize Sidebar...

Website Feedback

Closed Threads



Active: 2160 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 States17282 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
Next event in 1h 25m
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
Nina 130
StarCraft: Brood War
GuemChi 5746
Zeus 808
BeSt 746
Pusan 150
soO 55
Bale 27
Icarus 7
ZergMaN 6
Dota 2
monkeys_forever317
League of Legends
JimRising 710
Counter-Strike
m0e_tv572
Other Games
summit1g14367
C9.Mang0410
ViBE135
RuFF_SC225
Organizations
Counter-Strike
PGL14561
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
[ Show 13 non-featured ]
StarCraft 2
• Berry_CruncH246
• practicex 22
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
League of Legends
• TFBlade342
Upcoming Events
GSL
1h 25m
Afreeca Starleague
3h 25m
Soma vs Leta
Wardi Open
5h 25m
Monday Night Weeklies
9h 25m
OSC
17h 25m
CranKy Ducklings
1d 3h
Afreeca Starleague
1d 3h
Light vs Flash
Replay Cast
2 days
Replay Cast
2 days
The PondCast
3 days
[ Show More ]
Replay Cast
3 days
RSL Revival
4 days
Korean StarCraft League
4 days
RSL Revival
5 days
BSL
5 days
GSL
6 days
Cure vs TBD
TBD vs Maru
BSL
6 days
Liquipedia Results

Completed

CSL 2026 SPRING (S20)
WardiTV TLMC #16
Nations Cup 2026

Ongoing

BSL Season 22
ASL Season 21
IPSL Spring 2026
KCM Race Survival 2026 Season 2
Acropolis #4
KK 2v2 League Season 1
BSL 22 Non-Korean Championship
SCTL 2026 Spring
RSL Revival: Season 5
2026 GSL S1
Asian Champions League 2026
IEM Atlanta 2026
PGL Astana 2026
BLAST Rivals Spring 2026
IEM Rio 2026
PGL Bucharest 2026
Stake Ranked Episode 1
BLAST Open Spring 2026
ESL Pro League S23 Finals
ESL Pro League S23 Stage 1&2

Upcoming

YSL S3
Escore Tournament S2: W7
Escore Tournament S2: W8
CSLAN 4
Kung Fu Cup 2026 Grand Finals
HSC XXIX
uThermal 2v2 2026 Main Event
Maestros of the Game 2
2026 GSL S2
BLAST Bounty Summer 2026: Closed Qualifier
Stake Ranked Episode 3
XSE Pro League 2026
IEM Cologne Major 2026
Stake Ranked Episode 2
CS Asia Championships 2026
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 © 2026 TLnet. All Rights Reserved.