THIS is Why List Comprehension is SO Efficient!

แชร์
ฝัง
  • เผยแพร่เมื่อ 7 ม.ค. 2025

ความคิดเห็น • 235

  • @AccessDen
    @AccessDen ปีที่แล้ว +271

    If you have complex operations in a list comprehension it is almost always better to extract them into a function and then do something like [ f(n) for n in range(100) ]. This makes it clear that the list isn't being constructed by a recursive process and the reader can safely understand the function f independently of the range of values it is taking as input.

    • @Suntoria236
      @Suntoria236 ปีที่แล้ว +32

      Oh damn, now I’m beating myself over not using this way earlier. I’ve written some horrendously complicated list-comprehensions before…

    • @adamvinch5173
      @adamvinch5173 ปีที่แล้ว

      ⁠​⁠@@Suntoria236run “import this” in Python. “Simple is better than complex”. Even if the complicated way is a little bit more efficient, a solution that is easy to understand is way more valuable

    • @suhailmall98
      @suhailmall98 ปีที่แล้ว +3

      Or use a lambda function in the list comp

    • @DapsSenpai
      @DapsSenpai ปีที่แล้ว +19

      @@suhailmall98 this problem is specifically about not doing that to improve readability of list comprehension

    • @fisch37
      @fisch37 ปีที่แล้ว

      But what am I going to do with my seven line listcomp?!

  • @nobelphoenix
    @nobelphoenix ปีที่แล้ว +194

    This was one of the most unique python videos I've watched on yt. It's the first time I've looked under the hood of a python code. Thanks!

  • @LethalChicken77
    @LethalChicken77 ปีที่แล้ว +553

    My favorite optimization in python is rewriting my program in C++

    • @cholling1
      @cholling1 ปีที่แล้ว +91

      And if your original program uses numpy, rewriting it in C++ will probably slow it down.

    • @electronx5594
      @electronx5594 ปีที่แล้ว +18

      ​@@cholling1lmao this sent me laughing

    • @PongsiriHuang
      @PongsiriHuang ปีที่แล้ว +2

      ​@@cholling1I know numpy is quite fast but is it faster than code in C++?

    • @kirarevcrow
      @kirarevcrow ปีที่แล้ว +3

      Ofc you're gonna write a backend with C++

    • @fisch37
      @fisch37 ปีที่แล้ว +29

      ​@@PongsiriHuang Depends how good you are at C++

  • @klb-og7cp
    @klb-og7cp ปีที่แล้ว +133

    You should do more vids on writing efficient code! I think youtube lacks this type of programming content

    • @harrytsang1501
      @harrytsang1501 ปีที่แล้ว +4

      Efficient python is just python with proper use of external libraries. The most important part is still readability.
      Simply put, can you understand and work on this code 2 years from now and taken out of context

    • @l_..l.l.__l..l8833
      @l_..l.l.__l..l8833 ปีที่แล้ว

      ​@@harrytsang1501very true, use libraries written in C like numpy, and properly follow pep and you'll be fine

    • @gnikdroy
      @gnikdroy ปีที่แล้ว +9

      Trying to "microoptimize" python is pointless. If performance of lists of numbers was a concern, you would be using something like numpy anyway.
      The performance difference between a list comprehension and a for loop is never useful in python.

  • @williamjedig7480
    @williamjedig7480 ปีที่แล้ว +54

    I'm a little confused - if the main time savings arise from not having to load, precall, and call the append() function, why are the gradients of the list comprehension and for-loops so similar? It looks as though list comprehension in your example has a pretty constant time advantage. Would loading, precalling, then calling in every iteration not imply that the longer the list, the greater the time saving?

    • @Святослав-я1б
      @Святослав-я1б ปีที่แล้ว +25

      No, it doesn't "load" list like you think it does. The list is always in the memory, python just loads "header" part of the list, which is of constant size.

    • @megaing1322
      @megaing1322 ปีที่แล้ว +9

      Both are O(n) in total, just the scaling factor C is different. Each iteration takes less time, but this time is constant whether n is 10 or 10000.

    • @sobriquet
      @sobriquet ปีที่แล้ว +22

      I agree with @williamjedig7480. Since the lines are almost parallel, the overcost of the for loop method can't be caused by something in the for loop. It looks like there is no link between the graph and the disassembled code.

    • @koktszfung
      @koktszfung ปีที่แล้ว +7

      ​@@megaing1322if it is linearly scaling differently with n, then the slope would be different. Here, it is some random shift vertically.

    • @megaing1322
      @megaing1322 ปีที่แล้ว +3

      @@koktszfung You are right, his data fails to show it, I guess it's trash, i.e. not enough data points or too much noise. But correctly done, You clearly see the different slopes, and my explanation of the result you would see if you did it yourself is correct.

  • @juanmacias5922
    @juanmacias5922 ปีที่แล้ว +4

    This was amazing, thank you for the in depth answer!

  • @arduous222
    @arduous222 ปีที่แล้ว

    What makes this video great and pleasant to watch is that your presentation is not dogmatic but analytic. There are some python programmers out there arguing you should avoid using for loops because they are "not pythonic" and "not good for readibility". But you a made pretty clear case why in python list comprehension is better than for loop, and provided a balanced view in terms of readibility.

    • @scaaaarf
      @scaaaarf 16 วันที่ผ่านมา

      what you just said has 68 words in it

  • @arcanelore168
    @arcanelore168 ปีที่แล้ว +1

    Your videos are very well crafted. Keep up the good work!

  • @max-mr5xf
    @max-mr5xf ปีที่แล้ว +7

    You should also keep in mind that range is a generator and depending on its use the comprehension will return a generator too instead of the list.
    Depending on the scale (when you don’t need to keep all data in memory, when you’re working with infinite generators etc), the comprehension may make things even more useful than just faster.

    • @cholling1
      @cholling1 ปีที่แล้ว +4

      List comprehensions (in square brackets) ALWAYS return lists, even if the code inside them iterates over a range. Generator comprehensions (a parentheses) return generators.

    • @KOxArtist2
      @KOxArtist2 ปีที่แล้ว

      generator comps are so sick. i use them all the time with pytest

  • @Carberra
    @Carberra ปีที่แล้ว +1

    List comprehension ftw 😎 Really nice explanation!

  • @tomaslucenic4388
    @tomaslucenic4388 ปีที่แล้ว +5

    Top explanation! Many thanks for such high quality and easy to understand content! 🙏

  • @sorenmoller8888
    @sorenmoller8888 ปีที่แล้ว +27

    Since often times list comprehensions in python are used to filter or map elements from a list, how does the speed compare when using a list comprehension compared to using the map/filter methods?

    • @fakt7814
      @fakt7814 ปีที่แล้ว +4

      Interesting question. I think the biggest difference is that map, filter and zip are generators, so they run only when the next element needed, but no more. So if you don't need to accumulate intermediate results and you have a long chain of filtermap-like operations, it may be better to use generators at first and then iterate them. However I like to use functools.partial for lazy execution rather than generators, because they work in much more intuitive and explicit way (for example, you can't iterate through the same generator twice which can cause a bug if you're not careful, but you can use a list of partials as many times as you want).

    • @Bobbobbob984
      @Bobbobbob984 ปีที่แล้ว

      You can just use a generator expression. Haven't checked with the new optimizations. But in the past basically comprehensions were always faster because c and optimizations basically.

    • @olivierbouchez9150
      @olivierbouchez9150 ปีที่แล้ว

      Filter is a generator. It makes code more efficient, look video on itertools library.

  • @craftydoeseverything
    @craftydoeseverything ปีที่แล้ว +2

    This is such an interesting video! I had no idea about Python's `dis` library but I genuinely think I'm going to use it a lot now!

  • @dariomartin8032
    @dariomartin8032 ปีที่แล้ว +2

    Your videos are simply perfect, easy to understand, quick and simple.
    Good job, keep it up👍👍

  • @0986rashmi
    @0986rashmi 7 หลายเดือนก่อน

    Thanks for explaining why behind in each snippets

  • @prome666
    @prome666 ปีที่แล้ว +1

    Thanks, I'm just a Python beginner but I find these videos what's happening in the background very interesting. Many times I wonder why it is doing this or that and the answer is some call stack or explanation like this.

  • @samyakjain4715
    @samyakjain4715 8 หลายเดือนก่อน

    Damnn someone making non beginner content, great work mann

  • @olivierbouchez9150
    @olivierbouchez9150 ปีที่แล้ว +2

    Agree, numpy or pandas are faster, but add extra learning curves. This video is a training. Computation on a big list of number, if needed to be stored in memory, I would do it with numpy. Otherwise I will prefer a generator.

  • @spacelem
    @spacelem ปีที่แล้ว +1

    I don't use Python, but Julia has this too, and it's amazing to use (especially with Julia's actual support for multidimensional arrays).

  • @aioia3885
    @aioia3885 ปีที่แล้ว +3

    How would the time change if instead of using append, which has to sometimes reallocate another buffer, you just did something like my_array = n*[None] and then my_array[i] = x

    • @MG-xn4ug
      @MG-xn4ug ปีที่แล้ว +1

      I tested it and posted the results in a different comment. Short version is that your method is an additional ~17% faster than list comprehension.

  • @dadajonjurakuziev
    @dadajonjurakuziev ปีที่แล้ว +1

    Great explanation, thank you

  • @GrosDino216
    @GrosDino216 ปีที่แล้ว +3

    I like your font ! What is it ?

  • @kubre
    @kubre ปีที่แล้ว

    I remember doing this experiment and was amazed how much difference there was also the operator ** on list is also really fast

  • @dextrin36
    @dextrin36 ปีที่แล้ว

    Amazing video, with a great explanation!!

  • @SashoSuper
    @SashoSuper ปีที่แล้ว +1

    Well, thank you for making another video that we can learn from.

  • @_HetShah_
    @_HetShah_ ปีที่แล้ว +3

    what font do you use?

  • @jacobrosen
    @jacobrosen ปีที่แล้ว +3

    I'd love to see if there were any difference if the list in the for loop example was preallocated. Usually, when increasing the size of a list eventually the lists memory has to be reallocated to a larger block, which of course takes some time. If the list was preallocated this step would be faster

    • @MG-xn4ug
      @MG-xn4ug ปีที่แล้ว +1

      Yeah, I'd be interested to know how a more typical optimized approach compares. In C, for instance, you'd allocate the array once with its known size, then loop to assign the values, which is simple memory assignment to a known address with no overhead of function calls. I wonder if looping through the list in python with element assignments would have similar or even better performance than the comprehension version, which still is going to run into reallocating memory.

    • @MG-xn4ug
      @MG-xn4ug ปีที่แล้ว +3

      So I went ahead and tested this theory. The exact sample functions in this video, plus a "preallocated" version which is initiated using a for loop. I evaluated for various values of N, stepped by 50K all the way up to lists of size 10M, 10 averaged samples per function.
      Results:
      ~0.1067 seconds per 1000000 elements for the for-append loop
      ~0.0800 seconds... for the list comprehension (~25% faster)
      ~0.0661 seconds... for the preallocated for-assign loop (additional ~17% faster)
      All of these scale very linearly with the size of list. So the C-style version gives pretty significant additional time savings, at least for this very simplistic task.
      P.S. The graph shown in the video is pretty nonsensical. If anything, it looks like it's showing a shallower coefficient for the for-append loop.
      Also, I timed things with time.process_time(). The video shows him using perf_counter(), which isn't great for showing code efficiency because it's the total elapsed runtime including any time the process spent sleeping.

    • @jacobrosen
      @jacobrosen ปีที่แล้ว +1

      @@MG-xn4ug thanks for taking the time to test it! Interesting how the for loop is now faster!

    • @KOxArtist2
      @KOxArtist2 ปีที่แล้ว +1

      dude I knew this video was wrong. That's why I looked for this comment!

  • @tommy2117
    @tommy2117 ปีที่แล้ว

    Your content is so good, learn new thing everyday

  • @kaantureyyen
    @kaantureyyen ปีที่แล้ว +1

    Does anyone know his vs code setup? Theme, font, etc.

  • @lightning_11
    @lightning_11 ปีที่แล้ว

    "Now, the interpreter has 3 parts. 1) the compiler..." (1:50)
    Me: Hold up!! I call foul.

  • @JonyElektro
    @JonyElektro ปีที่แล้ว +3

    If I can ask... What's your VSCode theme? It looks sick

    • @tokeivo
      @tokeivo ปีที่แล้ว +1

      The colors look like typical Darkula or Dracula - not sure what's available in VSCode, but I assume one of those would be there.

  • @ploughable
    @ploughable 11 หลายเดือนก่อน

    wow, super useful, I was always asked myself if there are performance differences...

  • @no_name4796
    @no_name4796 ปีที่แล้ว +15

    It's always funny how whenever someone explain why X is faster then Y in python, it always come down to the actual C implementation of X and Y.
    It's like python is just a C wrapper
    (I use rust, btw)

    • @Maxawa0851
      @Maxawa0851 ปีที่แล้ว +5

      It quite literally is

    • @megaing1322
      @megaing1322 ปีที่แล้ว +3

      I mean, rust is just an assembly wrapper.

    • @no_name4796
      @no_name4796 ปีที่แล้ว +1

      @@megaing1322 yup, this is technically correct. Even though i want to see anyone able to write rust like code in assembly lol (well i guess python would be the same, as i guess the underlining C code is hard af)

    • @vinylSummer
      @vinylSummer ปีที่แล้ว +1

      Every programming language is a wrapper for machine code, if you really think about it

    • @benshulz4179
      @benshulz4179 ปีที่แล้ว

      @@vinylSummer no. Machine code differs greatly based on compiler, platform, etc.

  • @gustavojuantorena
    @gustavojuantorena ปีที่แล้ว +1

    Great explanation!

  • @ambervanraak
    @ambervanraak ปีที่แล้ว

    Why doesn't the python compiler detect you're only using the for loop to append and change the bytecode to a list_append instruction?

  • @column.01
    @column.01 ปีที่แล้ว

    I have one friend who insists on using list comp for everything even if it makes the code nearly unreadable in the long run. He's not dealing with large enough lists for list comprehension to really matter speed wise and just does it cause he can

  • @Indently
    @Indently ปีที่แล้ว

    1:36 Very easy to read and understand, not on my watch!

  • @rainymatch
    @rainymatch 9 หลายเดือนก่อน

    I totally love the video but the music is driving me crazy 😂. Of course, to each his own, the rest might like it, I just would like to have the option to listen to my own music or to go for silence whenever I feel! 😇 Anyway, thanks for the video, brilliant stuff. 👍

  • @aonodensetsu
    @aonodensetsu ปีที่แล้ว +1

    i write list comprehensions in multiple lines with indents so they're pretty readable even when decently complex

    • @gentlemanbirdlake
      @gentlemanbirdlake ปีที่แล้ว

      this is the way

    • @Eutropios
      @Eutropios ปีที่แล้ว

      Both Black and Ruff format it this way for you, so it's very readable

  • @mosesmbadi
    @mosesmbadi 4 หลายเดือนก่อน

    Awesome content. Quick question, what tool do you use to animate your videos?

  • @Sinke_100
    @Sinke_100 ปีที่แล้ว

    Your python game is raising, this is good content 👍🏻

  • @Wraith0100
    @Wraith0100 ปีที่แล้ว

    I learnt list comprehension like 2 days ago, though im new and it gets confusing sometimes
    But! Its so cool and i love it

  • @johanekekrantz7325
    @johanekekrantz7325 ปีที่แล้ว +4

    My perspective is that if you have to sacrifice readability for performance in python you are generally using the wrong language for the problem.
    Need a language that is easy to learn, get started with and make to make small to medium sized prototypes in? Then python is a good choice for a lot of people.
    Need a language that is fast and flexible? Then go with something like c, c++ or rust. If its just some small part you can make bindings. Even fairly simple c++ code can sometimes be thousands of times faster that the equivalent python code.

    • @cheesepie4ever
      @cheesepie4ever ปีที่แล้ว

      Theres always a middle ground of ease of use Vs performance. It doesn't have to be black and white

  • @crides0
    @crides0 10 หลายเดือนก่อน

    How does the type specialization in python 3.12 change this?

  • @fabricehategekimana5350
    @fabricehategekimana5350 ปีที่แล้ว +2

    I don't really like python but list comprehension is both performant and syntactically interesting ! Nowadays, zig is more low level than c

  • @huy906
    @huy906 ปีที่แล้ว

    cool and neat idea to toss around!

  • @kingki1953
    @kingki1953 ปีที่แล้ว +4

    Just FYI:
    You can even use list/dictionary comprehension as parameter in object or function!

  • @JosephLovesPython
    @JosephLovesPython ปีที่แล้ว +3

    Great video, and awesome animations!
    To further prove the point in the video one could do the following:
    def for_loop_preloaded(n):
    my_list = []
    # pre-load a reference to the append method as to avoid the "LOAD_METHOD" within the for loop
    append_method = my_list.append
    for x in range(n):
    append_method(x)
    return my_list
    Testing this we can see that it's quite faster than the "for_loop" function but still slightly slower than list comprehensions!

    • @epsi
      @epsi ปีที่แล้ว

      That's because it still needs to perform a lookup for the "append_method" variable each time, unlike a list comprehension that creates and uses an anonymous list (which is typically stored in a variable and/or used as a function argument after the list is complete).

  • @Idan_Nesimov
    @Idan_Nesimov ปีที่แล้ว

    very good video, love it !

  • @dany_fg
    @dany_fg 7 หลายเดือนก่อน +1

    Is this more efficient in dict and set too ?

  • @Doppel95
    @Doppel95 ปีที่แล้ว

    Do you recommend using a for-loop instead of a list-comprehension for more complex tasks just for the sake of readability or is there some trade-off at some point?

  • @lammybowers4800
    @lammybowers4800 ปีที่แล้ว

    Great video!

  • @MrRyanroberson1
    @MrRyanroberson1 ปีที่แล้ว +1

    Consideration: what if you set t = result.append and call t? This should be much faster

  • @workingguy3166
    @workingguy3166 ปีที่แล้ว +1

    What font is that

  • @SlimeyPlayzOSE
    @SlimeyPlayzOSE ปีที่แล้ว

    I wonder how this performs compared to a list(map(lambda x: x, range(n)))

  • @tom_verlaine_again
    @tom_verlaine_again ปีที่แล้ว +2

    It's very simple: the difference is because of append. If you would compare the for loop using something like "result = [0] * size_needed" and then enter the for loop and just index each result instead of appending, the performance would be very similar.

    • @lilDaveist
      @lilDaveist ปีที่แล้ว

      Shouldn’t be. Appending in python is constant if I am not mistaken.

  • @ajflink
    @ajflink 4 หลายเดือนก่อน

    I tend to write list comprehension within list comprehensions.
    Also, fun fact, there are only dictionary, set and list comprehensions in Python and they all can have comprehensions nested within each other each other.
    The one mystery that I want explained is the following example:
    num1 = 1
    num2 = num1
    What on Earth is the point of doing that? As far as I can tell, the only thing it does is make num1 and num2 point to the same object making num2 redundant. I get annoyed whenever I come across this in someone else's code.

  • @robinabashir6333
    @robinabashir6333 ปีที่แล้ว +1

    Can you please do a video on cgi using python and html forms

  • @MeerWulf
    @MeerWulf ปีที่แล้ว +1

    Isn't it moreso that append keeps being called and not that the list comprehension is actually faster

  • @felixwhise4165
    @felixwhise4165 ปีที่แล้ว

    please do more of these under the hood videos, very interesting

  • @xllAyato
    @xllAyato ปีที่แล้ว +8

    I think that it might have to do with array resizing. I do not know so much about python but in C/C++ it takes a lot longer to create a new array an refill it than creating an oversized one and just adding to the corresponding index.

    • @megaing1322
      @megaing1322 ปีที่แล้ว +9

      No, that doesn't happen here. It would in theory be possible, but as you can see from the bytecode sequence, none of those preallocate elements. `list.append` ofcourse is smart enough to correctly scale preallocation to make append O(1), but that is not a difference between the two versions. However, this would happen for example if you call `list(range(n))` instead.

    • @lucass8119
      @lucass8119 ปีที่แล้ว

      @@megaing1322 Yes, the cost here is the function call. Most compilers will inline the function call in contexts like this. I know in C++ most compilers would inline this function when used in a for loop, especially if the function is a template. It's a little strange the Python compiler chooses not to inline this. But, then again, usually these JIT type scenarios do very little optimizations. And I imagine the dynamic typing of Python might force this to not be inlined

    • @megaing1322
      @megaing1322 ปีที่แล้ว

      @@lucass8119 You clearly have no idea how python works. It isn't possible for the compiler itself to inline list.append. And CPython (which is what is being talked about) currently has no JIT compiler.

    • @ABaumstumpf
      @ABaumstumpf ปีที่แล้ว +1

      @@lucass8119 " the cost here is the function call."
      At least the data from this video would heavily imply - No, that is not correct and not the source of the differing performance:
      Here the 2 lines are almost parallel with a constant offset (the for-loop even slowly catching up). That can not be the result of an overhead that is incurred repeatedly

    • @lucass8119
      @lucass8119 ปีที่แล้ว

      @@ABaumstumpf The overhead isn't incurred repeatedly, its a constant time factor. Therefore, the two lines being parallel makes perfect sense.
      Its not like the second function call is more expensive than the first and so on. Each are equally expensive (theoretically) so the lines should be perfectly parallel, with the one with a function call being slightly slower. Both are O(n), they should be parallel.
      We know it has to be the function call, because look at the disassembly. That's the only difference.

  • @rikschaaf
    @rikschaaf ปีที่แล้ว +1

    I'm surprised that the append method isn't just inlined to prevent the need for a method call. I assume that append does something similar to just the LIST_APPEND op code, so such a small method should be optimized. Java is similarly high level, with compiling to byte code and running on a virtual machine (the JVM), but it optimizes method calls vs inlining automatically during compilation, based on the method's complexity. In a couple of other languages that run on the JVM, you can even specify explicitly if you want to inline a method or not (with some added benefits surrounding generics)

    • @Belissimo-T
      @Belissimo-T ปีที่แล้ว +2

      `list.append` is implemented in C. I don't see how this can be inlined. Also, it's difficult to prove that `my_list` is actually of type `list`, even though we declare it as such above. That's partly because Python doesn't have a static type system contrary to Java and `my_list` could get modified through, for example, threads.

    • @megaing1322
      @megaing1322 ปีที่แล้ว +1

      Java is not similarly high level, it gives you way more control. Most notably, java is statically typed, Python isn't. The compiler can't know that the variable is actually a list, so it ain't be inlined. If you want stuff like that, look at Cython.

    • @ABaumstumpf
      @ABaumstumpf ปีที่แล้ว

      @@megaing1322 "Java is not similarly high level, it gives you way more control."
      it is just as high-level if not more. Having more control doesn't make it any less highlevel. Being incredibly slow and without checks is NOT a trade of highlevel-languages.

    • @megaing1322
      @megaing1322 ปีที่แล้ว

      @@ABaumstumpf higher level = further from the actual CPU. In Java, you have direct accesses to varies low level types like different int sizes, a choice between float and double and arrays are exposed way more directly than in python. Yes Python is higher level than Java. That doesn't say anything about the quality of either. But are ofcourse still high level language, anything at a level of C or above is.

    • @ABaumstumpf
      @ABaumstumpf ปีที่แล้ว

      @@megaing1322 "In Java, you have direct accesses to varies low level types like different int sizes, a choice between float and double and arrays are exposed way more directly than in python. Yes Python is higher level than Java."
      No, that shows that python is a dynamically typed language. and that was a thing even 50 years ago in some low-level languages.
      The concept of high/low-level only makes sense when talking about which operations and idioms a language supports.
      Python does not support low-level programming, Java also not really, C++ does.
      python does support high-level abstractions, so does Java, so does C++.
      And no, not "anything above C" cause C is also high-level depending on the environment and what you are doing. Not as highlevel as many modern languages of course, but you are no longer restricted to bare-to-the-metal code.
      And btw: java has arbitrary precision numbers, and Python has floats (which usually are just C doubles) and complex (2 "floats"), and until Python3 it also had 2 integral-types.
      having more options available does not "make" a language lower-level.

  • @tanmaypatel4152
    @tanmaypatel4152 11 หลายเดือนก่อน

    What font do you use? Looks neat

  • @VyctorDaCostaMagalhaes
    @VyctorDaCostaMagalhaes ปีที่แล้ว

    Nice video, thanks for that! Where can I look for "best practices" or how to write more efficient code? I'm learning about these topics in Pyhton now, but it's very hard to find libraries and content...

  • @spicefiend
    @spicefiend ปีที่แล้ว

    How did you get experience on python internals?

  • @aizenvermillion434
    @aizenvermillion434 ปีที่แล้ว

    Is it a toxic workplace if your boss tells everyone to make the codes faster even if we sacrifice readability?
    Our layoffs have calm down and we do printout documentations of our system but I worry for the future employees and want to ask if I should step up and say that we should not sacrifice readability for speed.

    • @olivierbouchez9150
      @olivierbouchez9150 ปีที่แล้ว

      My view here, on readability, list comprehension doesn’t make code unreadable, if people are used to code in python. It’s event sometimes more simple. In fact, I will say it depends on the complexity of the computation. I would say do not use list comprehension if there are side effects.

    • @aizenvermillion434
      @aizenvermillion434 ปีที่แล้ว

      @@olivierbouchez9150 I'm talking about it in a more general sense.
      I really appreciate your perspective on it. Thanks and have an awesome day/afternoon/night. :)

    • @benshulz4179
      @benshulz4179 ปีที่แล้ว +1

      ​@@aizenvermillion434 Code speed isn't opposite of readability. Readability is an issue of either telling the truth about the use of your variables/functions, or not.
      Opposite of code speed is development speed. More you optimize, more difficult it will be to do small changes to the program, and vice versa. Development is about making the best product (code speed) or improving on that product (development speed )
      If your job requires you to do nothing else than to write a fast program, you shouldn't even care about readability. But if you need to do any amount of bugfixing or testing, you require a balance between the speed of the executable and the modularity of the code.

    • @aizenvermillion434
      @aizenvermillion434 ปีที่แล้ว

      @@benshulz4179 Thanks for the reply.
      An update on that. We got a new lead programmer on our team and he explained to the bosses better than we could.
      We got to code better than before at a good pace during projects now. We finally had the time to test them out and let the apps leave without errors unlike with our previous lead and manager.
      We wanted to be given time to code properly and give quality products but could not do so under the previous guys because they'd push us to finish as fast as possible and when complaints came we'd get the blame while the previous lead programmer dunks on us further.
      Sorry ranting in the end. I'm glad we got a new lead programmer that actually leads our team.

  • @HamzaAli-pg7ju
    @HamzaAli-pg7ju ปีที่แล้ว

    How did you make that graph? Did you make it on pythyor any other thing?

  • @dSupertramp
    @dSupertramp ปีที่แล้ว

    What library did you use to create the plot?

  • @paulsingh11
    @paulsingh11 ปีที่แล้ว

    Great! Another thing not taught at college! Glad I took Bio and Chem!

  • @mehDfd
    @mehDfd ปีที่แล้ว

    For this specific case where no added condition cant you simply return range(n)

    • @tokeivo
      @tokeivo ปีที่แล้ว +1

      Nope - not been able to do that for a long time. Range returns an iterator. You could return list(range(n)).

    • @mehDfd
      @mehDfd ปีที่แล้ว

      ​@@tokeivoi was fast to assume it retuned a list after printing it, thanks for the info

  • @reisaki18
    @reisaki18 11 หลายเดือนก่อน

    you should test each function on a separate file for transparency.

  • @killerboyak
    @killerboyak ปีที่แล้ว

    Can someone tell me what IDE this is, I use Jupyter notebook.

    • @dihydrogen
      @dihydrogen 11 หลายเดือนก่อน

      vs code

  • @michawhite7613
    @michawhite7613 ปีที่แล้ว +1

    This is interesting, although I always feel that if you're trying to do these sorts of optimizations to Python code, you've picked the wrong language

    • @AnthonyBerlin
      @AnthonyBerlin ปีที่แล้ว

      Sometimes it isn't possible to change language for various reasons and Python may be forced on you and your team, but it doesn't mean that performance never matters at all.

    • @K9Megahertz
      @K9Megahertz ปีที่แล้ว

      I feel the same way. I primarily use C++. I've done it for 30+ years. I don't understand why the industry has coughed up a language that does for the most part the exact same thing as C++ (Loops, arrays, variables, classes) just a lot lot slower... Why drive a Pinto when you can drive a Ferrari?
      Supposedly C++ is difficult... I don't get why people feel that way. I picked C up when I was 15ish by reading a book. I started picking up C++ a couple years later. This was long before TH-cam, Google, StackOverflow, Udemy, LeetCode.
      Just about every language boils down a few basic concepts.
      1) Sequential execution of instructions.
      2) Loops or conditional branching (JMP, JLE, GOTO, IF, WHILE, FOR, DO , etc.. it's all variants of the same concept)
      3) Storage in Memory, for example variables, (a , b, count, i, j, numDaysInMonth, numGoalsScored, x, y, z, etc..)
      4) Storage in Multiple chunks (bytes) of memory (malloc, alloc, new , free, delete, smartpointers, std::vector, lists, dictionaries, tuples, etc...)
      Now OO languages have things like classes, inheritance, polymorphism, but that stuff isn't overly complicated. Python has classes. Most of the time when I write Python, I use classes, I'm just used to it.
      It's all the same crap. I've programmed in LOGO, GW-BASIC, ASM, C, C++, C#, Visual Basic, Perl, Python and probably a few I'm forgetting. I stayed away from Java thankfully. All of these language boiled down to the same core concepts listed above, no matter what problem you were trying to solve.
      So... if you're going to spend a buttload of time writing a bunch of code, why not do it in a language that runs 30x faster??
      Honestly, If you have a language that has 3-4 different ways to do a for loop and they all have different performance characteristics that warrant making TH-cam videos about it. Well I think that's just a fundamental problem with the language itself and is something that really never should have ended up that way.

  • @xxlarrytfvwxx9531
    @xxlarrytfvwxx9531 ปีที่แล้ว +3

    Would this be O(n)?

    • @seanthesheep
      @seanthesheep ปีที่แล้ว +3

      both are O(n), you can see it's linear in the graph

  • @VIIben
    @VIIben ปีที่แล้ว

    Theme?

  • @TanmayBhatgare
    @TanmayBhatgare ปีที่แล้ว

    bro, please tell me which theme you are using...............................

  • @sayanghosh6996
    @sayanghosh6996 ปีที่แล้ว

    0:35 just do return list(range(n))

  • @domenicfieldhouse5644
    @domenicfieldhouse5644 ปีที่แล้ว +1

    I've heard comprehensions will become comparatively even better in 3.12

    • @megaing1322
      @megaing1322 ปีที่แล้ว

      What is being optimized is more when comprehension are being called a lot. An individual comprehension's iteration (which is more or less what is being tested here) wont change that much.

  • @thegeek786
    @thegeek786 11 หลายเดือนก่อน

    How to plot like this?

  • @ГлебГолубев-ч7щ
    @ГлебГолубев-ч7щ ปีที่แล้ว +3

    For better performance you should define your array size (in current task it’s n). Pre-defined array doesn’t waste time on expanding itself.

    • @koktszfung
      @koktszfung ปีที่แล้ว

      I agree. When you use list comprehension, you know the size of the array beforehand. Right now it seems unfair

    • @megaing1322
      @megaing1322 ปีที่แล้ว

      This isn't possible with python lists without writing manual C code. And list comprehensions don't do such an optimization.

    • @megaing1322
      @megaing1322 ปีที่แล้ว

      @@koktszfung Sure, you might know the size beforehand, but Python's list comprehension don't use that information. (for that, use `list(range(n))` instead)

    • @ГлебГолубев-ч7щ
      @ГлебГолубев-ч7щ ปีที่แล้ว

      @@megaing1322 It’s not possible to define strict size, but you can avoid list resizing (which by the way all in all takes O(n)) by simply writing arr = [0] * n. By default python list has size of 10.

    • @megaing1322
      @megaing1322 ปีที่แล้ว

      @@ГлебГолубев-ч7щ Yes, list resizing all in all takes O(n), each individual append however is O(1) (see amortized cost). So by prefilling the list you gain nothing in time complexity, and I am not sure if you gain a measurable difference is actual performance.

  • @claycreate
    @claycreate 8 หลายเดือนก่อน

    Can i do list(range(n)) ?

  • @davidro00
    @davidro00 ปีที่แล้ว

    A very comprehensive Video🫶🏼

  • @eloimartinez9446
    @eloimartinez9446 ปีที่แล้ว

    The real question is why the compiler doesn’t make the same bytecode for both options

  • @sergiorubencampero8479
    @sergiorubencampero8479 ปีที่แล้ว +1

    Great!! 👍👍👍

  • @Voidead_
    @Voidead_ ปีที่แล้ว +115

    python is so cool real not fake.

    • @alang.2054
      @alang.2054 ปีที่แล้ว +8

      List comprehension are not pythons idea

    • @Voidead_
      @Voidead_ ปีที่แล้ว +31

      @@alang.2054 python still cool not fake

    • @minkeymoo
      @minkeymoo ปีที่แล้ว +1

      Real

    • @skmgeek
      @skmgeek ปีที่แล้ว +1

      real

    • @afignisfirer4675
      @afignisfirer4675 ปีที่แล้ว

      ​@@alang.2054So where did these ideas come from? What are other languages that employ list comprehension??

  • @younessamr6802
    @younessamr6802 4 หลายเดือนก่อน

    what about mapreduce

  • @uuonhs1531
    @uuonhs1531 ปีที่แล้ว

    If you need performance you have to use numpy

  • @imsisig
    @imsisig ปีที่แล้ว +2

    Youre like fireship but python

  • @digitalmachine0101
    @digitalmachine0101 ปีที่แล้ว

    Good information

  • @NRG2k
    @NRG2k ปีที่แล้ว

    my_list = [*range(100)]
    is the actual way for [x for x in range(100)]

  • @Thekingslayer-ig5se
    @Thekingslayer-ig5se ปีที่แล้ว

    The best channel for people like us who work extensively in python

  • @arandomguy9474
    @arandomguy9474 11 หลายเดือนก่อน

    so its the append which fucks up stuff. i need to check out if using variable 'i' and not using any variable '_' makes a difference when working with large numbers. let me know your finding too brother!

  • @ori61511
    @ori61511 ปีที่แล้ว +1

    Actually in python 3.12 they made comprehensions about 2 times faster than 3.11

  • @StereoSensation
    @StereoSensation ปีที่แล้ว

    "python" and "efficient" in the same sentence is crazy.

    • @PennyEvolus
      @PennyEvolus 3 หลายเดือนก่อน

      Tell me ur shit at python without telling me ur shit at python

  • @olivierbouchez9150
    @olivierbouchez9150 ปีที่แล้ว +1

    It would be interesting to compare performance between list comprehensions and generators.
    [x**2 for x in range(n)] compare to (x**2 for x in range(n)) of course there is a difference in the moment the values are computed. Generator could be the best choice to avoid the list loaded in memory, but values available on need. Switching list to generator is a way to make code efficient.

  • @duydug9967
    @duydug9967 ปีที่แล้ว

    i don't know why it up to 4 peoples who dislike this video ;-;
    It really a good video!!!!

    • @alang.2054
      @alang.2054 ปีที่แล้ว

      I personally disliked it because the title didn't say video was looking specifically at python implementation. I clicked it for algorithmic explanation

  • @FinlayDaG33k
    @FinlayDaG33k ปีที่แล้ว +1

    The lines seem to be converging, so that means that at some point, a for loop might be more efficient. :^)

  • @netcat22
    @netcat22 ปีที่แล้ว +2

    List comprehensions are basically just mathematical notation. It's beautiful.

  • @ihandjikanasser3713
    @ihandjikanasser3713 ปีที่แล้ว

    Nice video, But to my side, the list comprehension is taking more time than the for loop.

  • @as4yt
    @as4yt ปีที่แล้ว

    I would say "somewhat more efficient".