सीपीयू समय

सीपीयू समय (या प्रक्रिया समय) वह समय है जिसके लिए केंद्रीय प्रसंस्करण इकाई (सीपीयू) का उपयोग कंप्यूटर प्रोग्राम या ऑपरेटिंग सिस्टम के निर्देश (कंप्यूटर विज्ञान) को संसाधित करने के लिए किया गया था, जो कि बीते हुए समय के विपरीत है, जिसमें उदाहरण के लिए, इनपुट/आउटपुट (आई/ओ) संचालन की प्रतीक्षा करना या कम-शक्ति (निष्क्रिय) मोड में प्रवेश करना शामिल है। CPU समय को सिस्टम समय या सेकंड में मापा जाता है। अक्सर, सीपीयू समय को सीपीयू की क्षमता के प्रतिशत के रूप में मापना उपयोगी होता है, जिसे सीपीयू उपयोग कहा जाता है। CPU समय और CPU उपयोग के दो मुख्य उपयोग हैं।

सीपीयू समय का उपयोग दो कार्यात्मक रूप से समान एल्गोरिदम की समग्र अनुभवजन्य दक्षता को मापने के लिए किया जाता है। उदाहरण के लिए, कोई भी छँटाई एल्गोरिथ्म अवर्गीकृत सूची लेता है और क्रमबद्ध सूची लौटाता है, और नियतात्मक एल्गोरिदम में किसी दिए गए इनपुट सूची के आधार पर चरणों की संख्या में ऐसा करेगा। हालाँकि बुलबुले की तरह और मर्ज़ सॉर्ट में अलग-अलग बड़ा ओ संकेतन होते हैं, जिससे मर्ज सॉर्ट कम चरणों में पूरा हो जाता है। किसी भी एल्गोरिदम के कामकाज के ज्ञान के बिना बबल सॉर्ट का बड़ा सीपीयू समय दिखाता है कि यह मर्ज सॉर्ट की तुलना में विशेष इनपुट डेटा के लिए कम कुशल है।

इस प्रकार का माप विशेष रूप से उपयोगी होता है जब ऐसे एल्गोरिदम की तुलना की जाती है जो जटिलता में मामूली नहीं होते हैं। इस मामले में वॉल टाइम (बीता हुआ वास्तविक समय) अप्रासंगिक है, कंप्यूटर वास्तविक दुनिया के चर जैसे सीपीयू के तापमान, साथ ही अन्य ऑपरेटिंग सिस्टम चर, जैसे प्रक्रिया की प्राथमिकता के आधार पर प्रोग्राम को धीमी या तेज गति से निष्पादित कर सकता है।

सीपीयू उपयोग का उपयोग यह निर्धारित करने के लिए किया जाता है कि प्रोसेसर को कंप्यूटर प्रोग्रामों के बीच कैसे साझा किया जाता है। किसी एकल प्रोग्राम द्वारा उच्च CPU उपयोग यह संकेत दे सकता है कि यह प्रसंस्करण शक्ति की अत्यधिक मांग कर रहा है या इसमें खराबी हो सकती है; उदाहरण के लिए, यह अनंत लूप में प्रवेश कर गया है। सीपीयू समय किसी एकल प्रोग्राम के लिए आवश्यक प्रसंस्करण शक्ति को मापने की अनुमति देता है, जिससे हस्तक्षेप समाप्त हो जाता है, जैसे कि इनपुट के इंतजार में निष्पादित समय या अन्य प्रोग्रामों को चलाने की अनुमति देने के लिए निलंबित किया जाना।

इसके विपरीत, बीता हुआ वास्तविक समय (या बस वास्तविक समय, या दीवार-घड़ी का समय) कंप्यूटर प्रोग्राम की शुरुआत से अंत तक लिया गया समय है जैसा कि साधारण घड़ी द्वारा मापा जाता है। बीते हुए वास्तविक समय में I/O समय, कोई भी मल्टीटास्किंग विलंब और प्रोग्राम द्वारा किए गए अन्य सभी प्रकार के इंतजार शामिल हैं।

उपखंड
सीपीयू समय या सीपीयू उपयोग को प्रत्येक थ्रेड (कंप्यूटिंग), प्रत्येक प्रक्रिया (कंप्यूटिंग) या पूरे सिस्टम के लिए रिपोर्ट किया जा सकता है। इसके अलावा, सीपीयू वास्तव में क्या कर रहा था इसके आधार पर, रिपोर्ट किए गए मानों को इसमें विभाजित किया जा सकता है:


 * उपयोगकर्ता समय वह समय है जब सीपीयू उपयोगकर्ता स्थान में कोड निष्पादित करने में व्यस्त था।
 * सिस्टम समय वह समय है जब सीपीयू कर्नेल स्थान में कोड निष्पादित करने में व्यस्त था। यदि यह मान किसी थ्रेड या प्रक्रिया के लिए रिपोर्ट किया गया है, तो यह उस समय का प्रतिनिधित्व करता है जब कर्नेल निष्पादन संदर्भ (कंप्यूटिंग) की ओर से काम कर रहा था, उदाहरण के लिए, थ्रेड द्वारा सिस्टम कॉल जारी करने के बाद।
 * निष्क्रिय समय (केवल पूरे सिस्टम के लिए) वह समय है जब सीपीयू व्यस्त नहीं था, या, अन्यथा, सिस्टम निष्क्रिय प्रक्रिया को निष्पादित करने में लगने वाला समय। निष्क्रिय समय वास्तव में अप्रयुक्त सीपीयू क्षमता को मापता है।
 * आभासी हार्डवेयर पर चोरी का समय (केवल पूरे सिस्टम के लिए), वह समय है जिसे ऑपरेटिंग सिस्टम निष्पादित करना चाहता था, लेकिन सूत्र द्वारा इसकी अनुमति नहीं दी गई थी। ऐसा तब हो सकता है जब भौतिक हार्डवेयर एकाधिक अतिथि ऑपरेटिंग सिस्टम चलाता है और हाइपरवाइजर ने सीपीयू टाइम स्लॉट को दूसरे को आवंटित करने का विकल्प चुना है।

