Thursday, March 30, 2023

Critical section code

 Many students of Operating Systems get confused on some simple concepts such as critical section. Instead of memorizing the definition of critical section, it is better to understand it with the help of a simple example.

Suppose there is a global variable that may be accessed (i.e. read/write) by two or more threads at the same time, then the part where the two threads read/write the value of the variable needs protection. It simply means that only one thread should be able to read or update the value at a time. Otherwise, the value of the variable may end up wrong. Let us understand this problem with an example:

Let's say there is a global variable int x (with initial value 0)

Now, if you want to increment the value of the global variable two times using two threads T1 and T2. the expected value of x at the end of two increments is 2.

Now the following sequence of event may happen (with the action result after the --> ):

T1 reads value of x --> reads 0

T2 reads value of x --> reads 0

T1 increments x --- > x becomes 1

T2 increments x --- > x becomes 1 because T2 had also read 0

So, the final value of global variable x is 1, not 2. This was not what was expected. The part of the code where the two threads accessed the value of x is a critical section that needs protection.

As mentioned earlier, the critical section needs to be protected from simultaneous access by multiple threads. Mutex is a simple locking mechanism to do that. A mutex is nothing but a lock. Before entering the critical code, a thread must acquire the lock. If the lock is unavailable, the thread must wait (it is blocked). A lock is unavailable when some other thread has already acquired the lock. When the other thread goes out of critical section code, it must release the lock (unlock). The waiting thread can then enter the critical section. The above sequence of events then becomes:

T1 request the lock --> acquires lock

T1 reads value of x --> reads 0

T2 requests the lock --> blocks

T1 increments x --- > x becomes 1

T1 releases the lock --> lock released

                                --> T2 acquires the lock now

 reads value of x --> reads 1

T1 increments x --- > x becomes 2


We can see that the threads are now properly updating the global variable. The lock/unlock process is part of the program and it is the programmer's responsibility to write the code for requesting/releasing the lock. This post has become a bit long. Will give a concrete C example in the next blog. Stay tuned!

Thursday, March 23, 2023

Resources to learn NLP

Q. Which youtube videos and blogs should I start with to learn NLP?

ChatGPT answers:

There are many great YouTube videos and blogs that can help you get started with learning Natural Language Processing (NLP). Here are a few resources to consider:

  1. YouTube Channels:
  • Natural Language Processing with Python by sentdex
  • NLP Tutorial using Python NLTK (Natural Language Toolkit) by Edureka
  • Deep Learning for Natural Language Processing by Stanford University
  1. Blogs:
  1. Courses:
  • Natural Language Processing with Python on Udemy
  • Applied Natural Language Processing on Coursera by University of Michigan
  • Deep Learning for Natural Language Processing on Coursera by National Research University of Higher School of Economics

It's important to note that NLP is a vast field with many different sub-topics and techniques. It may be helpful to start with an introductory course or tutorial to gain a broad understanding of the field, and then dive deeper into specific topics that interest you. Good luck with your NLP learning journey!

Wednesday, March 22, 2023

After hibernating for more than a decade, I am rebooting this blog...


Question:

In what ways should the teachers of computer science update themselves to handle challenges posed by AI based teachers ? 

ChatGPT answers:

The emergence of AI-based teaching tools is changing the landscape of education, including computer science. In order to handle the challenges posed by AI-based teachers, computer science teachers should consider the following:

  1. Stay up-to-date with the latest advancements in AI and machine learning: Teachers should stay informed about the latest advancements in AI and machine learning to understand how these technologies can be used to enhance teaching and learning.

  2. Incorporate AI-based teaching tools into their teaching practice: Teachers should be familiar with AI-based teaching tools and how they can be used to supplement traditional teaching methods. They can incorporate these tools into their lessons to provide students with personalized learning experiences.

  3. Embrace a growth mindset: Teachers should be open to learning new skills and techniques to incorporate AI-based teaching tools into their practice. They should embrace a growth mindset and be willing to experiment with new technologies and teaching methods.

  4. Focus on developing critical thinking skills: While AI-based teaching tools can provide students with personalized learning experiences, it is important for teachers to continue to focus on developing critical thinking skills. Teachers should encourage students to question and analyze information they receive, including information presented by AI-based teaching tools.

  5. Collaborate with other teachers and experts: Teachers should collaborate with other computer science teachers and experts in the field of AI and machine learning. This collaboration can help teachers stay up-to-date with the latest advancements and best practices in AI-based teaching.

Steps to install PyTorch on VMware workstation (Ubuntu guest)

  The following is the list of steps to install pytorch 2.0 in VMware workstation (Ubuntu guest): $ mkdir ~/pytorch $ mkdir ~/pytorch/as...