TUTORIAL IS WRONG! What is wrong: 1. When creating the sub-process, all the names (variables) from the original process are being copied, but they are NOT shared with the original process. When you append to a list in the sub-process, list in the original process stays empty. This style of creating sub-processes in the video is very similar to C++ and it's library. But in C++ to get results of calculations you pass to a function a pointer to a specific memory address to save results to, which is NOT the case for Python! Basically, results_a in sub-process is not an instance of results_a in original process. If you don't believe me, go ahead and try printing the results_a list after the calculations in the sub-process! It will be empty. 2. After starting the sub-process p1, you must JOIN it with the p1.join() command. This command waits for p1 sub-process to finish. In the tutorial, program just starts sub-processes, but they may or may not be finished by the time the original process ends (in the case of finishing before sub-processes finish, it will throw an error I believe). And the time that you have measured - it is the time that it took to CREATE all the sub-processes, but not to finish them. 3. As many of commenters have said, temp_a = results_a does NOT make a copy of the list! After this line of code temp_a and results_a will "point" to the same list, and changing results_a will change temp_a. To check this, try print(results_a is temp_a) - this will print True! Therefor print(results_a == temp_a) will always be True, even if calculations in sub-process is wrong (which they are). I have watched some videos from this channel before (for example a video "Progress Bars in Python Terminal" was very useful), but some videos are to short to cover all the nuances (which is very important in my opinion) and some are just catchpenny, botched and harmful for the viewer (like this one)! I really hope it is not intentional. I wish the author good luck and be more responsible when creating videos.
I appreciate the video and learned a fair amount, but I was going to post something similar to Aecapa. The fact that the video split the work into 3 threads but saw a 7x speedup should have been a red flag.
Don't you need a p1.join() to wait the all of the processes to finish? Isn't the time you are recording just the time for the processes to start, but not to finsih (without the p1.join())?
There is an issue with list comparisons. You dont copy elements of the list but rather you generate another variable pointing at the list. No matter what calculations are made, they will always be equal. Thanks for the video btw.
I am not sure if I am correct on this but you declare your results_a, results_b and results_c lists and then append your calculations to these lists. Then you basically point to the same lists with your temp_a, temp_b and temp_c variables and append again to result_a, result_b and result_c. The thing is as I understand it temp_a and result_a are referring to the exact same list and therefor you are appending to both, which means temp_a and result_a will always be the same. If you use the "is" keyword instead of "==" it will also show true. They will also have the same id.
After starting processes, I think we have to check if all those processes are completed, using .join(), I guess where as you re directly printing end time immediately after starting process, so not sure if overall logic is correct
9:35 Uhh, idk if im stupid, but those lists are immutable, you would need to deepcopy them to actually compare them and be sure that they end up with the same result. I trust you tho, this is supposed to work. otherwise well done!
This needs an edit or even a full reupload. It doesn't make sense to say that there is a 7x speedup when you are only using 3 processes. At 100% efficiency you would finish 3 times faster, which even that won't really happen. You're just measuring the time it takes to launch the processes.
how do you differentiate multi-threading vs multiprocessing? like which use case is good for multi-threading vs multiprocessing? which is faster? Also, why aren't you developing on a linux distro?
Process and threads are os terms. When you launch some program, a process is spawned. It has a thread. You can add threads to a process. Now, when you do multiprpcessing, you are eseentially launching a new program which is doing it's own job and will have it's own thread
Asserting that Python is slow is actually incorrect. Python program speed may differ significantly depending on many factors such as how you structure your code, and which code editor you choose to run your programs on...etc...etc
Hello! I use Threading with Selenium, download 2 profiles from the temple! through threadings, I pass the link and --profile-directory to args . The problem is that on one thread selenium follows the link, on the other the browser opens and that's it... does not click on the link..... and if I remove the path to the profiles and their directories, everything works fine! thank you in advance!!!
It seems multiprocessing doesn't directly work with Jupyterlab (or IPython, not sure), one workaround is to have the worker function in a separate .py file and imported. Also, I am not sure about the high level concurrent module, but I think it's important to let new multiprocessing learners know about this at the beginning, thanks.
@lru_cache is your buddy, friend. :) www.geeksforgeeks.org/python-functools-lru_cache/ tl;dr: from functools import lru_cache Basically just toss @lru_cache(maxsize = int()) as a decorator around your function. Your shit is about to fly lol. (Especially if you're using multiprocessing as well.) # Function that computes Fibonacci # numbers with lru_cache @lru_cache(maxsize = 128) def fib_with_cache(n): if n < 2: return n return fib_with_cache(n-1) + fib_with_cache(n-2)
The faster way to solve the fibonacci sequence isnt by using recursive functions but instead implementing the general formula of the sequence. (Sorry if I mispelled, not native english speaker)
@@fernandomagnabosco I believe you are correct. The general formula will outpace recursion. Especially as 'n' increases. Fibonacci sequence is one of the slowest things to compute though. (Excluding BOGO sort of course :) ). Your English was flawless by the way. Cheers.
Hi! Thanks for an starting point. There are something missing. 1- The process does not have a join() function. 2- You never reset results list, so, technically, you append again the same results. 3- Taking 2 as true, how in the world temps are equal to results lists? Check same code with some little changes : import multiprocessing as mp import time, math global results_a,results_b,results_c results_a = 0 results_b = 0 results_c = 0 def make_calc_1(numbers): global results_a for number in numbers: results_a += (number * 2) def make_calc_2(numbers): global results_b for number in numbers: results_b += (number * 2) def make_calc_3(numbers): global results_c for number in numbers: results_c += (number * 2) if __name__ == '__main__': numbers = list(range(2)) # up to 1 : Result = (1 * 2) = 2 numbers2 = list(range(3)) # up to 2 : Result = (1 * 2) + (2 * 2) = 6 numbers3 = list(range(4)) # up to 3 : Result = (1 * 2) + (2 * 2) + (3 * 2) = 12 tini = time.time() make_calc_1(numbers) make_calc_2(numbers2) make_calc_3(numbers3) tfin = time.time() print (" Sequential time : ", (tfin - tini)) print(" A : ", results_a, " B : ", results_b," C : ",results_c) tini = tfin # Reset results values to zero (0) results_a = 0 results_b = 0 results_c = 0
p1 = mp.Process(target="make_calc_1",args=(numbers),) p2 = mp.Process(target="make_calc_2",args=(numbers2),) p3 = mp.Process(target="make_calc_3",args=(numbers3),) p1.start() p2.start() p3.start() p1.join() p2.join() p3.join() # Whatever you chose ("terminate()" or "kill()") produce same results p1.terminate() p2.terminate() p3.terminate()
tfin = time.time() print (" Multiprocess time : ", (tfin - tini)) print(" A : ", results_a, " B : ", results_b," C : ",results_c) Anyway, thanks for references and try to make it simple.
@Nin Tendo Hi, when numbers, number2, numbers3 are set as big enough 1.000.000, 2.000.000, 3.000.000 then the result is Sequential time I get is 0.5 seconds and the Multiprocess time as 1 second. Could you explain why the 1st part is faster than the 2-nd one?
I only noticed 2-, was looking to find a comment like this :) regarding 3-: I think the result lists were neither global nor returned by the functions? that would mean basically comparing empty lists.
I am learning this multiprocessing thing, I searching internet to know suppose I have two lists of samples and I want to add those lists element wise how to do it in multiprocessing. I asked chatgpt but the solution it gives some error. main problem is, suppose I have a sample dict with params like 'a', 'b', 'c' with 1000 numbers of samples. now I want to find the value of the function for each sample points (like, sample['a'][i] + sample['b'][i] + sample['c'][i] actual function is more complicated). how to make the calculation parallel for 1000 sample points.
im deploying a python API file on amazon ec2 where one function in it utilizes multiprocessing to parallelize some data processing - assigned 2 CPU cores1 Now if this api is deployed and if the api receives 100 concurrent calls will api fail because it exceeded the processor capacity or any other cause to fail???
Nice content. But I think there is a mistake when you try to compare the results. I think you are not actually getting the results from the parallel computation.
yeah the results for the parallel computation is empty. However if you print the elements at the end of each method it is computing. Also the time for multiprocessing is not accurate since the threads are still running and doing the computation.
From this example, how can I archive that function one repeats itself until two finishes? Handle in the subprocess itself or in the part, where its declared/started?
I am not really sure, but seeing that he used global variables (result_a, result_b, ...) you could probably have a global variable for that too. Something like: func2_finished = False def func1: while not func2_finished: # Your code here def func2: # Your code here func2_finished = True I am not too sure though, but maybe you could try this.
Here used only 3 processes but if I want to run my code on 50 processors then I have to write the creating process 50 times ..i.e. impossible. How it will be solved??
TNX it's really helpfull! I got some error: "File "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/multiprocessing/process.py", line 315, in _bootstrap self.run()" do u know why? also, the array is empty
Hi, nice video. It could be very useful if you add another video explaining how to extract the return value when you use Process and some error handling notions. The most typical ones.
20, 9 divided by 2, 9 equals 7(rounded down from 7, 138). If you multiply 2, 9 with 7 you should get around 20,9. Hence 7x faster. You can also say 600% faster than only using one processor.
No, the number of processes is not really limited, if there is a limit, it is set by the operating system. Just Windows alone has over 100 processes running at startup on my dual core. Using more processes than you have cores doesn't speed your program up though.
Here used only 3 processes but if I want to run my code on 50 processors then I have to write the creating process 50 times ..i.e. impossible. How it will be solved??
The result of time comparison is wrong. When you are starting the process and not joining it before moving forward then it gives a wrong value. I am not a full time coder but I can spot these things. Shut down your channel 😡
@@b391i they are very different. mp runs each task in a seperate process (core) but mt shares the threads of a core, but it isnt parallel (like mp, which is)
If you're truly interested: Detailed explanation: blog.floydhub.com/multiprocessing-vs-threading-in-python-what-every-data-scientist-needs-to-know/ Quick explanation: www.python-engineer.com/courses/advancedpython/15-thread-vs-process/ TL;DR: Threading: 1 Savant Dutch knitter who can thread faster than anyone... But she only has two hands so the knitting is only about 1000 knots-per-minute... Multiprocessing: 100 Teletubby knitters who are questionable... At best. But still 100 of them. Jk, about the TL;DR... Look into the links.
I have learned python for only few months and even i can tell that this tutorial is wrong. Please be responsible by removing this video or at least correct yourself and re-post this topic.
Really an inspiring video, however, with a few caveats pointed out below. The list comparision makes no sense, the child processes don't change the variables in the parent process. The time advantage exceeding that of number of the employed processors is unreal. I would really consider to take down this video because it risks to overshadow the otherwise excellent quality of your channel.
i don't get it... you guys on youtube doing these tutorials are LITERALLY IT/CompSci/etc. people, yet most of you don't have the common sense to upload your 720p and above resolution in 24 fps. WHY use 60 fps? WHY? why such a huge bandwidth jump if we want to watch in 720p rather than 480p? take my criticism constructively, not everyone has infinite data or high speed connections
TUTORIAL IS WRONG!
What is wrong:
1. When creating the sub-process, all the names (variables) from the original process are being copied, but they are NOT shared with the original process. When you append to a list in the sub-process, list in the original process stays empty.
This style of creating sub-processes in the video is very similar to C++ and it's library. But in C++ to get results of calculations you pass to a function a pointer to a specific memory address to save results to, which is NOT the case for Python!
Basically, results_a in sub-process is not an instance of results_a in original process.
If you don't believe me, go ahead and try printing the results_a list after the calculations in the sub-process! It will be empty.
2. After starting the sub-process p1, you must JOIN it with the p1.join() command. This command waits for p1 sub-process to finish.
In the tutorial, program just starts sub-processes, but they may or may not be finished by the time the original process ends (in the case of finishing before sub-processes finish, it will throw an error I believe). And the time that you have measured - it is the time that it took to CREATE all the sub-processes, but not to finish them.
3. As many of commenters have said, temp_a = results_a does NOT make a copy of the list! After this line of code temp_a and results_a will "point" to the same list, and changing results_a will change temp_a. To check this, try print(results_a is temp_a) - this will print True! Therefor print(results_a == temp_a) will always be True, even if calculations in sub-process is wrong (which they are).
I have watched some videos from this channel before (for example a video "Progress Bars in Python Terminal" was very useful), but some videos are to short to cover all the nuances (which is very important in my opinion) and some are just catchpenny, botched and harmful for the viewer (like this one)! I really hope it is not intentional.
I wish the author good luck and be more responsible when creating videos.
So, how would you code so that the subprocesses actually append the calculations to the appropriate lists?
I appreciate the video and learned a fair amount, but I was going to post something similar to Aecapa. The fact that the video split the work into 3 threads but saw a 7x speedup should have been a red flag.
Thanks for pointing out this issue, even I thought the same.
Don't you need a p1.join() to wait the all of the processes to finish? Isn't the time you are recording just the time for the processes to start, but not to finsih (without the p1.join())?
That’s what I thought too
There is an issue with list comparisons. You dont copy elements of the list but rather you generate another variable pointing at the list. No matter what calculations are made, they will always be equal. Thanks for the video btw.
I am not sure if I am correct on this but you declare your results_a, results_b and results_c lists and then append your calculations to these lists. Then you basically point to the same lists with your temp_a, temp_b and temp_c variables and append again to result_a, result_b and result_c. The thing is as I understand it temp_a and result_a are referring to the exact same list and therefor you are appending to both, which means temp_a and result_a will always be the same. If you use the "is" keyword instead of "==" it will also show true. They will also have the same id.
I was just about to write this. Thanks!
temp_a = results_a.copy() and so on should be able to remindy this issue.
I discovered this channel a couple of weeks ago and I love it !
After starting processes, I think we have to check if all those processes are completed, using .join(), I guess
where as you re directly printing end time immediately after starting process, so not sure if overall logic is correct
9:35 Uhh, idk if im stupid, but those lists are immutable, you would need to deepcopy them to actually compare them and be sure that they end up with the same result. I trust you tho, this is supposed to work. otherwise well done!
Men, thanks a lot for this mini-lesson :) It was very useful to overcome an issue that I had with a current project.
I watched like two video's on this, but this one was by far the clearest. Thanks!!
This needs an edit or even a full reupload. It doesn't make sense to say that there is a 7x speedup when you are only using 3 processes. At 100% efficiency you would finish 3 times faster, which even that won't really happen. You're just measuring the time it takes to launch the processes.
Thank you for this tutorial. You demoed clear and short to the point.
Thanks for watching!
There should be a waiting point until the three parallel processes are finished before taking the end time stamp.
This video finally helped me understand how multiprocessing works. Thank you!
Tysm for this video! It’s super useful for developing my physics sandbox in python. It’s found a great use!
Incredible video overall!
As always, it was very helpful.
thanks, that was straight to the point, love your work!
how do you differentiate multi-threading vs multiprocessing? like which use case is good for multi-threading vs multiprocessing? which is faster?
Also, why aren't you developing on a linux distro?
Process and threads are os terms. When you launch some program, a process is spawned. It has a thread. You can add threads to a process. Now, when you do multiprpcessing, you are eseentially launching a new program which is doing it's own job and will have it's own thread
You are 😳😳😳.. I don't have words to appreciate you bro.. 🔥🔥🔥🔥
Asserting that Python is slow is actually incorrect. Python program speed may differ significantly depending on many factors such as how you structure your code, and which code editor you choose to run your programs on...etc...etc
wow, this is amazing. After implementing multiprocessing my code went from 20 minutes to 30 seconds.
You should read @AecapA comment before calculating run time
Do you need to join() at the end?
Hello! I use Threading with Selenium, download 2 profiles from the temple! through threadings, I pass the link and --profile-directory to args
. The problem is that on one thread selenium follows the link, on the other the browser opens and that's it... does not click on the link..... and if I remove the path to the profiles and their directories, everything works fine! thank you in advance!!!
But when I print out the a,b, and c after the mp calculation, they are empty lists.
It seems multiprocessing doesn't directly work with Jupyterlab (or IPython, not sure), one workaround is to have the worker function in a separate .py file and imported. Also, I am not sure about the high level concurrent module, but I think it's important to let new multiprocessing learners know about this at the beginning, thanks.
You were correct the first time. It's pronounced processes not processeeez
Loved this new video, was actually searching on how to use multiprocessing to speed up factorial and Fibonacci computations!
Lol me too 😅
@lru_cache is your buddy, friend. :) www.geeksforgeeks.org/python-functools-lru_cache/
tl;dr:
from functools import lru_cache
Basically just toss @lru_cache(maxsize = int()) as a decorator around your function.
Your shit is about to fly lol. (Especially if you're using multiprocessing as well.)
# Function that computes Fibonacci
# numbers with lru_cache
@lru_cache(maxsize = 128)
def fib_with_cache(n):
if n < 2:
return n
return fib_with_cache(n-1) + fib_with_cache(n-2)
The faster way to solve the fibonacci sequence isnt by using recursive functions but instead implementing the general formula of the sequence.
(Sorry if I mispelled, not native english speaker)
@@fernandomagnabosco I believe you are correct. The general formula will outpace recursion. Especially as 'n' increases. Fibonacci sequence is one of the slowest things to compute though. (Excluding BOGO sort of course :) ). Your English was flawless by the way. Cheers.
@@fernandomagnabosco Do you mean the golden ratio recurrence relation?
so how to get the return value of these functions..
Thank you man! it was very useful for my project, thanks for the tutorial
Hi! Thanks for an starting point. There are something missing.
1- The process does not have a join() function.
2- You never reset results list, so, technically, you append again the same results.
3- Taking 2 as true, how in the world temps are equal to results lists? Check same code with some little changes :
import multiprocessing as mp
import time, math
global results_a,results_b,results_c
results_a = 0
results_b = 0
results_c = 0
def make_calc_1(numbers):
global results_a
for number in numbers:
results_a += (number * 2)
def make_calc_2(numbers):
global results_b
for number in numbers:
results_b += (number * 2)
def make_calc_3(numbers):
global results_c
for number in numbers:
results_c += (number * 2)
if __name__ == '__main__':
numbers = list(range(2)) # up to 1 : Result = (1 * 2) = 2
numbers2 = list(range(3)) # up to 2 : Result = (1 * 2) + (2 * 2) = 6
numbers3 = list(range(4)) # up to 3 : Result = (1 * 2) + (2 * 2) + (3 * 2) = 12
tini = time.time()
make_calc_1(numbers)
make_calc_2(numbers2)
make_calc_3(numbers3)
tfin = time.time()
print (" Sequential time : ", (tfin - tini))
print(" A : ", results_a, "
B : ", results_b,"
C : ",results_c)
tini = tfin
# Reset results values to zero (0)
results_a = 0
results_b = 0
results_c = 0
p1 = mp.Process(target="make_calc_1",args=(numbers),)
p2 = mp.Process(target="make_calc_2",args=(numbers2),)
p3 = mp.Process(target="make_calc_3",args=(numbers3),)
p1.start()
p2.start()
p3.start()
p1.join()
p2.join()
p3.join()
# Whatever you chose ("terminate()" or "kill()") produce same results
p1.terminate()
p2.terminate()
p3.terminate()
tfin = time.time()
print ("
Multiprocess time : ", (tfin - tini))
print(" A : ", results_a, "
B : ", results_b,"
C : ",results_c)
Anyway, thanks for references and try to make it simple.
@Nin Tendo Hi, when numbers, number2, numbers3 are set as big enough 1.000.000, 2.000.000, 3.000.000 then the result is Sequential time I get is 0.5 seconds and the Multiprocess time as 1 second. Could you explain why the 1st part is faster than the 2-nd one?
I only noticed 2-, was looking to find a comment like this :) regarding 3-: I think the result lists were neither global nor returned by the functions? that would mean basically comparing empty lists.
yeah buddy, thanks this is what i expected from you
I am learning this multiprocessing thing, I searching internet to know suppose I have two lists of samples and I want to add those lists element wise how to do it in multiprocessing. I asked chatgpt but the solution it gives some error. main problem is, suppose I have a sample dict with params like 'a', 'b', 'c' with 1000 numbers of samples. now I want to find the value of the function for each sample points (like, sample['a'][i] + sample['b'][i] + sample['c'][i] actual function is more complicated). how to make the calculation parallel for 1000 sample points.
im deploying a python API file on amazon ec2 where one function in it utilizes multiprocessing to parallelize some data processing - assigned 2 CPU cores1
Now if this api is deployed and if the api receives 100 concurrent calls will api fail because it exceeded the processor capacity or any other cause to fail???
any news when gil will be removed or any speed ups?
what keyboard do you use?
Nice content. But I think there is a mistake when you try to compare the results. I think you are not actually getting the results from the parallel computation.
yeah the results for the parallel computation is empty. However if you print the elements at the end of each method it is computing. Also the time for multiprocessing is not accurate since the threads are still running and doing the computation.
Do you have example using numpy multidimension array?
executing this crashed my RAM, i have 24 cores, but only 16g ram memory, maybe that has something to do with it?
Can you use await keyword to yield the stack untill process ends?
From this example, how can I archive that function one repeats itself until two finishes? Handle in the subprocess itself or in the part, where its declared/started?
I am not really sure, but seeing that he used global variables (result_a, result_b, ...) you could probably have a global variable for that too. Something like:
func2_finished = False
def func1:
while not func2_finished:
# Your code here
def func2:
# Your code here
func2_finished = True
I am not too sure though, but maybe you could try this.
Hi, is it possible to start multi instances of particular process with single object at the same time without finishing 1st process
Can you have multiprocessing if its code being imported?
How to check how much proces i can run on one time?
Btw. all results and temp variables are empty. So technically the code doesnt work
u right. did you fixed it some how?
@@Itamar960 no i didnt fix it
yes tthat was very good. can you do a video where your running the same strategy on multiple stocks?
Super helpful, thanks!
Here used only 3 processes but if I want to run my code on 50 processors then I have to write the creating process 50 times ..i.e. impossible. How it will be solved??
Where are the 3 join()??????
TNX it's really helpfull!
I got some error: "File "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/multiprocessing/process.py", line 315, in _bootstrap
self.run()" do u know why?
also, the array is empty
I bet you could really take advantage of multi-processing by using it with a JIT compiler like Numba
Hi, nice video. It could be very useful if you add another video explaining how to extract the return value when you use Process and some error handling notions. The most typical ones.
literally was just learning about this
Same , multiprocessing from OS in Galvin !
AttributeError: module 'multiprocessing' has no attribute 'Process'
How could you get a 7-times improvement if you only spawned three processes though?
20, 9 divided by 2, 9 equals 7(rounded down from 7, 138). If you multiply 2, 9 with 7 you should get around 20,9. Hence 7x faster. You can also say 600% faster than only using one processor.
Also, is there a limit on how many processes I can run at the same time? Is it based on the number of cores my cpu has?
yes it is
No, the number of processes is not really limited, if there is a limit, it is set by the operating system. Just Windows alone has over 100 processes running at startup on my dual core. Using more processes than you have cores doesn't speed your program up though.
Here used only 3 processes but if I want to run my code on 50 processors then I have to write the creating process 50 times ..i.e. impossible. How it will be solved??
@@sujatabasu282 there are multiprocess pools that can be used for this :)
VIM with pycharm tutorial?
Name of intro music?
How do you center a list of words?
like
list = ["a", "b" , "c"]
list2 = [" a ", " b ", " c "]
@@1Aditya1 that is adding whitespace - you would have to do:
list = ["a", "b" , "c"]
final_list = []
for item in list:
final_list.append(' '+item+' ')
btw i havnt tested this but im pretty sure it would work
@@pw5687
list = [["a", "b"], ["1", "2"], ["c", "d"]]
center_list = [2, 3]
output_list = [[" a ", " b "], [" 1 "," 2 "], [" c ", " d "]]
For this one?
super video .. nice !!
Well explained
Bro please make a tutorial on a seq2seq chat bot it would be a great project please consider it
please share code with us in next videos.
i keep getting errors bruh
The result of time comparison is wrong. When you are starting the process and not joining it before moving forward then it gives a wrong value.
I am not a full time coder but I can spot these things. Shut down your channel 😡
I liked the old into...
Methods like join() are so poorly defined in the documentation. Like bloody hell who wrote the damn thing? I miss Java...
thanks bro
Nice
why do you even talk about comments when you just ignore all of them anyway...
Hiii
Not up-to the standard NeuralLine
Threading And Multi-Processing Are The Same As I Guess 🤔
you didn't watched the full video I guess..
its basically the same
@@SparePlayss There is two modules in python with the same job one named "threading " and the second module named "multiprocessing".
@@b391i they are very different. mp runs each task in a seperate process (core) but mt shares the threads of a core, but it isnt parallel (like mp, which is)
If you're truly interested:
Detailed explanation: blog.floydhub.com/multiprocessing-vs-threading-in-python-what-every-data-scientist-needs-to-know/
Quick explanation: www.python-engineer.com/courses/advancedpython/15-thread-vs-process/
TL;DR:
Threading: 1 Savant Dutch knitter who can thread faster than anyone... But she only has two hands so the knitting is only about 1000 knots-per-minute...
Multiprocessing: 100 Teletubby knitters who are questionable... At best. But still 100 of them.
Jk, about the TL;DR... Look into the links.
I have learned python for only few months and even i can tell that this tutorial is wrong. Please be responsible by removing this video or at least correct yourself and re-post this topic.
I can't even begin to stress how many flaws and mistakes this video has
Really an inspiring video, however, with a few caveats pointed out below. The list comparision makes no sense, the child processes don't change the variables in the parent process. The time advantage exceeding that of number of the employed processors is unreal. I would really consider to take down this video because it risks to overshadow the otherwise excellent quality of your channel.
Beware, many things are so wrong here.
420 Likes.
cap
i don't get it... you guys on youtube doing these tutorials are LITERALLY IT/CompSci/etc. people, yet most of you don't have the common sense to upload your 720p and above resolution in 24 fps. WHY use 60 fps? WHY? why such a huge bandwidth jump if we want to watch in 720p rather than 480p? take my criticism constructively, not everyone has infinite data or high speed connections
!
Horrible. As others have mentioned, buggy and outright incorrect. Please do not adopt these examples for your code.
Please don't make guides on something you're clueless.
Well explained