यूनिक्स कमांड शीर्ष
यूनिक्स कमांड टॉप (सॉफ्टवेयर) सभी प्रक्रियाओं के लिए सीपीयू समय, प्राथमिकता, बीता हुआ वास्तविक समय और अन्य जानकारी प्रदान करता है और इसे वास्तविक समय में अपडेट करता है।

यूनिक्स कमांड समय
यूनिक्स कमांड टाइम (लिनक्स) यूनिक्स प्रक्रिया के लिए सीपीयू समय और बीता हुआ वास्तविक समय प्रिंट करता है।

इस प्रक्रिया में कुल 0.337 सेकंड का सीपीयू समय लगा, जिसमें से 0.327 सेकंड उपयोगकर्ता स्थान में और अंतिम 0.010 सेकंड प्रक्रिया की ओर से कर्नेल मोड में खर्च किए गए। बीता हुआ वास्तविक समय 1.15 सेकंड था।

निम्नलिखित एप्लिकेशन नेक्स्टप्राइमनंबर का स्रोत कोड है जिसका उपयोग उपरोक्त उदाहरण में किया गया था।

POSIX फ़ंक्शन और
सी पॉज़िक्स लाइब्रेरी और POSIX वातावरण में किसी भी प्रक्रिया द्वारा खपत किए गए CPU समय को प्राप्त करने के लिए इसका उपयोग किया जा सकता है। यदि प्रक्रिया मल्टीथ्रेडेड है, तो सीपीयू समय सभी थ्रेड (कंप्यूटर विज्ञान) का योग है। कर्नेल 2.6.26 से शुरू होने वाले लिनक्स के साथ पैरामीटर RUSAGE_THREAD है जो केवल कॉलिंग थ्रेड के लिए संसाधन उपयोग के आंकड़ों की ओर ले जाता है।

कुल CPU समय
बहु |मल्टी-प्रोसेसर मशीनों पर, कंप्यूटर प्रोग्राम समानांतर कंप्यूटिंग शेड्यूलिंग का उपयोग करके प्रसंस्करण के लिए दो या दो से अधिक सीपीयू का उपयोग कर सकता है। ऐसी स्थितियों में, कुल सीपीयू समय की धारणा का उपयोग किया जाता है, जो कंप्यूटर प्रोग्राम द्वारा उपयोग किए गए सभी सीपीयू द्वारा उपभोग किए गए सीपीयू समय का योग है।

सीपीयू समय और बीता हुआ वास्तविक समय
बीता हुआ वास्तविक समय हमेशा उन कंप्यूटर प्रोग्रामों के सीपीयू समय से अधिक या उसके बराबर होता है जो प्रसंस्करण के लिए केवल सीपीयू का उपयोग करते हैं। यदि I/O या अन्य संसाधनों के लिए कोई प्रतीक्षा शामिल नहीं है, तो बीता हुआ वास्तविक समय और CPU समय बहुत समान हैं।

सीपीयू समय और समानांतर प्रसंस्करण प्रौद्योगिकी के लिए बीता हुआ वास्तविक समय
यदि कोई प्रोग्राम समानांतर कंप्यूटिंग का उपयोग करता है, तो उस प्रोग्राम के लिए कुल CPU समय उसके बीते हुए वास्तविक समय से अधिक होगा। (कुल सीपीयू समय)/(सीपीयू की संख्या) बीता हुआ वास्तविक समय के समान होगा यदि कार्य भार प्रत्येक सीपीयू पर समान रूप से वितरित किया जाता है और I/O या अन्य संसाधनों के लिए कोई प्रतीक्षा शामिल नहीं है।

उदाहरण: मल्टी-कोर प्रोसेसर | हेक्सा-कोर प्रोसेसर पर निष्पादित सॉफ्टवेयर एप्लिकेशन उपयोगकर्ता की आवश्यकता को पूरा करने के लिए तीन यूनिक्स प्रक्रियाएं बनाता है। इन तीन प्रक्रियाओं में से प्रत्येक दो थ्रेड बनाता है, जो कुल 6 कार्यशील थ्रेड की गणना करता है। गणना 6 स्वतंत्र धागों पर समान रूप से वितरित की जाती है। यदि संसाधनों के लिए कोई प्रतीक्षा शामिल नहीं है, तो कुल सीपीयू समय बीते हुए वास्तविक समय का छह गुना होने की उम्मीद है।

यह भी देखें

 * बीता हुआ वास्तविक समय
 * CPU
 * प्रक्रिया (कंप्यूटिंग)
 * सिस्टम समय
 * शीर्ष (यूनिक्स)
 * एमपीस्टेट
 * लोड (कंप्यूटिंग)

बाहरी संबंध