మీరు ఈ ప్రాజెక్ట్కు సహకరించడానికి ఆసక్తి కలిగి ఉంటే, దయచేసి సమీక్షించడానికి కొంత సమయం కేటాయించండి CONTRIBUTING.md ఎలా ప్రారంభించాలో వివరణాత్మక సూచనల కోసం. మీ సహకారాలు చాలా ప్రశంసించబడ్డాయి!
- పరిచయం
- ఎలక్ట్రానిక్ కంప్యూటర్
- బూలియన్ లాజిక్
- సంఖ్య వ్యవస్థలు
- సెంట్రల్ ప్రాసెసింగ్ యూనిట్(CPU)
- రిజిస్టర్లు, కాష్ మరియు RAM
- [సూచనలు మరియు ప్రోగ్రామ్](#సూచనలు మరియు ప్రోగ్రామ్)
- ప్రోగ్రామింగ్ లాంగ్వేజెస్
- డేటా రకాలు
- [ప్రకటనలు మరియు విధులు](#స్టేట్మెంట్లు మరియు విధులు)
- డేటా నిర్మాణాలు
- అల్గోరిథంలు
- అలన్ ట్యూరింగ్
- సాఫ్ట్వేర్ ఇంజనీరింగ్
- ఇంటిగ్రేటెడ్ సర్క్యూట్లు
- ఆబ్జెక్ట్ ఓరియెంటెడ్ ప్రోగ్రామింగ్
- ఫంక్షనల్ ప్రోగ్రామింగ్
- ఆపరేటింగ్ సిస్టమ్స్
- మెమరీ మరియు స్టోరేజ్
- ఫైల్ సిస్టమ్
- క్లౌడ్ కంప్యూటింగ్
- మెషిన్ లెర్నింగ్
- వెబ్ టెక్నాలజీ
- నెట్వర్కింగ్
- ఇంటర్నెట్
- DBMS(డేటాబేస్ మేనేజ్మెంట్ సిస్టమ్)
- క్రిప్టోగ్రఫీ
- గణన సిద్ధాంతం
కంప్యూటర్ సైన్స్ అనేది కంప్యూటర్లు మరియు కంప్యూటింగ్ మరియు వాటి సైద్ధాంతిక మరియు ఆచరణాత్మక అనువర్తనాల అధ్యయనం. కంప్యూటర్ సైన్స్ అనేక సమస్యలకు గణితం, ఇంజనీరింగ్ మరియు లాజిక్ సూత్రాలను వర్తిస్తుంది. వీటిలో అల్గోరిథం ఫార్ములేషన్, సాఫ్ట్వేర్/హార్డ్వేర్ డెవలప్మెంట్ మరియు ఆర్టిఫిషియల్ ఇంటెలిజెన్స్ ఉన్నాయి.
గణించే పరికరం, ముఖ్యంగా హై-స్పీడ్ మ్యాథమెటికల్ లేదా లాజికల్ ఆపరేషన్లు చేసే లేదా సమీకరించడం, నిల్వ చేయడం, సహసంబంధాలు లేదా సమాచారాన్ని ప్రాసెస్ చేసే ప్రోగ్రామబుల్ ఎలక్ట్రానిక్ మెషీన్.
బూలియన్ తర్కం అనేది సత్యం మరియు అసత్యం యొక్క విలువలతో వ్యవహరించే గణిత శాస్త్ర విభాగం. ఇది తర్కం యొక్క వ్యవస్థ, ఇది వరుసగా తప్పుడు మరియు సత్యాన్ని సూచించడానికి 0 మరియు 1 అనే రెండు విలువలను మాత్రమే ఉపయోగిస్తుంది. దీనిని 1854లో మొదటిసారిగా వివరించిన జార్జ్ బూల్ పేరు మీదుగా దీనిని బూలియన్ ఆల్జీబ్రా అని కూడా పిలుస్తారు.
ఆపరేటర్ | పేరు | వివరణ |
---|---|---|
! | కాదు | ఆపరాండ్ విలువను తిరస్కరిస్తుంది. |
&& | మరియు | రెండు ఒపెరాండ్లు నిజమైతే నిజంని చూపుతుంది. |
|| | లేదా | ఒకటి లేదా అన్ని ఒపెరాండ్లు నిజమైతే నిజంని చూపుతుంది. |
ఆపరేటర్ | పేరు | వివరణ |
---|---|---|
() | కుండలీకరణాలు | కీలకపదాలను సమూహపరచడానికి మరియు నిబంధనలను శోధించే క్రమాన్ని నియంత్రించడానికి మిమ్మల్ని అనుమతిస్తుంది. |
"" | కొటేషన్ గుర్తులు | ఖచ్చితమైన పదబంధంతో ఫలితాలను అందిస్తుంది. |
* | నక్షత్రం గుర్తు | కీవర్డ్ వైవిధ్యాన్ని కలిగి ఉన్న ఫలితాలను అందిస్తుంది. |
⊕ | XOR | ఆపరాండ్లు భిన్నంగా ఉంటే నిజంని చూపుతుంది |
⊽ | NOR | అన్ని ఒపెరాండ్లు తప్పు అయితే నిజంని చూపుతుంది. |
⊼ | NAND | దాని రెండు ఇన్పుట్లలోని రెండు విలువలు నిజం అయితే మాత్రమే తప్పుని చూపుతుంది. |
సంఖ్యా వ్యవస్థలు సంఖ్యలను వ్యక్తీకరించడానికి గణిత వ్యవస్థలు. సంఖ్యా వ్యవస్థ సంఖ్యలను సూచించడానికి ఉపయోగించే చిహ్నాల సమితిని మరియు ఆ చిహ్నాలను మార్చడానికి నియమాల సమితిని కలిగి ఉంటుంది. సంఖ్యా వ్యవస్థలో ఉపయోగించే చిహ్నాలను సంఖ్యలు అంటారు.
బైనరీ అనేది గాట్ఫ్రైడ్ లీబ్నిజ్ చేత కనుగొనబడిన బేస్-2 సంఖ్య వ్యవస్థ, ఇది కేవలం రెండు సంఖ్యలు లేదా అంకెలతో రూపొందించబడింది: 0 (సున్నా) మరియు 1 (ఒకటి). ఈ నంబరింగ్ సిస్టమ్ అన్ని బైనరీ కోడ్లకు ఆధారం, ఇది ప్రతిరోజూ ఉపయోగించే కంప్యూటర్ ప్రాసెసర్ సూచనల వంటి డిజిటల్ డేటాను వ్రాయడానికి ఉపయోగించబడుతుంది. బైనరీలోని 0లు మరియు 1లు వరుసగా ఆఫ్ లేదా ఆన్ని సూచిస్తాయి. ట్రాన్సిస్టర్లో, "0" అనేది విద్యుత్ ప్రవాహాన్ని సూచిస్తుంది మరియు "1" విద్యుత్ ప్రవాహానికి అనుమతించబడుతుందని సూచిస్తుంది. ఈ విధంగా, కంప్యూటింగ్ పరికరం లోపల సంఖ్యలు భౌతికంగా సూచించబడతాయి, గణనలను అనుమతిస్తాయి.
బైనరీ ఇప్పటికీ కంప్యూటర్లకు ప్రాథమిక భాషగా ఉంది మరియు కింది కారణాల వల్ల ఎలక్ట్రానిక్స్ మరియు కంప్యూటర్ హార్డ్వేర్తో ఉపయోగించబడుతుంది:
- ఇది సరళమైన మరియు సొగసైన డిజైన్.
- బైనరీ యొక్క 0 మరియు 1 పద్ధతి ఎలక్ట్రికల్ సిగ్నల్ ఆఫ్ (తప్పు) లేదా ఆన్ (నిజమైన) స్థితిని త్వరగా గుర్తించగలదు.
- ఎలక్ట్రికల్ సిగ్నల్లో రెండు రాష్ట్రాలు మాత్రమే దూరంగా ఉంచడం వల్ల అది విద్యుత్ జోక్యానికి తక్కువ అవకాశం ఉంటుంది.
- అయస్కాంత మాధ్యమం యొక్క సానుకూల మరియు ప్రతికూల ధ్రువాలు త్వరగా బైనరీకి అనువదించబడతాయి.
- లాజిక్ సర్క్యూట్లను నియంత్రించడానికి బైనరీ అత్యంత ప్రభావవంతమైన మార్గం.
సెంట్రల్ ప్రాసెసింగ్ యూనిట్ (CPU) అనేది ఏదైనా కంప్యూటర్లో అత్యంత ముఖ్యమైన భాగం. CPU కంప్యూటర్లోని ఇతర భాగాలను నియంత్రించడానికి సంకేతాలను పంపుతుంది, మెదడు శరీరాన్ని ఎలా నియంత్రిస్తుంది. CPU అనేది ఎలక్ట్రానిక్ మెషీన్, ఇది చేయవలసిన కంప్యూటర్ పనుల జాబితాలో పని చేస్తుంది, దీనిని సూచనలు అని పిలుస్తారు. ఇది సూచనల జాబితాను చదువుతుంది మరియు ప్రతి ఒక్కటి క్రమంలో అమలు చేస్తుంది (అమలు చేస్తుంది). CPU అమలు చేయగల సూచనల జాబితా కంప్యూటర్ ప్రోగ్రామ్. CPU "కోర్లు" అని పిలువబడే విభాగాలపై ఒకేసారి ఒకటి కంటే ఎక్కువ సూచనలను ప్రాసెస్ చేయగలదు. నాలుగు కోర్లతో కూడిన CPU ఒకేసారి నాలుగు ప్రోగ్రామ్లను ప్రాసెస్ చేయవచ్చు. CPU మూడు ప్రధాన భాగాలతో తయారు చేయబడింది. వారు:
రిజిస్టర్లు అనేది CPUలో ఉండే చిన్న మొత్తంలో హై-స్పీడ్ మెమరీ. రిజిస్టర్లు అనేది "ఫ్లిప్-ఫ్లాప్స్" (1 బిట్ మెమరీని నిల్వ చేయడానికి ఉపయోగించే సర్క్యూట్) యొక్క సమాహారం. ప్రాసెసింగ్ సమయంలో అవసరమైన చిన్న మొత్తంలో డేటాను నిల్వ చేయడానికి వాటిని ప్రాసెసర్ ఉపయోగిస్తుంది. ఒక CPU "కోర్లు" అని పిలువబడే అనేక రిజిస్టర్లను కలిగి ఉండవచ్చు. రిజిస్టర్ అంకగణితం మరియు తర్కం కార్యకలాపాలలో కూడా సహాయపడుతుంది.
అంకగణిత కార్యకలాపాలు రిజిస్టర్లలో నిల్వ చేయబడిన సంఖ్యా డేటాపై CPUచే నిర్వహించబడే గణిత గణనలు. ఈ ఆపరేషన్లలో కూడిక, తీసివేత, గుణకారం మరియు భాగహారం ఉంటాయి. లాజిక్ కార్యకలాపాలు రిజిస్టర్లలో నిల్వ చేయబడిన బైనరీ డేటాపై CPUచే నిర్వహించబడే బూలియన్ లెక్కలు. ఈ ఆపరేషన్లలో పోలికలు (ఉదా. రెండు విలువలు సమానంగా ఉంటే పరీక్షించడం) మరియు లాజికల్ ఆపరేషన్లు (ఉదా. AND, OR, NOT) ఉంటాయి.
ఈ కార్యకలాపాలను నిర్వహించడానికి రిజిస్టర్లు చాలా అవసరం ఎందుకంటే అవి చిన్న మొత్తంలో డేటాను త్వరగా యాక్సెస్ చేయడానికి మరియు మార్చడానికి CPUని అనుమతిస్తాయి. తరచుగా యాక్సెస్ చేయబడిన డేటాను రిజిస్టర్లలో నిల్వ చేయడం ద్వారా, మెమరీ నుండి డేటాను తిరిగి పొందే నెమ్మదిగా ప్రక్రియను CPU నివారించవచ్చు.
పెద్ద మొత్తంలో డేటా కాష్లో నిల్వ చేయబడుతుంది ("నగదు" అని ఉచ్ఛరిస్తారు), రిజిస్టర్ల వలె అదే ఇంటిగ్రేటెడ్ సర్క్యూట్లో ఉన్న చాలా వేగవంతమైన మెమరీ. ప్రోగ్రామ్ నడుస్తున్నప్పుడు తరచుగా యాక్సెస్ చేయబడిన డేటా కోసం కాష్ ఉపయోగించబడుతుంది. RAMలో ఎక్కువ మొత్తంలో డేటా నిల్వ చేయబడవచ్చు. RAM అంటే రాండమ్-యాక్సెస్ మెమరీ, ఇది ప్రాసెసర్కు అవసరమైనంత వరకు డిస్క్ నిల్వ నుండి తరలించబడిన డేటా మరియు సూచనలను కలిగి ఉండే ఒక రకమైన మెమరీ.
కాష్ మెమరీ అనేది చిప్-ఆధారిత కంప్యూటర్ భాగం, ఇది కంప్యూటర్ మెమరీ నుండి డేటాను తిరిగి పొందడం మరింత సమర్థవంతంగా చేస్తుంది. ఇది తాత్కాలిక నిల్వ ప్రాంతంగా పనిచేస్తుంది కాబట్టి కంప్యూటర్ ప్రాసెసర్ సులభంగా డేటాను తిరిగి పొందగలదు. ఈ తాత్కాలిక నిల్వ ప్రాంతం, కాష్ అని పిలుస్తారు, ఇది కంప్యూటర్ యొక్క ప్రధాన మెమరీ మూలం కంటే ప్రాసెసర్కు మరింత సులభంగా అందుబాటులో ఉంటుంది, సాధారణంగా కొన్ని రకాల DRAM.
కాష్ మెమరీని కొన్నిసార్లు CPU (సెంట్రల్ ప్రాసెసింగ్ యూనిట్) మెమరీ అని పిలుస్తారు, ఎందుకంటే ఇది సాధారణంగా CPU చిప్లో నేరుగా విలీనం చేయబడుతుంది లేదా CPUతో ప్రత్యేక బస్సు ఇంటర్కనెక్ట్ను కలిగి ఉన్న ప్రత్యేక చిప్లో ఉంచబడుతుంది. అందువల్ల, ఇది ప్రాసెసర్కు మరింత అందుబాటులో ఉంటుంది మరియు ప్రాసెసర్కు భౌతికంగా దగ్గరగా ఉన్నందున సామర్థ్యాన్ని పెంచగలదు.
ప్రాసెసర్కు దగ్గరగా ఉండాలంటే, ప్రధాన మెమరీ కంటే కాష్ మెమరీ చాలా తక్కువగా ఉండాలి. పర్యవసానంగా, ఇది తక్కువ నిల్వ స్థలాన్ని కలిగి ఉంటుంది. ఇది ప్రధాన మెమరీ కంటే ఖరీదైనది, ఎందుకంటే ఇది అధిక పనితీరును అందించే క్లిష్టమైన చిప్.
ఇది పరిమాణం మరియు ధరలో ఏమి త్యాగం చేస్తుంది, అది వేగంతో భర్తీ చేస్తుంది. కాష్ మెమరీ RAM కంటే 10 నుండి 100 రెట్లు వేగంగా పనిచేస్తుంది, CPU అభ్యర్థనకు ప్రతిస్పందించడానికి కొన్ని నానోసెకన్లు మాత్రమే అవసరం.
కాష్ మెమరీ కోసం ఉపయోగించే అసలు హార్డ్వేర్ పేరు హై-స్పీడ్ స్టాటిక్ రాండమ్ యాక్సెస్ మెమరీ (SRAM). కంప్యూటర్ యొక్క ప్రధాన మెమరీలో ఉపయోగించే హార్డ్వేర్ పేరు డైనమిక్ రాండమ్-యాక్సెస్ మెమరీ (DRAM).
కాష్ మెమరీ విస్తృత పదం కాష్తో గందరగోళం చెందకూడదు. కాష్లు అనేది హార్డ్వేర్ మరియు సాఫ్ట్వేర్ రెండింటిలోనూ ఉండే తాత్కాలిక డేటా స్టోర్లు. కాష్ మెమరీ అనేది నిర్దిష్ట హార్డ్వేర్ కాంపోనెంట్ను సూచిస్తుంది, ఇది నెట్వర్క్లోని వివిధ స్థాయిలలో కాష్లను సృష్టించడానికి కంప్యూటర్లను అనుమతిస్తుంది. కాష్ అనేది ఒక హార్డ్వేర్ లేదా సాఫ్ట్వేర్, ఇది ఏదైనా, సాధారణంగా డేటాను, తాత్కాలికంగా కంప్యూటింగ్ వాతావరణంలో నిల్వ చేయడానికి ఉపయోగించబడుతుంది.
RAM (రాండమ్ యాక్సెస్ మెమరీ) అనేది కంప్యూటర్ మెమరీ యొక్క ఒక రూపం, దీనిని ఏ క్రమంలోనైనా చదవవచ్చు మరియు మార్చవచ్చు, సాధారణంగా పని చేసే డేటా మరియు మెషిన్ కోడ్ను నిల్వ చేయడానికి ఉపయోగిస్తారు. యాదృచ్ఛిక యాక్సెస్ మెమరీ పరికరం డేటా అంశాలను అనుమతిస్తుంది ఇతర డైరెక్ట్-యాక్సెస్ డేటా స్టోరేజ్ మీడియాతో (హార్డ్ డిస్క్లు, CD-RWS వంటివి, మెమొరీ లోపల డేటా యొక్క భౌతిక స్థానంతో సంబంధం లేకుండా దాదాపు అదే సమయంలో చదవడం లేదా వ్రాయడం, DVD-RWలు మరియు పాత మాగ్నెటిక్ టేప్లు మరియు డ్రమ్ మెమరీ), మీడియా భ్రమణ వేగం మరియు చేయి కదలిక వంటి యాంత్రిక పరిమితుల కారణంగా రికార్డింగ్ మాధ్యమంలో వాటి భౌతిక స్థానాలపై ఆధారపడి డేటా అంశాలను చదవడానికి మరియు వ్రాయడానికి అవసరమైన సమయం గణనీయంగా మారుతుంది.
కంప్యూటర్ సైన్స్లో, ఇన్స్ట్రక్షన్ అనేది ప్రాసెసర్ ఇన్స్ట్రక్షన్ సెట్ ద్వారా నిర్వచించబడిన ప్రాసెసర్ యొక్క ఒకే ఆపరేషన్. కంప్యూటర్ ప్రోగ్రామ్ అంటే కంప్యూటర్కు ఏమి చేయాలో చెప్పే సూచనల జాబితా. కంప్యూటర్ చేసే ప్రతిదీ కంప్యూటర్ ప్రోగ్రామ్ను ఉపయోగించడం ద్వారా సాధించబడుతుంది. కంప్యూటర్ మెమరీలో నిల్వ చేయబడిన ప్రోగ్రామ్లు ("అంతర్గత ప్రోగ్రామింగ్") మధ్య విరామాలతో కూడా కంప్యూటర్ను ఒకదాని తర్వాత మరొకటి చేయడానికి అనుమతిస్తాయి.
ప్రోగ్రామింగ్ లాంగ్వేజ్ అనేది స్ట్రింగ్లను లేదా విజువల్ ప్రోగ్రామింగ్ లాంగ్వేజ్ల విషయంలో గ్రాఫికల్ ప్రోగ్రామ్ ఎలిమెంట్లను వివిధ రకాల మెషిన్ కోడ్ అవుట్పుట్గా మార్చే ఏదైనా నియమాల సమితి. ప్రోగ్రామింగ్ లాంగ్వేజ్లు కంప్యూటర్ ప్రోగ్రామింగ్లో అల్గారిథమ్లను అమలు చేయడానికి ఉపయోగించే ఒక రకమైన కంప్యూటర్ భాష.
ప్రోగ్రామింగ్ భాషలు తరచుగా రెండు విస్తృత వర్గాలుగా విభజించబడ్డాయి:
- ఉన్నత-స్థాయి భాష ఆంగ్ల భాషకు సమానమైన వాక్యనిర్మాణాన్ని ఉపయోగిస్తుంది. కంపైలర్ లేదా ఇంటర్ప్రెటర్ని ఉపయోగించి సోర్స్ కోడ్ మెషీన్-అర్థం చేసుకోగలిగే మెషిన్ కోడ్గా మార్చబడుతుంది. జావా మరియు పైథాన్ ఉన్నత-స్థాయి ప్రోగ్రామింగ్ భాషలకు కొన్ని ఉదాహరణలు. ఇవి సాధారణంగా తక్కువ-స్థాయి కంటే నెమ్మదిగా ఉంటాయి, కానీ ఇది సులభంగా ఉంటుంది.
- తక్కువ-స్థాయి ప్రోగ్రామింగ్ భాషలు హార్డ్వేర్తో మరింత సన్నిహితంగా పనిచేస్తాయి మరియు దానిపై మరింత నియంత్రణను కలిగి ఉంటాయి. వారు నేరుగా హార్డ్వేర్తో సంకర్షణ చెందుతారు. తక్కువ-స్థాయి భాషలకు రెండు సాధారణ ఉదాహరణలు యంత్ర భాష మరియు అసెంబ్లీ భాష. ఇవి సాధారణంగా హై-లెవల్ కంటే వేగంగా ఉంటాయి, అయితే ఇది చాలా కష్టమైన మరియు చదవగలిగే లోపానికి సంబంధించిన ఖర్చుతో వస్తుంది.
అనేక విభిన్న ప్రోగ్రామింగ్ నమూనాలు కూడా ఉన్నాయి. ప్రోగ్రామింగ్ నమూనాలు ఇచ్చిన ప్రోగ్రామ్ లేదా ప్రోగ్రామింగ్ లాంగ్వేజ్ని నిర్వహించగల విభిన్న మార్గాలు లేదా శైలులు. ప్రతి నమూనా సాధారణ ప్రోగ్రామింగ్ సమస్యలను ఎలా పరిష్కరించాలి అనే దాని గురించి నిర్దిష్ట నిర్మాణాలు, లక్షణాలు మరియు అభిప్రాయాలను కలిగి ఉంటుంది.
ప్రోగ్రామింగ్ నమూనాలు కాదు భాషలు లేదా సాధనాలు. మీరు ఒక నమూనాతో దేనినీ "నిర్మించలేరు". అవి చాలా మంది వ్యక్తులు అంగీకరించిన, అనుసరించిన మరియు విస్తరించిన ఆదర్శాలు మరియు మార్గదర్శకాల సమితి లాంటివి. ప్రోగ్రామింగ్ భాషలు ఎల్లప్పుడూ ఒక నిర్దిష్ట నమూనాతో ముడిపడి ఉండవు. ఒక నిర్దిష్ట నమూనాను దృష్టిలో ఉంచుకుని నిర్మించబడిన * భాషలు ఉన్నాయి మరియు ఇతరులకన్నా ఎక్కువగా ఆ రకమైన ప్రోగ్రామింగ్ను సులభతరం చేసే లక్షణాలను కలిగి ఉన్నాయి (హాస్కెల్ మరియు ఫంక్షనల్ ప్రోగ్రామింగ్ మంచి ఉదాహరణ). కానీ "మల్టీ-పారాడిగ్మ్" భాషలు కూడా ఉన్నాయి, వీటిలో మీరు మీ కోడ్ని నిర్దిష్ట నమూనా లేదా ఇతర వాటికి సరిపోయేలా మార్చుకోవచ్చు (జావాస్క్రిప్ట్ మరియు పైథాన్ మంచి ఉదాహరణలు).
డేటా రకం, ప్రోగ్రామింగ్లో, ఒక వేరియబుల్ ఏ రకమైన విలువను కలిగి ఉందో మరియు ఏ రకమైన గణిత, రిలేషనల్ లేదా లాజికల్ ఆపరేషన్లను దోషం లేకుండా దానికి వర్తింపజేయగలదో పేర్కొనే వర్గీకరణ.
ప్రోగ్రామింగ్ లాంగ్వేజ్లో ప్రిమిటివ్ డేటా రకాలు అత్యంత ప్రాథమిక డేటా రకాలు. అవి మరింత సంక్లిష్టమైన డేటా రకాల బిల్డింగ్ బ్లాక్లు. ప్రిమిటివ్ డేటా రకాలు ప్రోగ్రామింగ్ లాంగ్వేజ్ ద్వారా ముందే నిర్వచించబడ్డాయి మరియు రిజర్వు చేయబడిన కీవర్డ్ ద్వారా పేరు పెట్టబడతాయి.
నాన్-ప్రిమిటివ్ డేటా రకాలను రిఫరెన్స్ డేటా రకాలు అని కూడా అంటారు. అవి ప్రోగ్రామర్ చేత సృష్టించబడతాయి మరియు ప్రోగ్రామింగ్ భాష ద్వారా నిర్వచించబడవు. నాన్-ప్రిమిటివ్ డేటా రకాలను కాంపోజిట్ డేటా రకాలు అని కూడా అంటారు ఎందుకంటే అవి ఇతర రకాలతో కూడి ఉంటాయి.
కంప్యూటర్ ప్రోగ్రామింగ్లో, స్టేట్మెంట్ అనేది తప్పనిసరి ప్రోగ్రామింగ్ లాంగ్వేజ్ యొక్క వాక్యనిర్మాణ యూనిట్, ఇది చేయవలసిన కొన్ని చర్యలను వ్యక్తపరుస్తుంది. అటువంటి భాషలో వ్రాసిన ప్రోగ్రామ్ ఒకటి లేదా అంతకంటే ఎక్కువ స్టేట్మెంట్ల క్రమం ద్వారా ఏర్పడుతుంది. ఒక ప్రకటనలో అంతర్గత భాగాలు ఉండవచ్చు (ఉదా., వ్యక్తీకరణలు). కోడ్ యొక్క లాజిక్ను రూపొందించడానికి అవసరమైన ఏదైనా ప్రోగ్రామింగ్ భాషలో రెండు ప్రధాన రకాల స్టేట్మెంట్లు ఉన్నాయి.
- [షరతులతో కూడిన ప్రకటనలు](స్టేట్మెంట్లు%20మరియు%20ఫంక్షన్లు/readme.md#షరతులతో కూడిన ప్రకటనలు)
ప్రధానంగా రెండు రకాల షరతులతో కూడిన ప్రకటనలు ఉన్నాయి:
- ఉంటే
- లేకపోతే
- స్విచ్ కేసు
ప్రధానంగా మూడు రకాల షరతులతో కూడిన ప్రకటనలు ఉన్నాయి:
- లూప్ కోసం
- అయితే లూప్
- డూ - అయితే లూప్ (అయితే లూప్ యొక్క వైవిధ్యం)
- do - లూప్ వరకు
ఫంక్షన్ అనేది ఒక నిర్దిష్ట పనిని చేసే స్టేట్మెంట్ల బ్లాక్. విధులు డేటాను అంగీకరిస్తాయి, ప్రాసెస్ చేస్తాయి మరియు ఫలితాన్ని అందిస్తాయి లేదా అమలు చేస్తాయి. విధులు ప్రాథమికంగా పునర్వినియోగ భావనకు మద్దతు ఇవ్వడానికి వ్రాయబడ్డాయి. ఒక ఫంక్షన్ వ్రాసిన తర్వాత, అదే కోడ్ను పునరావృతం చేయకుండా సులభంగా కాల్ చేయవచ్చు.
వివిధ ఫంక్షనల్ భాషలు ఫంక్షన్లను వ్రాయడానికి వేర్వేరు సింటాక్స్లను ఉపయోగిస్తాయి.
ఫంక్షన్ల గురించి మరింత చదవండి ఇక్కడ
కంప్యూటర్ సైన్స్లో, డేటా స్ట్రక్చర్ అనేది డేటా ఆర్గనైజేషన్, మేనేజ్మెంట్ మరియు స్టోరేజ్ ఫార్మాట్, ఇది సమర్థవంతమైన యాక్సెస్ మరియు సవరణను అనుమతిస్తుంది. మరింత ఖచ్చితంగా, డేటా నిర్మాణం అనేది డేటా విలువలు, వాటి మధ్య సంబంధాలు మరియు డేటాకు వర్తించే విధులు లేదా కార్యకలాపాల సమాహారం.
- అరే
- [లింక్డ్ లిస్ట్](డేటా%20 స్ట్రక్చర్స్/రీడ్మే.ఎమ్డి#లింక్డ్లిస్ట్)
- స్టాక్
- క్యూ
- హాష్ టేబుల్
- [హీప్](డేటా%20 స్ట్రక్చర్స్/రీడ్మే.ఎమ్డి#హీప్)
- [చెట్టు](డేటా%20 స్ట్రక్చర్స్/రీడ్మే.ఎమ్డి#ట్రీ)
- గ్రాఫ్
అల్గారిథమ్లు గణనను పూర్తి చేయడానికి అవసరమైన దశల సెట్లు. అవి మా పరికరాలు చేసే పనులలో ప్రధానమైనవి మరియు ఇది కొత్త భావన కాదు. గణితం అభివృద్ధి చెందినప్పటి నుండి, పనులను మరింత సమర్ధవంతంగా పూర్తి చేయడంలో మాకు సహాయం చేయడానికి అల్గారిథమ్లు అవసరమవుతాయి, అయితే ఈ రోజు మనం సార్టింగ్ మరియు గ్రాఫ్ సెర్చ్ వంటి కొన్ని ఆధునిక కంప్యూటింగ్ సమస్యలను పరిశీలించి, వాటిని మరింతగా ఎలా తయారు చేశామో చూపించబోతున్నాం. సమర్థవంతమైనది కాబట్టి మీరు వింటర్ఫెల్ లేదా రెస్టారెంట్ లేదా మరేదైనా చౌకైన విమాన ఛార్జీలు లేదా మ్యాప్ దిశలను మరింత సులభంగా కనుగొనవచ్చు.
అల్గారిథమ్ యొక్క సమయ సంక్లిష్టత కొంత ఇన్పుట్ కోసం అల్గారిథమ్ ఎంత సమయాన్ని ఉపయోగిస్తుందో అంచనా వేస్తుంది. పరామితి ఇన్పుట్ పరిమాణంగా ఉండే ఫంక్షన్గా సామర్థ్యాన్ని సూచించడం ఆలోచన. సమయ సంక్లిష్టతను లెక్కించడం ద్వారా, అల్గోరిథం అమలు చేయకుండానే తగినంత వేగంగా ఉందో లేదో మేము గుర్తించగలము.
స్పేస్ కాంప్లెక్సిటీ అనేది ఒక అల్గారిథమ్/ప్రోగ్రామ్ ఉపయోగించే మొత్తం మెమరీ స్పేస్ను సూచిస్తుంది, అమలు కోసం ఇన్పుట్ విలువల స్థలంతో సహా. స్పేస్ సంక్లిష్టతను గుర్తించడానికి అల్గారిథమ్/ప్రోగ్రామ్లో వేరియబుల్స్ ఆక్రమించిన స్థలాన్ని లెక్కించండి.
సార్టింగ్ అనేది ఒక నిర్దిష్ట క్రమంలో వస్తువుల జాబితాను అమర్చే ప్రక్రియ. ఉదాహరణకు, మీరు పేర్ల జాబితాను కలిగి ఉంటే, మీరు వాటిని అక్షర క్రమంలో క్రమబద్ధీకరించాలనుకోవచ్చు. ప్రత్యామ్నాయంగా, మీరు సంఖ్యల జాబితాను కలిగి ఉంటే, మీరు వాటిని చిన్న నుండి పెద్ద వరకు క్రమంలో ఉంచాలనుకోవచ్చు. క్రమబద్ధీకరించడం అనేది ఒక సాధారణ పని, మరియు ఇది మనం అనేక రకాలుగా చేయగలిగినది.
శోధించడం అనేది కంటైనర్లో నిర్దిష్ట లక్ష్య మూలకాన్ని కనుగొనడానికి ఒక అల్గారిథమ్. శోధన అల్గారిథమ్లు మూలకం కోసం తనిఖీ చేయడానికి లేదా అది నిల్వ చేయబడిన ఏదైనా డేటా నిర్మాణం నుండి మూలకాన్ని తిరిగి పొందడానికి రూపొందించబడ్డాయి.
స్ట్రింగ్లు ప్రోగ్రామింగ్లో ఎక్కువగా ఉపయోగించే మరియు అత్యంత ముఖ్యమైన డేటా స్ట్రక్చర్లలో ఒకటి, ఈ రిపోజిటరీలో ఎక్కువగా ఉపయోగించిన కొన్ని అల్గారిథమ్లు ఉన్నాయి, ఇవి మా కోడ్ను వేగంగా శోధించడంలో సహాయపడతాయి.
గ్రాఫ్ శోధన అనేది నిర్దిష్ట నోడ్ను కనుగొనడానికి గ్రాఫ్ ద్వారా శోధించే ప్రక్రియ. గ్రాఫ్ అనేది నిర్దేశించని గ్రాఫ్ కోసం ఈ శీర్షాల యొక్క క్రమం చేయని జతల సెట్తో పాటు లేదా నిర్దేశించబడిన గ్రాఫ్ కోసం ఆర్డర్ చేయబడిన జతల సెట్తో పాటు పరిమిత (మరియు బహుశా మార్చదగిన) శీర్షాలు లేదా నోడ్లు లేదా పాయింట్లను కలిగి ఉండే డేటా నిర్మాణం. ఈ జతలను ఎడ్జ్లు, ఆర్క్లు లేదా అన్డైరెక్ట్ చేసిన గ్రాఫ్కు లైన్లుగా పిలుస్తారు మరియు డైరెక్ట్ చేసిన గ్రాఫ్కు బాణాలు, దర్శకత్వం వహించిన అంచులు, డైరెక్ట్ ఆర్క్లు లేదా డైరెక్ట్ లైన్లు అని పిలుస్తారు. శీర్షాలు గ్రాఫ్ నిర్మాణంలో భాగం కావచ్చు లేదా పూర్ణాంక సూచికలు లేదా సూచనల ద్వారా సూచించబడే బాహ్య ఎంటిటీలు కావచ్చు. అనేక వాస్తవ-ప్రపంచ అనువర్తనాలకు గ్రాఫ్లు అత్యంత ఉపయోగకరమైన డేటా నిర్మాణాలలో ఒకటి. వస్తువుల మధ్య జత వైపు సంబంధాలను మోడల్ చేయడానికి గ్రాఫ్లు ఉపయోగించబడతాయి. ఉదాహరణకు, ఎయిర్లైన్ రూట్ నెట్వర్క్ అనేది గ్రాఫ్, దీనిలో నగరాలు శీర్షాలుగా ఉంటాయి మరియు విమాన మార్గాలు అంచులుగా ఉంటాయి. నెట్వర్క్లను సూచించడానికి గ్రాఫ్లు కూడా ఉపయోగించబడతాయి. ఇంటర్నెట్ను గ్రాఫ్గా రూపొందించవచ్చు, దీనిలో కంప్యూటర్లు శీర్షాలుగా ఉంటాయి మరియు కంప్యూటర్ల మధ్య లింక్లు అంచులుగా ఉంటాయి. లింక్డ్ఇన్ మరియు ఫేస్బుక్ వంటి సోషల్ నెట్వర్క్లలో కూడా గ్రాఫ్లు ఉపయోగించబడతాయి. అనేక వాస్తవ-ప్రపంచ అనువర్తనాలను సూచించడానికి గ్రాఫ్లు ఉపయోగించబడతాయి: కంప్యూటర్ నెట్వర్క్లు, సర్క్యూట్ డిజైన్ మరియు ఏరోనాటికల్ షెడ్యూలింగ్ కొన్ని మాత్రమే.
డైనమిక్ ప్రోగ్రామింగ్ అనేది గణిత ఆప్టిమైజేషన్ పద్ధతి మరియు కంప్యూటర్ ప్రోగ్రామింగ్ పద్ధతి. రిచర్డ్ బెల్మాన్ 1950లలో ఈ పద్ధతిని అభివృద్ధి చేసాడు మరియు ఏరోస్పేస్ ఇంజనీరింగ్ నుండి ఎకనామిక్స్ వరకు అనేక రంగాలలో అప్లికేషన్లను కనుగొన్నాడు. రెండు సందర్భాలలో, ఇది సంక్లిష్టమైన సమస్యను పునరావృత పద్ధతిలో సరళమైన ఉప-సమస్యలుగా విభజించడం ద్వారా సరళీకృతం చేయడాన్ని సూచిస్తుంది. కొన్ని నిర్ణయ సమస్యలను ఈ విధంగా వేరుగా తీసుకోలేనప్పటికీ, అనేక పాయింట్ల వ్యవధిలో ఉండే నిర్ణయాలు తరచుగా పునరావృతంగా విడిపోతాయి. అదేవిధంగా, కంప్యూటర్ సైన్స్లో, ఒక సమస్యను ఉప-సమస్యలుగా విభజించి, ఆపై పునరావృతమయ్యే ఉప-సమస్యలకు సరైన పరిష్కారాలను కనుగొనడం ద్వారా సమస్యను ఉత్తమంగా పరిష్కరించగలిగితే, అది సరైన సబ్స్ట్రక్చర్ను కలిగి ఉంటుంది. ఈ లక్షణాలతో సమస్యలను పరిష్కరించడానికి డైనమిక్ ప్రోగ్రామింగ్ ఒక మార్గం. సంక్లిష్టమైన సమస్యను సరళమైన ఉప-సమస్యలుగా విభజించే ప్రక్రియను "విభజించు మరియు జయించు" అంటారు.
అత్యాశ అల్గారిథమ్లు అనేది కొన్ని ఆప్టిమైజేషన్ సమస్యలకు సరైన పరిష్కారాన్ని కనుగొనడానికి ఉపయోగించే అల్గారిథమ్ల యొక్క సాధారణ, సహజమైన తరగతి. వారిని అత్యాశ అని పిలుస్తారు, ఎందుకంటే, ప్రతి దశలో, వారు ఆ సమయంలో ఉత్తమంగా కనిపించే ఎంపికను చేస్తారు. దీనర్థం అత్యాశతో కూడిన అల్గారిథమ్లు ప్రపంచవ్యాప్తంగా సరైన పరిష్కారాన్ని తిరిగి ఇవ్వడానికి హామీ ఇవ్వవు, బదులుగా గ్లోబల్ ఆప్టిమమ్ను కనుగొనాలనే ఆశతో స్థానికంగా సరైన ఎంపికలను చేస్తాయి. ఆప్టిమైజేషన్ సమస్యల కోసం అత్యాశ అల్గారిథమ్లు ఉపయోగించబడతాయి. సమస్య కింది లక్షణాన్ని కలిగి ఉంటే గ్రీడీని ఉపయోగించి ఆప్టిమైజేషన్ సమస్యను పరిష్కరించవచ్చు: ప్రతి దశలో, మేము ప్రస్తుతానికి ఉత్తమంగా కనిపించే ఎంపికను చేయవచ్చు మరియు పూర్తి సమస్యకు సరైన పరిష్కారాన్ని పొందుతాము.
బ్యాక్ట్రాకింగ్ అనేది సమస్య యొక్క పరిమితులను ఏ సమయంలోనైనా సంతృప్తి పరచడంలో విఫలమయ్యే పరిష్కారాలను తొలగించడం ద్వారా, ఒక సమయంలో ఒక్కొక్క ముక్కగా పరిష్కారాన్ని నిర్మించడానికి ప్రయత్నించడం ద్వారా పునరావృతమయ్యే సమస్యలను పరిష్కరించడానికి అల్గారిథమిక్ టెక్నిక్. శోధన చెట్టు యొక్క ఏ స్థాయికి చేరుకునే వరకు సమయం గడిచిపోయింది).
బ్రాంచ్ మరియు బౌండ్ అనేది కాంబినేటోరియల్ ఆప్టిమైజేషన్ సమస్యలను పరిష్కరించడానికి ఒక సాధారణ సాంకేతికత. ఇది ఒక క్రమబద్ధమైన గణన సాంకేతికత, ఇది సమస్య యొక్క నిర్మాణాన్ని ఉపయోగించడం ద్వారా అభ్యర్థి పరిష్కారాల సంఖ్యను తగ్గించి, బహుశా సరైనది కానటువంటి అభ్యర్థి పరిష్కారాలను తొలగిస్తుంది.
సమయ సంక్లిష్టత: ఇది మొత్తం సమయం కంటే నిర్దిష్ట ఇన్స్ట్రక్షన్ సెట్ని ఎన్నిసార్లు అమలు చేయాలనే అంచనాగా నిర్వచించబడింది. సమయం ఆధారపడిన దృగ్విషయం కాబట్టి, ప్రాసెసర్ వేగం, ఉపయోగించిన కంపైలర్ మొదలైన కొన్ని బాహ్య కారకాలపై సమయ సంక్లిష్టత మారవచ్చు.
స్పేస్ కాంప్లెక్సిటీ: ఇది ప్రోగ్రామ్ దాని అమలు కోసం వినియోగించే మొత్తం మెమరీ స్పేస్.
రెండూ ఇన్పుట్ పరిమాణం(n) ఫంక్షన్గా లెక్కించబడతాయి. అల్గోరిథం యొక్క సమయ సంక్లిష్టత పెద్ద O సంజ్ఞామానంలో వ్యక్తీకరించబడింది.
అల్గోరిథం యొక్క సామర్థ్యం ఈ రెండు పారామితులపై ఆధారపడి ఉంటుంది.
సమయ సంక్లిష్టత రకాలు:
- ఉత్తమ సమయ సంక్లిష్టత: అల్గోరిథం తక్కువ సమయం లేదా కనిష్ట సమయాన్ని తీసుకునే ఇన్పుట్. ఉత్తమ సందర్భంలో, మేము అల్గోరిథం యొక్క తక్కువ పరిమిత సమయ సంక్లిష్టతను గణిస్తాము. ఉదాహరణకు: లీనియర్ సెర్చ్లో పెద్ద డేటా శ్రేణి యొక్క మొదటి స్థానంలో శోధించాల్సిన డేటా ఉన్నట్లయితే, ఉత్తమ సందర్భం ఏర్పడుతుంది.
- సగటు సమయ సంక్లిష్టత: మేము అన్ని యాదృచ్ఛిక ఇన్పుట్లను తీసుకుంటాము మరియు అన్ని ఇన్పుట్ల కోసం గణన సమయాన్ని గణిస్తాము. ఆపై, మేము దానిని మొత్తం ఇన్పుట్ల సంఖ్యతో విభజిస్తాము.
- చెత్త సమయ సంక్లిష్టత: అల్గోరిథం ఎక్కువ సమయం లేదా గరిష్ట సమయం తీసుకునే ఇన్పుట్ను నిర్వచించండి. చెత్త సందర్భంలో, మేము అల్గోరిథం యొక్క ఎగువ సరిహద్దును గణిస్తాము. ఉదాహరణ: లీనియర్ సెర్చ్ అల్గారిథమ్లో శోధించాల్సిన డేటా పెద్ద డేటా శ్రేణి యొక్క చివరి ప్రదేశంలో ఉంటే, అప్పుడు చెత్త పరిస్థితి ఏర్పడుతుంది.
కొన్ని సాధారణ సమయ సంక్లిష్టతలు:
-
O(1): ఇది స్థిరమైన సమయాన్ని సూచిస్తుంది. O(1) సాధారణంగా ఇన్పుట్ పరిమాణంతో సంబంధం లేకుండా ఒక అల్గోరిథం స్థిరమైన సమయాన్ని కలిగి ఉంటుంది. హాష్ మ్యాప్లు స్థిరమైన సమయానికి సరైన ఉదాహరణలు.
-
O(log n): ఇది సంవర్గమాన సమయాన్ని సూచిస్తుంది. O(log n) అంటే ఆపరేషన్ల కోసం ప్రతి సందర్భంలో తగ్గడం. బైనరీ సెర్చ్ ట్రీస్ (BSTలు)లో మూలకాల కోసం శోధించడం లాగరిథమిక్ సమయానికి మంచి ఉదాహరణ.
-
O(n): ఇది సరళ సమయాన్ని సూచిస్తుంది. O(n) అంటే పనితీరు ఇన్పుట్ పరిమాణానికి నేరుగా అనులోమానుపాతంలో ఉంటుంది. సరళంగా చెప్పాలంటే, ఇన్పుట్ల సంఖ్య మరియు ఆ ఇన్పుట్లను అమలు చేయడానికి పట్టే సమయం అనుపాతంలో ఉంటుంది. శ్రేణులలోని లీనియర్ శోధన అనేది లీనియర్ టైమ్ కాంప్లెక్సిటీకి గొప్ప ఉదాహరణ.
-
O(n*n): ఇది చతుర్భుజ సమయాన్ని సూచిస్తుంది. O(n^2) అంటే పనితీరు తీసుకున్న ఇన్పుట్ వర్గానికి నేరుగా అనులోమానుపాతంలో ఉంటుంది. సరళంగా చెప్పాలంటే, అమలు చేయడానికి పట్టే సమయం ఇన్పుట్ పరిమాణం కంటే దాదాపు చదరపు రెట్లు పడుతుంది. సమూహ లూప్లు క్వాడ్రాటిక్ టైమ్ కాంప్లెక్సిటీకి సరైన ఉదాహరణలు.
-
O(n log n): ఇది బహుపది సమయ సంక్లిష్టతను సూచిస్తుంది. O(n log n) అంటే పనితీరు O(log n) కంటే n రెట్లు ఎక్కువ అని అర్థం, (ఇది చెత్త-కేస్ సంక్లిష్టత). ఒక మంచి ఉదాహరణ విభజించబడింది మరియు విలీన క్రమబద్ధీకరణ వంటి అల్గారిథమ్లను జయించవచ్చు. ఈ అల్గోరిథం మొదట సెట్ను విభజిస్తుంది, ఇది O(log n) సమయాన్ని తీసుకుంటుంది, ఆపై O(n) సమయం తీసుకుంటుంది, ఇది O(n) సమయం తీసుకుంటుంది- కాబట్టి, Merge sort O(n log n) సమయాన్ని తీసుకుంటుంది.
అల్గోరిథం | సమయ సంక్లిష్టత | అంతరిక్ష సంక్లిష్టత | ||
---|---|---|---|---|
ఉత్తమ | సగటు | చెత్త | చెత్త | |
ఎంపిక క్రమబద్ధీకరణ | Ω(n^2) | θ(n^2) | O(n^2) | O(1) |
బబుల్ క్రమబద్ధీకరణ | Ω(n) | θ(n^2) | O(n^2) | O(1) |
చొప్పించడం క్రమబద్ధీకరించు | Ω(n) | θ(n^2) | O(n^2) | O(1) |
కుప్ప క్రమబద్ధీకరించు | Ω(n లాగ్(n)) | θ(n లాగ్(n)) | O(n log(n)) | O(1) |
త్వరిత క్రమబద్ధీకరణ | Ω(n లాగ్(n)) | θ(n లాగ్(n)) | O(n^2) | O(n) |
క్రమబద్ధీకరించు | Ω(n లాగ్(n)) | θ(n లాగ్(n)) | O(n log(n)) | O(n) |
బకెట్ క్రమబద్ధీకరణ | Ω(n +k) | θ(n +k) | O(n^2) | O(n) |
రాడిక్స్ క్రమబద్ధీకరణ | Ω(nk) | θ(nk) | O(nk) | O(n + k) |
క్రమబద్ధీకరించు | Ω(n +k) | θ(n +k) | O(n + k) | O(k) |
షెల్ క్రమబద్ధీకరించు | Ω(n లాగ్(n)) | θ(n లాగ్(n)) | O(n^2) | O(1) |
టిమ్ క్రమబద్ధీకరించు | Ω(n) | θ(n లాగ్(n)) | O(n log(n)) | O(n) |
చెట్టు క్రమబద్ధీకరణ | Ω(n లాగ్(n)) | θ(n లాగ్(n)) | O(n^2) | O(n) |
క్యూబ్ క్రమబద్ధీకరణ | Ω(n) | θ(n లాగ్(n)) | O(n log(n)) | O(n) |
అల్గోరిథం | సమయ సంక్లిష్టత | ||
---|---|---|---|
ఉత్తమ | సగటు | చెత్త | |
సరళ శోధన | O(1) | O(N) | O(N) |
బైనరీ శోధన | O(1) | O(logN) | O(logN) |
అలాన్ ట్యూరింగ్ (జననం జూన్ 23, 1912, లండన్, ఇంజి.- జూన్ 7, 1954న మరణించారు, విల్మ్స్లో, చెషైర్) ఒక ఆంగ్ల గణిత శాస్త్రజ్ఞుడు మరియు తర్కవేత్త. అతను కేంబ్రిడ్జ్ విశ్వవిద్యాలయం మరియు ప్రిన్స్టన్ ఇన్స్టిట్యూట్ ఫర్ అడ్వాన్స్డ్ స్టడీలో చదువుకున్నాడు. తన సెమినల్ 1936 పేపర్ "ఆన్ కంప్యూటబుల్ నంబర్స్"లో, అతను గణితంలో సత్యాన్ని నిర్ణయించే సార్వత్రిక అల్గారిథమిక్ పద్ధతి ఉనికిలో లేదని మరియు గణితం ఎల్లప్పుడూ నిర్ణయించలేని (తెలియని వాటికి విరుద్ధంగా) ప్రతిపాదనలను కలిగి ఉంటుందని నిరూపించాడు. ఆ పేపర్ ట్యూరింగ్ యంత్రాన్ని కూడా పరిచయం చేసింది. కంప్యూటర్లు చివరికి మానవుడి నుండి వేరు చేయలేని విధంగా ఆలోచించగలవని అతను నమ్మాడు మరియు ఈ సామర్థ్యాన్ని అంచనా వేయడానికి ఒక సాధారణ పరీక్షను (ట్యూరింగ్ పరీక్ష చూడండి) ప్రతిపాదించాడు. ఈ అంశంపై అతని పత్రాలు కృత్రిమ మేధస్సులో పరిశోధనకు పునాదిగా విస్తృతంగా గుర్తించబడ్డాయి. అతను రెండవ ప్రపంచ యుద్ధం సమయంలో క్రిప్టోగ్రఫీలో విలువైన పని చేసాడు, రేడియో కమ్యూనికేషన్ల కోసం జర్మనీ ఉపయోగించే ఎనిగ్మా కోడ్ను విచ్ఛిన్నం చేయడంలో ముఖ్యమైన పాత్ర పోషించాడు. యుద్ధం తరువాత, అతను మాంచెస్టర్ విశ్వవిద్యాలయంలో బోధించాడు మరియు ఇప్పుడు కృత్రిమ మేధస్సు అని పిలవబడే పనిని ప్రారంభించాడు. ఈ సంచలనాత్మక పని మధ్య, ట్యూరింగ్ తన బెడ్లో సైనైడ్తో విషం తాగి చనిపోయాడు. అతని మరణం స్వలింగ సంపర్క చర్య (అప్పుడు నేరం) మరియు 12 నెలల హార్మోన్ థెరపీకి శిక్ష విధించిన తర్వాత అతనిని అరెస్టు చేసింది.
2009లో బహిరంగ ప్రచారాన్ని అనుసరించి, బ్రిటీష్ ప్రధాన మంత్రి గోర్డాన్ బ్రౌన్ ట్యూరింగ్తో వ్యవహరించిన భయంకరమైన విధానానికి బ్రిటిష్ ప్రభుత్వం తరపున అధికారిక బహిరంగ క్షమాపణ చెప్పారు. క్వీన్ ఎలిజబెత్ II 2013లో మరణానంతర క్షమాపణను మంజూరు చేసింది. "అలన్ ట్యూరింగ్ లా" అనే పదాన్ని ఇప్పుడు యునైటెడ్ కింగ్డమ్లోని 2017 చట్టాన్ని సూచించడానికి అనధికారికంగా ఉపయోగించబడుతోంది, ఇది స్వలింగ సంపర్క చర్యలను నిషేధించే చారిత్రక చట్టం ప్రకారం హెచ్చరించిన లేదా దోషులుగా నిర్ధారించబడిన పురుషులను ముందస్తుగా క్షమించింది.
ట్యూరింగ్కు అతని విగ్రహాలు మరియు కంప్యూటర్ సైన్స్ ఆవిష్కరణలకు వార్షిక అవార్డుతో సహా అతని పేరు మీద అనేక వస్తువులతో విస్తృతమైన వారసత్వం ఉంది. అతను తన పుట్టినరోజు సందర్భంగా జూన్ 23, 2021న విడుదల చేసిన ప్రస్తుత బ్యాంక్ ఆఫ్ ఇంగ్లండ్ £50 నోట్లో కనిపించాడు. 2019 BBC సిరీస్, ప్రేక్షకులచే ఓటు వేయబడినట్లుగా, అతన్ని 20వ శతాబ్దపు గొప్ప వ్యక్తిగా పేర్కొంది.
సాఫ్ట్వేర్ ఇంజనీరింగ్ అనేది సాఫ్ట్వేర్ అప్లికేషన్ల రూపకల్పన, అభివృద్ధి, పరీక్ష మరియు నిర్వహణతో వ్యవహరించే కంప్యూటర్ సైన్స్ యొక్క శాఖ. సాఫ్ట్వేర్ ఇంజనీర్లు తుది వినియోగదారుల కోసం సాఫ్ట్వేర్ పరిష్కారాలను రూపొందించడానికి ఇంజనీరింగ్ సూత్రాలు మరియు ప్రోగ్రామింగ్ భాషల పరిజ్ఞానాన్ని వర్తింపజేస్తారు.
సాఫ్ట్వేర్ ఇంజనీరింగ్ యొక్క వివిధ నిర్వచనాలను చూద్దాం:
- IEEE, దాని ప్రామాణిక 610.12-1990లో, సాఫ్ట్వేర్ ఇంజినీరింగ్ను క్రమబద్ధమైన, క్రమశిక్షణతో కూడిన అప్లికేషన్గా నిర్వచించింది, ఇది సాఫ్ట్వేర్ అభివృద్ధి, ఆపరేషన్ మరియు నిర్వహణ కోసం గణించదగిన విధానం.
- ఫ్రిట్జ్ బాయర్ దీనిని 'స్థాపన మరియు ప్రామాణిక ఇంజనీరింగ్ సూత్రాలను ఉపయోగించినట్లు నిర్వచించారు. ఇది విశ్వసనీయమైన మరియు నిజమైన మెషీన్లపై సమర్థవంతంగా పనిచేసే ఆర్థిక సాఫ్ట్వేర్ను పొందడంలో మీకు సహాయపడుతుంది.
- కంప్యూటర్ ప్రోగ్రామ్ల సృజనాత్మక రూపకల్పన మరియు నిర్మాణానికి శాస్త్రీయ పరిజ్ఞానం యొక్క ఆచరణాత్మక అనువర్తనంతో కూడిన సాఫ్ట్వేర్ ఇంజనీరింగ్ని బోహ్మ్ నిర్వచించాడు. ఇది వాటిని అభివృద్ధి చేయడానికి, నిర్వహించడానికి మరియు నిర్వహించడానికి అవసరమైన అనుబంధ డాక్యుమెంటేషన్ను కూడా కలిగి ఉంటుంది.'
కంప్యూటర్ గేమ్ల నుండి నెట్వర్క్ కంట్రోల్ సిస్టమ్ల వరకు అన్నింటినీ అభివృద్ధి చేయడానికి సరైన ప్రోగ్రామింగ్ లాంగ్వేజ్లు, ప్లాట్ఫారమ్లు మరియు ఆర్కిటెక్చర్లను ఎలా ఉపయోగించాలో విజయవంతమైన ఇంజనీర్లకు తెలుసు. వారి సిస్టమ్లను నిర్మించడంతో పాటు, సాఫ్ట్వేర్ ఇంజనీర్లు ఇతర ఇంజనీర్లు రూపొందించిన సాఫ్ట్వేర్ను పరీక్షించడం, మెరుగుపరచడం మరియు నిర్వహించడం కూడా చేస్తారు.
ఈ పాత్రలో, మీ రోజువారీ పనులు క్రింది వాటిని కలిగి ఉండవచ్చు:
- సాఫ్ట్వేర్ సిస్టమ్ల రూపకల్పన మరియు నిర్వహణ
- కొత్త సాఫ్ట్వేర్ ప్రోగ్రామ్లను మూల్యాంకనం చేయడం మరియు పరీక్షించడం
- వేగం మరియు స్కేలబిలిటీ కోసం ఆప్టిమైజింగ్ సాఫ్ట్వేర్
- కోడ్ రాయడం మరియు పరీక్షించడం
- క్లయింట్లు, ఇంజనీర్లు, భద్రతా నిపుణులు మరియు ఇతర వాటాదారులతో సంప్రదింపులు
- వాటాదారులు మరియు అంతర్గత కస్టమర్లకు కొత్త ఫీచర్లను అందించడం
సాఫ్ట్వేర్ ఇంజనీరింగ్ ప్రక్రియలో అవసరాల సేకరణ, రూపకల్పన, అమలు, పరీక్ష మరియు నిర్వహణ వంటి అనేక దశలు ఉంటాయి. సాఫ్ట్వేర్ అభివృద్ధికి క్రమశిక్షణా విధానాన్ని అనుసరించడం ద్వారా, సాఫ్ట్వేర్ ఇంజనీర్లు దాని వినియోగదారుల అవసరాలను తీర్చే అధిక-నాణ్యత సాఫ్ట్వేర్ను సృష్టించగలరు.
-
సాఫ్ట్వేర్ ఇంజనీరింగ్లో మొదటి దశ అవసరాల సేకరణ. ఈ దశలో, సాఫ్ట్వేర్ ఇంజనీర్ క్లయింట్తో కలిసి సాఫ్ట్వేర్ యొక్క ఫంక్షనల్ మరియు నాన్-ఫంక్షనల్ అవసరాలను గుర్తించడానికి పని చేస్తాడు. ఫంక్షనల్ అవసరాలు సాఫ్ట్వేర్ ఏమి చేయాలో వివరిస్తాయి, అయితే ఫంక్షనల్ కాని అవసరాలు దానిని ఎంత బాగా చేయాలో వివరిస్తాయి. అవసరాల సేకరణ అనేది ఒక క్లిష్టమైన దశ, ఎందుకంటే ఇది మొత్తం సాఫ్ట్వేర్ అభివృద్ధి ప్రక్రియకు పునాది వేస్తుంది.
-
అవసరాలు సేకరించిన తర్వాత, తదుపరి దశ డిజైన్. ఈ దశలో, సాఫ్ట్వేర్ ఇంజనీర్ సాఫ్ట్వేర్ ఆర్కిటెక్చర్ మరియు కార్యాచరణ కోసం వివరణాత్మక ప్రణాళికను రూపొందిస్తాడు. ఈ ప్లాన్లో సాఫ్ట్వేర్ నిర్మాణం, ప్రవర్తన మరియు ఇతర సిస్టమ్లతో పరస్పర చర్యలను పేర్కొనే సాఫ్ట్వేర్ డిజైన్ పత్రం ఉంటుంది. సాఫ్ట్వేర్ డిజైన్ డాక్యుమెంట్ అమలు దశకు బ్లూప్రింట్గా ఉపయోగపడుతుంది కాబట్టి ఇది చాలా అవసరం.
-
అమలు దశ అంటే సాఫ్ట్వేర్ ఇంజనీర్ సాఫ్ట్వేర్ కోసం అసలు కోడ్ను సృష్టించడం. ఇక్కడే డిజైన్ డాక్యుమెంట్ వర్కింగ్ సాఫ్ట్వేర్గా మార్చబడుతుంది. అమలు దశలో కోడ్ రాయడం, కంపైల్ చేయడం మరియు డిజైన్ డాక్యుమెంట్లో పేర్కొన్న అవసరాలకు అనుగుణంగా ఉండేలా పరీక్షించడం వంటివి ఉంటాయి.
-
సాఫ్ట్వేర్ ఇంజినీరింగ్లో పరీక్ష అనేది కీలక దశ. ఈ దశలో, సాఫ్ట్వేర్ ఇంజనీర్ సాఫ్ట్వేర్ సరిగ్గా పనిచేస్తుందని, నమ్మదగినదని మరియు ఉపయోగించడానికి సులభమైనదని నిర్ధారించడానికి తనిఖీ చేస్తాడు. ఇందులో యూనిట్ టెస్టింగ్, ఇంటిగ్రేషన్ టెస్టింగ్ మరియు సిస్టమ్ టెస్టింగ్ వంటి అనేక రకాల టెస్టింగ్ ఉంటుంది. టెస్టింగ్ సాఫ్ట్వేర్ ఆశించిన విధంగా అవసరాలు మరియు విధులను తీరుస్తుందని నిర్ధారిస్తుంది.
-
సాఫ్ట్వేర్ ఇంజనీరింగ్ చివరి దశ నిర్వహణ. ఈ దశలో, సాఫ్ట్వేర్ ఇంజనీర్ లోపాలను సరిచేయడానికి, కొత్త ఫీచర్లను జోడించడానికి లేదా దాని పనితీరును మెరుగుపరచడానికి సాఫ్ట్వేర్లో మార్పులు చేస్తాడు. నిర్వహణ అనేది సాఫ్ట్వేర్ జీవితకాలమంతా కొనసాగే కొనసాగుతున్న ప్రక్రియ.
- కంప్యూటర్ సైన్స్: ఎలక్ట్రికల్ ఇంజనీరింగ్ ప్రధానంగా భౌతిక శాస్త్రంపై ఆధారపడి ఉంటుంది కాబట్టి సాఫ్ట్వేర్కు శాస్త్రీయ పునాదిని ఇస్తుంది.
- మేనేజ్మెంట్ సైన్స్: సాఫ్ట్వేర్ ఇంజనీరింగ్ శ్రమతో కూడుకున్నది మరియు సాంకేతిక మరియు నిర్వాహక నియంత్రణను కోరుతుంది. అందువల్ల, ఇది నిర్వహణ శాస్త్రంలో విస్తృతంగా ఉపయోగించబడుతుంది.
- ఎకనామిక్స్: ఈ రంగంలో, సాఫ్ట్వేర్ ఇంజనీరింగ్ వనరులను అంచనా వేయడానికి మరియు ఖర్చులను నియంత్రించడంలో మీకు సహాయపడుతుంది. ఒక కంప్యూటింగ్ సిస్టమ్ అభివృద్ధి చేయబడాలి మరియు ఇచ్చిన బడ్జెట్లో డేటాను క్రమం తప్పకుండా నిర్వహించాలి.
- సిస్టమ్ ఇంజనీరింగ్: చాలా సాఫ్ట్వేర్ చాలా పెద్ద సిస్టమ్లో భాగం. ఉదాహరణకు, ఇండస్ట్రీ మానిటరింగ్ సిస్టమ్లోని సాఫ్ట్వేర్ లేదా విమానంలోని ఫ్లైట్ సాఫ్ట్వేర్. ఈ రకమైన వ్యవస్థ యొక్క అధ్యయనానికి సాఫ్ట్వేర్ ఇంజనీరింగ్ పద్ధతులను వర్తింపజేయాలి.
ఇంటిగ్రేటెడ్ సర్క్యూట్ లేదా మోనోలిథిక్ ఇంటిగ్రేటెడ్ సర్క్యూట్ (దీనిని IC, చిప్ లేదా మైక్రోచిప్ అని కూడా పిలుస్తారు) అనేది సెమీకండక్టర్ పదార్థం యొక్క ఒక చిన్న ఫ్లాట్ పీస్ (లేదా "చిప్"), సాధారణంగా సిలికాన్పై ఎలక్ట్రానిక్ సర్క్యూట్ల సమితి. చాలా చిన్న MOSFETలు (మెటల్-ఆక్సైడ్-సెమీకండక్టర్ ఫీల్డ్-ఎఫెక్ట్ ట్రాన్సిస్టర్లు) చిన్న చిప్లో కలిసిపోతాయి. ఇది వివిక్త ఎలక్ట్రానిక్ భాగాలతో నిర్మించిన వాటి కంటే చిన్న, వేగవంతమైన మరియు తక్కువ ఖర్చుతో కూడిన సర్క్యూట్లకు దారి తీస్తుంది. IC యొక్క సామూహిక ఉత్పత్తి సామర్థ్యం, విశ్వసనీయత మరియు ఇంటిగ్రేటెడ్ సర్క్యూట్ డిజైన్కు బిల్డింగ్-బ్లాక్ విధానం వివిక్త ట్రాన్సిస్టర్ల స్థానంలో ప్రామాణిక ICలను వేగంగా స్వీకరించేలా నిర్ధారిస్తుంది. ICలు ఇప్పుడు వాస్తవంగా అన్ని ఎలక్ట్రానిక్ పరికరాలలో ఉపయోగించబడుతున్నాయి మరియు ఎలక్ట్రానిక్స్ ప్రపంచాన్ని విప్లవాత్మకంగా మార్చాయి. కంప్యూటర్లు, మొబైల్ ఫోన్లు మరియు ఇతర గృహోపకరణాలు ఇప్పుడు ఆధునిక సమాజాల నిర్మాణంలో విడదీయరాని భాగాలుగా మారాయి, ఆధునిక కంప్యూటర్ ప్రాసెసర్లు మరియు మైక్రోకంట్రోలర్లు వంటి ICల యొక్క చిన్న పరిమాణం మరియు తక్కువ ధరతో సాధ్యమయ్యాయి.
మెటల్-ఆక్సైడ్-సిలికాన్ (MOS) సెమీకండక్టర్ డివైస్ ఫ్యాబ్రికేషన్లో సాంకేతిక పురోగతి ద్వారా చాలా-పెద్ద-స్థాయి ఏకీకరణ ఆచరణాత్మకమైనది. 1960వ దశకంలో వాటి మూలం నుండి, చిప్ల పరిమాణం, వేగం మరియు సామర్థ్యం అపారంగా పురోగమించాయి, అదే పరిమాణంలోని చిప్లపై మరింత ఎక్కువ MOS ట్రాన్సిస్టర్లకు సరిపోయే సాంకేతిక పురోగతులతో నడిచింది - ఒక ఆధునిక చిప్లో అనేక బిలియన్ల MOS ట్రాన్సిస్టర్లు ఉండవచ్చు. మానవ వేలుగోళ్ల పరిమాణంలో ఉన్న ప్రాంతం. ఈ పురోగతులు, స్థూలంగా మూర్ చట్టాన్ని అనుసరించి, నేటి కంప్యూటర్ చిప్లు 1970ల ప్రారంభంలో కంప్యూటర్ చిప్ల కంటే మిలియన్ల రెట్లు మరియు వేగాన్ని వేల రెట్లు కలిగి ఉన్నాయి.
ICలు వివిక్త సర్క్యూట్ల కంటే రెండు ప్రధాన ప్రయోజనాలను కలిగి ఉన్నాయి: ఖర్చు మరియు పనితీరు. చిప్లు, వాటి భాగాలన్నింటితో పాటు, ఒక సమయంలో ఒక ట్రాన్సిస్టర్ను నిర్మించకుండా ఫోటోలిథోగ్రఫీ ద్వారా యూనిట్గా ముద్రించబడినందున ఖర్చు తక్కువగా ఉంటుంది. ఇంకా, ప్యాక్ చేయబడిన ICలు డిస్క్రీట్ సర్క్యూట్ల కంటే చాలా తక్కువ మెటీరియల్ని ఉపయోగిస్తాయి. పనితీరు ఎక్కువగా ఉంటుంది ఎందుకంటే IC యొక్క భాగాలు త్వరగా మారతాయి మరియు వాటి చిన్న పరిమాణం మరియు సామీప్యత కారణంగా తులనాత్మకంగా తక్కువ శక్తిని వినియోగిస్తాయి. ICల యొక్క ప్రధాన ప్రతికూలత ఏమిటంటే వాటిని రూపొందించడానికి మరియు అవసరమైన ఫోటోమాస్క్లను రూపొందించడానికి అధిక ధర. ఈ అధిక ప్రారంభ ధర అంటే అధిక ఉత్పత్తి వాల్యూమ్లను ఊహించినప్పుడు మాత్రమే ICలు వాణిజ్యపరంగా లాభదాయకంగా ఉంటాయి.
ఆధునిక ఎలక్ట్రానిక్ కాంపోనెంట్ డిస్ట్రిబ్యూటర్లు తరచుగా ఇంటిగ్రేటెడ్ సర్క్యూట్లను ఉప-వర్గీకరించారు:
- డిజిటల్ ICలు లాజిక్ ICలు (మైక్రోప్రాసెసర్లు మరియు మైక్రోకంట్రోలర్లు వంటివి), మెమరీ చిప్లు (MOS మెమరీ మరియు ఫ్లోటింగ్-గేట్ మెమరీ వంటివి), ఇంటర్ఫేస్ ICలు (లెవల్ షిఫ్టర్లు, సీరియలైజర్/డీరియలైజర్ మొదలైనవి), పవర్ మేనేజ్మెంట్ ICలు మరియు ప్రోగ్రామబుల్గా వర్గీకరించబడ్డాయి. పరికరాలు.
- అనలాగ్ ICలు లీనియర్ ఇంటిగ్రేటెడ్ సర్క్యూట్లు మరియు RF సర్క్యూట్లు (రేడియో ఫ్రీక్వెన్సీ సర్క్యూట్లు)గా వర్గీకరించబడ్డాయి.
- మిక్స్డ్-సిగ్నల్ ఇంటిగ్రేటెడ్ సర్క్యూట్లు డేటా అక్విజిషన్ ICలు (A/D కన్వర్టర్లు, D/A కన్వర్టర్లు మరియు డిజిటల్ పొటెన్షియోమీటర్లు), క్లాక్/టైమింగ్ ICలు, స్విచ్డ్ కెపాసిటర్ (SC) సర్క్యూట్లు మరియు RF CMOS సర్క్యూట్లుగా వర్గీకరించబడ్డాయి.
- త్రీ-డైమెన్షనల్ ఇంటిగ్రేటెడ్ సర్క్యూట్లు (3D ICలు) సిలికాన్ ద్వారా (TSV) ICలు మరియు Cu-Cu కనెక్షన్ ICలు ద్వారా వర్గీకరించబడ్డాయి.
ఆబ్జెక్ట్ ఓరియెంటెడ్ ప్రోగ్రామింగ్ అనేది వస్తువులు మరియు డేటా యొక్క భావనలపై ఆధారపడిన ప్రాథమిక ప్రోగ్రామింగ్ నమూనా.
కోడ్ యొక్క మెరుగైన రీడబిలిటీ మరియు పునర్వినియోగం కోసం ప్రతి ప్రోగ్రామర్ కట్టుబడి ఉండాల్సిన ప్రామాణిక కోడ్ ఇది.
- సంగ్రహణ
- ఎన్కప్సులేషన్
- వారసత్వం
- పాలిమార్ఫిజం
OOP యొక్క ఈ భావనల గురించి మరింత చదవండి ఇక్కడ
కంప్యూటర్ సైన్స్లో, ఫంక్షనల్ ప్రోగ్రామింగ్ అనేది ప్రోగ్రామింగ్ నమూనా, ఇక్కడ ప్రోగ్రామ్లను వర్తింపజేయడం మరియు కంపోజ్ చేయడం ద్వారా ప్రోగ్రామ్లు నిర్మించబడతాయి. ఇది డిక్లరేటివ్ ప్రోగ్రామింగ్ నమూనా, దీనిలో ఫంక్షన్ నిర్వచనాలు ప్రోగ్రామ్ యొక్క నడుస్తున్న స్థితిని నవీకరించే అత్యవసర ప్రకటనల క్రమం కాకుండా, ఇతర విలువలకు విలువలను మ్యాప్ చేసే వ్యక్తీకరణల వృక్షాలు.
ఫంక్షనల్ ప్రోగ్రామింగ్లో, ఫంక్షన్లు ఫస్ట్-క్లాస్ సిటిజన్లుగా పరిగణించబడతాయి, అంటే అవి పేర్లకు (స్థానిక ఐడెంటిఫైయర్లతో సహా) కట్టుబడి ఉంటాయి, ఆర్గ్యుమెంట్లుగా ఆమోదించబడతాయి మరియు ఏదైనా ఇతర డేటా రకం వలె ఇతర ఫంక్షన్ల నుండి తిరిగి ఇవ్వబడతాయి. ఇది ప్రోగ్రామ్లను డిక్లరేటివ్ మరియు కంపోజబుల్ శైలిలో వ్రాయడానికి అనుమతిస్తుంది, ఇక్కడ చిన్న విధులు మాడ్యులర్ పద్ధతిలో మిళితం చేయబడతాయి.
ఫంక్షనల్ ప్రోగ్రామింగ్ కొన్నిసార్లు పూర్తిగా ఫంక్షనల్ ప్రోగ్రామింగ్కు పర్యాయపదంగా పరిగణించబడుతుంది, ఇది ఫంక్షనల్ ప్రోగ్రామింగ్ యొక్క ఉపసమితి, ఇది అన్ని ఫంక్షన్లను నిర్ణయాత్మక గణిత విధులు లేదా స్వచ్ఛమైన విధులుగా పరిగణిస్తుంది. కొన్ని ఇచ్చిన ఆర్గ్యుమెంట్లతో స్వచ్ఛమైన ఫంక్షన్ని పిలిచినప్పుడు, అది ఎల్లప్పుడూ అదే ఫలితాన్ని అందిస్తుంది మరియు ఏదైనా మార్చగల స్థితి లేదా ఇతర దుష్ప్రభావాల ద్వారా ప్రభావితం చేయబడదు. ఇది ఇంపెరేటివ్ ప్రోగ్రామింగ్లో సాధారణమైన అపవిత్ర విధానాలకు విరుద్ధంగా ఉంటుంది, ఇది దుష్ప్రభావాలు (ప్రోగ్రామ్ యొక్క స్థితిని సవరించడం లేదా వినియోగదారు నుండి ఇన్పుట్ తీసుకోవడం వంటివి) కలిగి ఉంటుంది. పూర్తిగా ఫంక్షనల్ ప్రోగ్రామింగ్ యొక్క ప్రతిపాదకులు దుష్ప్రభావాలను పరిమితం చేయడం ద్వారా, ప్రోగ్రామ్లు తక్కువ బగ్లను కలిగి ఉంటాయని, డీబగ్ చేయడం మరియు పరీక్షించడం సులభం మరియు అధికారిక ధృవీకరణ విధానాలకు మరింత అనుకూలంగా ఉంటాయి.
ఫంక్షనల్ ప్రోగ్రామింగ్ దాని మూలాలను అకాడెమియాలో కలిగి ఉంది, ఇది లాంబ్డా కాలిక్యులస్ నుండి ఉద్భవించింది, ఇది కేవలం ఫంక్షన్ల ఆధారంగా గణన యొక్క అధికారిక వ్యవస్థ. ఫంక్షనల్ ప్రోగ్రామింగ్ చారిత్రాత్మకంగా అత్యవసరమైన ప్రోగ్రామింగ్ కంటే తక్కువ జనాదరణ పొందింది, అయితే అనేక ఫంక్షనల్ భాషలు నేడు పరిశ్రమ మరియు విద్యలో ఉపయోగించబడుతున్నాయి.
ఫంక్షనల్ ప్రోగ్రామింగ్ భాషలకు కొన్ని ఉదాహరణలు:
ఫంక్షనల్ ప్రోగ్రామింగ్ చారిత్రాత్మకంగా లాంబ్డా కాలిక్యులస్ నుండి తీసుకోబడింది. లాంబ్డా కాలిక్యులస్ అనేది ఫంక్షన్లతో గణనలను అధ్యయనం చేయడానికి అలోంజో చర్చిచే అభివృద్ధి చేయబడిన ఫ్రేమ్వర్క్. దీనిని తరచుగా "ప్రపంచంలోని అతి చిన్న ప్రోగ్రామింగ్ భాష" అని పిలుస్తారు. ఇది ఏది గణించదగినది మరియు ఏది కాదు అనేదానికి నిర్వచనాన్ని అందిస్తుంది. ఇది ట్యూరింగ్ మెషీన్కు దాని గణన సామర్థ్యంతో సమానం మరియు లాంబ్డా కాలిక్యులస్ ద్వారా గణించదగిన ఏదైనా ట్యూరింగ్ మెషీన్ ద్వారా గణించదగినది ఏదైనా గణించదగినది. ఇది విధులు మరియు వాటి మూల్యాంకనాలను వివరించడానికి సైద్ధాంతిక ఫ్రేమ్వర్క్ను అందిస్తుంది.
ఫంక్షనల్ ప్రోగ్రామింగ్ యొక్క కొన్ని ముఖ్యమైన అంశాలు:
- స్వచ్ఛమైన విధులు
- పునరావృతం
- సూచన పారదర్శకత
- ఫస్ట్ క్లాస్ మరియు హయ్యర్ ఆర్డర్ ఫంక్షన్లుగా విధులు
- వేరియబుల్ మార్పులేనివి.
ప్యూర్ ఫంక్షన్లు: ఈ ఫంక్షన్లు రెండు ప్రధాన లక్షణాలను కలిగి ఉంటాయి. మొదటిది, మరేదైనా సంబంధం లేకుండా ఒకే వాదనల కోసం అవి ఎల్లప్పుడూ ఒకే అవుట్పుట్ను ఉత్పత్తి చేస్తాయి. రెండవది, వాటికి ఎటువంటి దుష్ప్రభావాలు లేవు. అనగా వారు ఎటువంటి వాదనలు లేదా స్థానిక/గ్లోబల్ వేరియబుల్ను సవరించరు లేదా ఇన్పుట్/అవుట్పుట్ స్ట్రీమ్లు. తరువాతి ఆస్తిని మార్పులేని అంటారు. స్వచ్ఛమైన ఫంక్షన్ యొక్క ఏకైక ఫలితం అది తిరిగి ఇచ్చే విలువ. అవి నిర్ణయాత్మకమైనవి. ఫంక్షనల్ ప్రోగ్రామింగ్ని ఉపయోగించి చేసిన ప్రోగ్రామ్లు డీబగ్ చేయడం సులభం ఎందుకంటే వాటికి ఎటువంటి దుష్ప్రభావాలు లేవు లేదా దాచిన I/O. ప్యూర్ ఫంక్షన్లు సమాంతర/ఏకకాలిక అప్లికేషన్లను వ్రాయడాన్ని సులభతరం చేస్తాయి. ఈ శైలిలో కోడ్ వ్రాయబడినప్పుడు, స్మార్ట్ కంపైలర్ అనేక పనులను చేయగలదు- ఇది సూచనలను సమాంతరంగా చేయగలదు, అవసరమైనంత వరకు ఫలితాలను మూల్యాంకనం చేయడానికి వేచి ఉండండి మరియు ఇన్పుట్ మారనంత కాలం ఫలితాలు మారవు కాబట్టి ఫలితాలను గుర్తుంచుకోండి. పైథాన్లోని ప్యూర్ ఫంక్షన్కి ఇక్కడ ఒక సాధారణ ఉదాహరణ:
def sum(x ,y): # sum అనేది x మరియు y లను ఆర్గ్యుమెంట్లుగా తీసుకునే ఫంక్షన్
తిరిగి x + y # విలువను మార్చకుండా x + yని తిరిగి ఇస్తుంది
** పునరావృతం**: స్వచ్ఛమైన ఫంక్షనల్ ప్రోగ్రామింగ్ భాషలలో "ఫర్" లేదా "వైల్" లూప్లు లేవు. పునరావృతం ద్వారా పునరావృతం చేయబడుతుంది. ఒక బేస్ కేస్ చేరే వరకు పునరావృత విధులు పదే పదే తమను తాము పిలుస్తాయి. పునరావృతం యొక్క సాధారణ ఉదాహరణ ఇక్కడ ఉంది C లో ఫంక్షన్:
int fib(n) {
ఉంటే (n <= 1)
తిరిగి 1;
లేకపోతే
తిరిగి (fib(n-1) + fib(n-2));
}
రిఫరెన్షియల్ పారదర్శకత: ఫంక్షనల్ ప్రోగ్రామ్లలో, ఒకసారి నిర్వచించిన వేరియబుల్స్ ప్రోగ్రామ్ అంతటా వాటి విలువను మార్చవు. ఫంక్షనల్ ప్రోగ్రామ్లు అసైన్మెంట్ స్టేట్మెంట్లను కలిగి ఉండవు. మనం కొంత విలువను నిల్వ చేయవలసి వస్తే, బదులుగా కొత్త వేరియబుల్ని నిర్వచించాము. ఇది దుష్ప్రభావాల యొక్క ఏదైనా అవకాశాన్ని తొలగిస్తుంది ఎందుకంటే ఏదైనా వేరియబుల్ అమలు సమయంలో దాని వాస్తవ విలువతో భర్తీ చేయబడుతుంది. ఏదైనా వేరియబుల్ యొక్క స్థితి ఏ క్షణంలోనైనా స్థిరంగా ఉంటుంది. ఉదాహరణ:
x = x + 1 # ఇది వేరియబుల్ xకి కేటాయించిన విలువను మార్చింది
# కాబట్టి, వ్యక్తీకరణ రెఫరెన్షియల్గా పారదర్శకంగా ఉండదు
ఫంక్షన్లు ఫస్ట్-క్లాస్ మరియు హైయర్ ఆర్డర్: ఫస్ట్ క్లాస్ ఫంక్షన్లు ఫస్ట్-క్లాస్ వేరియబుల్స్గా పరిగణించబడతాయి. ఫస్ట్ క్లాస్ వేరియబుల్స్ని ఫంక్షన్లకు పారామీటర్లుగా పాస్ చేయవచ్చు, ఫంక్షన్ల నుండి రిటర్న్ చేయవచ్చు లేదా డేటా స్ట్రక్చర్లలో స్టోర్ చేయవచ్చు.
ఫంక్షన్ అప్లికేషన్ల కలయికను ఫన్కాల్ అనే LISP ఫారమ్ని ఉపయోగించి నిర్వచించవచ్చు, ఇది ఒక ఫంక్షన్ మరియు ఆర్గ్యుమెంట్ల శ్రేణిని ఆర్గ్యుమెంట్లుగా తీసుకుంటుంది మరియు ఆ ఆర్గ్యుమెంట్లకు ఆ ఫంక్షన్ని వర్తింపజేస్తుంది:
(డిఫన్ ఫిల్టర్ (లిస్ట్ ఆఫ్ ఎలిమెంట్స్ టెస్ట్)
(కాండ్ ((మూలకాల యొక్క శూన్య జాబితా) నిల్)
((ఫన్కాల్ టెస్ట్ (కార్ లిస్ట్ ఆఫ్ ఎలిమెంట్స్))
(కాన్స్ (కార్ లిస్ట్ ఆఫ్ ఎలిమెంట్స్)
(ఫిల్టర్ (సిడిఆర్ లిస్ట్ ఆఫ్ ఎలిమెంట్స్)
పరీక్ష)))
(t (ఫిల్టర్ (cdr లిస్ట్ ఆఫ్ ఎలిమెంట్స్)
పరీక్ష))))
ఫిల్టర్ ఫంక్షన్ జాబితా యొక్క మొదటి మూలకానికి పరీక్షను వర్తింపజేస్తుంది. పరీక్ష శూన్యం కానిదిగా తిరిగి వచ్చినట్లయితే, అది జాబితా యొక్క cdrకి వర్తింపజేయబడిన ఫిల్టర్ యొక్క ఫలితంపై మూలకాన్ని కలిగి ఉంటుంది; లేకుంటే, అది కేవలం ఫిల్టర్ చేయబడిన cdrని తిరిగి ఇస్తుంది. ఈ ఫంక్షన్ వివిధ రకాల ఫిల్టరింగ్ పనులను నిర్వహించడానికి పారామీటర్లుగా ఆమోదించబడిన విభిన్న అంచనాలతో ఉపయోగించవచ్చు:
> (ఫిల్టర్ '(1 3 -9 5 -2 -7 6) #'plusp) ; అన్ని ప్రతికూల సంఖ్యలను ఫిల్టర్ చేయండి
అవుట్పుట్: (1 3 5 6)
> (ఫిల్టర్ '(1 2 3 4 5 6 7 8 9) #'evenp) ; అన్ని బేసి సంఖ్యలను ఫిల్టర్ చేయండి
అవుట్పుట్: (2 4 6 8)
మరియు అందువలన న.
వేరియబుల్స్ మార్పులేనివి: ఫంక్షనల్ ప్రోగ్రామింగ్లో, బీమ్ ప్రారంభించిన తర్వాత మనం వేరియబుల్ని సవరించలేము. మేము కొత్త వేరియబుల్లను సృష్టించగలము- కానీ ఇప్పటికే ఉన్న వేరియబుల్ను మేము సవరించలేము మరియు ఇది ప్రోగ్రామ్ యొక్క రన్టైమ్ అంతటా స్థితిని నిర్వహించడానికి నిజంగా సహాయపడుతుంది. ఒకసారి మనం ఒక వేరియబుల్ని సృష్టించి దాని విలువను సెట్ చేసిన తర్వాత, ఆ వేరియబుల్ విలువ ఎప్పటికీ మారదని తెలుసుకోవడం ద్వారా మనకు పూర్తి విశ్వాసం ఉంటుంది.
ఆపరేటింగ్ సిస్టమ్ (లేదా సంక్షిప్తంగా OS) కంప్యూటర్ వినియోగదారు మరియు కంప్యూటర్ హార్డ్వేర్ మధ్య మధ్యవర్తిగా పనిచేస్తుంది. ఆపరేటింగ్ సిస్టమ్ యొక్క ఉద్దేశ్యం వినియోగదారుడు ప్రోగ్రామ్లను సౌకర్యవంతంగా మరియు సమర్ధవంతంగా అమలు చేయగల వాతావరణాన్ని అందించడం. ఆపరేటింగ్ సిస్టమ్ అనేది కంప్యూటర్ హార్డ్వేర్ను నిర్వహించే సాఫ్ట్వేర్. కంప్యూటర్ సిస్టమ్ యొక్క సరైన ఆపరేషన్ను నిర్ధారించడానికి మరియు సిస్టమ్ యొక్క సరైన ఆపరేషన్లో జోక్యం చేసుకోకుండా వినియోగదారు ప్రోగ్రామ్లను నిరోధించడానికి హార్డ్వేర్ తగిన యంత్రాంగాలను అందించాలి. మరింత సాధారణ నిర్వచనం ఏమిటంటే, ఆపరేటింగ్ సిస్టమ్ అనేది కంప్యూటర్లో అన్ని సమయాల్లో నడుస్తున్న ఒక ప్రోగ్రామ్ (సాధారణంగా కెర్నల్ అని పిలుస్తారు), మిగతావన్నీ అప్లికేషన్ ప్రోగ్రామ్లు.
ఆపరేటింగ్ సిస్టమ్లను రెండు దృక్కోణాల నుండి చూడవచ్చు: వనరుల నిర్వాహకులు మరియు విస్తరించిన యంత్రాలు. రిసోర్స్-మేనేజర్ వీక్షణలో, ఆపరేటింగ్ సిస్టమ్ యొక్క పని వ్యవస్థలోని వివిధ భాగాలను సమర్థవంతంగా నిర్వహించండి. విస్తరించిన యంత్ర వీక్షణలో, సిస్టమ్ యొక్క పని వినియోగదారులకు మరింత సంగ్రహణలను అందించడం. అసలు యంత్రం కంటే ఉపయోగించడానికి అనుకూలమైనది. వీటిలో ప్రక్రియలు, చిరునామా ఖాళీలు, మరియు ఫైళ్లు. ఆపరేటింగ్ సిస్టమ్లు ఆపరేటర్ను భర్తీ చేసినప్పటి నుండి ఆధునిక మల్టీప్రోగ్రామింగ్ సిస్టమ్ల వరకు సుదీర్ఘ చరిత్రను కలిగి ఉన్నాయి. హైలైట్లలో ప్రారంభ బ్యాచ్ సిస్టమ్లు, మల్టీప్రోగ్రామింగ్ సిస్టమ్లు మరియు పర్సనల్ కంప్యూటర్ సిస్టమ్లు ఉన్నాయి. ఆపరేటింగ్ సిస్టమ్లు హార్డ్వేర్తో సన్నిహితంగా సంకర్షణ చెందుతాయి కాబట్టి, కొంత జ్ఞానం వాటిని అర్థం చేసుకోవడానికి కంప్యూటర్ హార్డ్వేర్ ఉపయోగపడుతుంది. కంప్యూటర్లు నిర్మించబడ్డాయి ప్రాసెసర్లు, జ్ఞాపకాలు మరియు I/O పరికరాలు. ఈ భాగాలు బస్సుల ద్వారా అనుసంధానించబడి ఉన్నాయి. అన్ని ఆపరేటింగ్ సిస్టమ్లు నిర్మించబడిన ప్రాథమిక అంశాలు ప్రక్రియలు, మెమరీ నిర్వహణ, I/O నిర్వహణ, ఫైల్ సిస్టమ్ మరియు భద్రత. ఏదైనా ఆపరేటింగ్ సిస్టమ్ యొక్క గుండె అది నిర్వహించగల సిస్టమ్ కాల్ల సమితి. ఆపరేటింగ్ సిస్టమ్ ఏమి చేస్తుందో ఇవి తెలియజేస్తాయి.
ఆపరేటింగ్ సిస్టమ్ సంక్లిష్ట వ్యవస్థ యొక్క అన్ని భాగాలను నిర్వహిస్తుంది. ఆధునిక కంప్యూటర్లు ప్రాసెసర్లు, జ్ఞాపకాలు, టైమర్లు, డిస్క్లు, ఎలుకలు, నెట్వర్క్ ఇంటర్ఫేస్లు, ప్రింటర్లు మరియు అనేక రకాల ఇతర పరికరాలు. దిగువ వీక్షణలో, ఆపరేటింగ్ సిస్టమ్ యొక్క పని క్రమబద్ధమైన మరియు నియంత్రిత కేటాయింపును అందించడం. ప్రాసెసర్లు, జ్ఞాపకాలు మరియు I/O పరికరాలు కోరుకునే వివిధ ప్రోగ్రామ్లలో ఉన్నాయి. ఆధునిక ఆపరేటింగ్ సిస్టమ్లు బహుళ ప్రోగ్రామ్లను మెమరీలో మరియు అమలు చేయడానికి అనుమతిస్తాయి ఏకకాలంలో. కొన్నింటిలో మూడు ప్రోగ్రామ్లు నడుస్తున్నట్లయితే ఏమి జరుగుతుందో ఊహించండి కంప్యూటర్లన్నీ ఒకే ప్రింటర్లో తమ అవుట్పుట్ను ఏకకాలంలో ప్రింట్ చేయడానికి ప్రయత్నించాయి. ఫలితం పూర్తిగా గందరగోళంగా ఉంటుంది. ఆపరేటింగ్ సిస్టమ్ సంభావ్య గందరగోళానికి క్రమాన్ని తీసుకురాగలదు డిస్క్లో ప్రింటర్కు ఉద్దేశించిన మొత్తం అవుట్పుట్ను బఫర్ చేయడం ద్వారా. ఒక ప్రోగ్రామ్ పూర్తయినప్పుడు, ఆపరేటింగ్ సిస్టమ్ చేయగలదు ఆపై ప్రింటర్ కోసం నిల్వ చేయబడిన డిస్క్ ఫైల్ నుండి దాని అవుట్పుట్ను కాపీ చేయండి, అదే సమయంలో, ఇతర ప్రోగ్రామ్ మరింత అవుట్పుట్ను ఉత్పత్తి చేయడాన్ని కొనసాగించవచ్చు, అవుట్పుట్ ప్రింటర్కి వెళ్లడం లేదని (ఇంకా) పట్టించుకోలేదు. కంప్యూటర్ (లేదా నెట్వర్క్) ఒకటి కంటే ఎక్కువ మంది వినియోగదారులను కలిగి ఉన్నప్పుడు, నిర్వహించాల్సిన అవసరం ఉంది మరియు మెమొరీ, I/O పరికరాలు మరియు ఇతర వనరులను మరింత ఎక్కువగా రక్షించండి వినియోగదారులు ఒకరితో ఒకరు జోక్యం చేసుకోవచ్చు. అదనంగా, వినియోగదారులు తరచుగా అవసరం హార్డ్వేర్ మాత్రమే కాకుండా సమాచారాన్ని కూడా భాగస్వామ్యం చేయండి (ఫైళ్లు, డేటాబేస్లు మొదలైనవి). సంక్షిప్తంగా, ఆపరేటింగ్ సిస్టమ్ యొక్క ఈ అభిప్రాయం దాని ప్రాథమిక పనిని ట్రాక్ చేయడం ఏ ప్రోగ్రామ్లు ఏ వనరును ఉపయోగిస్తున్నాయి, వనరుల అభ్యర్థనలను మంజూరు చేయడానికి, ఖాతాకు ఉపయోగం కోసం మరియు విభిన్న ప్రోగ్రామ్లు మరియు వినియోగదారుల నుండి విరుద్ధమైన అభ్యర్థనలను మధ్యవర్తిత్వం చేయడానికి.
మెషీన్-లాంగ్వేజ్ స్థాయిలో చాలా కంప్యూటర్ల నిర్మాణం ప్రాచీనమైనది మరియు ఇబ్బందికరమైనది ప్రోగ్రామ్, ముఖ్యంగా ఇన్పుట్/అవుట్పుట్ కోసం. ఈ పాయింట్ మరింత కాంక్రీటుగా చేయడానికి, పరిగణించండి చాలా కంప్యూటర్లలో ఉపయోగించే ఆధునిక SATA (సీరియల్ ATA) హార్డ్ డిస్క్లు. డిస్క్ని ఉపయోగించడానికి ప్రోగ్రామర్ ఏమి తెలుసుకోవాలి. అప్పటి నుండి, ఇంటర్ఫేస్ అనేకసార్లు సవరించబడింది మరియు దాని కంటే చాలా క్లిష్టంగా ఉంది 2007. ఏ సేన్ ప్రోగ్రామర్ ఈ డిస్క్తో హార్డ్వేర్ స్థాయిలో వ్యవహరించాలని కోరుకోడు. బదులుగా, డిస్క్ డ్రైవర్ అని పిలువబడే సాఫ్ట్వేర్ ముక్క హార్డ్వేర్తో వ్యవహరిస్తుంది మరియు డిస్క్ బ్లాక్లను చదవడానికి మరియు వ్రాయడానికి ఇంటర్ఫేస్ను అందిస్తుంది, వివరాలలోకి రాకుండా. I/O పరికరాలను నియంత్రించడానికి ఆపరేటింగ్ సిస్టమ్లు అనేక డ్రైవర్లను కలిగి ఉంటాయి. కానీ చాలా అప్లికేషన్లకు ఈ స్థాయి కూడా చాలా తక్కువగా ఉంది. ఈ కారణంగా, అన్ని ఆపరేటింగ్ సిస్టమ్లు డిస్క్లను ఉపయోగించడం కోసం మరొక నైరూప్య పొరను అందిస్తాయి: ఫైల్స్. ఈ సంగ్రహాన్ని ఉపయోగించి, ప్రోగ్రామ్లు హార్డ్వేర్ ఎలా పనిచేస్తుందనే గజిబిజి వివరాలతో వ్యవహరించకుండా ఫైల్లను సృష్టించవచ్చు, వ్రాయవచ్చు మరియు చదవవచ్చు. ఈ సంక్లిష్టతను నిర్వహించడానికి ఈ సంగ్రహణ కీలకం. మంచి సంగ్రహణలు దాదాపు అసాధ్యమైన పనిని రెండు నిర్వహించదగినవిగా మార్చండి. మొదటిది నిర్వచించడం మరియు సంగ్రహణలను అమలు చేయడం. రెండవది పరిష్కరించడానికి ఈ సంగ్రహాలను ఉపయోగించడం చేతిలో సమస్య.
-
మొదటి తరం (1945-55): రెండవ ప్రపంచ యుద్ధ కాలం వరకు బాబేజ్ యొక్క వినాశకరమైన ప్రయత్నాల తర్వాత డిజిటల్ కంప్యూటర్ల నిర్మాణంలో స్వల్ప పురోగతి సాధించబడింది. అయోవా స్టేట్ యూనివర్శిటీలో, ప్రొఫెసర్ జాన్ అటానాసోఫ్ మరియు అతని గ్రాడ్యుయేట్ విద్యార్థి క్లిఫోర్డ్ బెర్రీ ఈ రోజు మొదటి కార్యాచరణ డిజిటల్ కంప్యూటర్గా గుర్తింపు పొందారు. బెర్లిన్లోని కొన్రాడ్ జుసే అదే సమయంలో ఎలక్ట్రోమెకానికల్ రిలేలను ఉపయోగించి Z3 కంప్యూటర్ను నిర్మించారు. మార్క్ Iను హార్వర్డ్లోని హోవార్డ్ ఐకెన్, ఇంగ్లాండ్లోని బ్లెచ్లీ పార్క్లోని శాస్త్రవేత్తల బృందం కొలోసస్ మరియు 1944లో పెన్సిల్వేనియా విశ్వవిద్యాలయంలో విలియం మౌచ్లీ మరియు అతని డాక్టరల్ విద్యార్థి J. ప్రెస్పెర్ ఎకెర్ట్ చేత ENIAC సృష్టించారు.
-
రెండవ తరం (1955-65): 1950ల మధ్యలో ట్రాన్సిస్టర్ యొక్క ఆవిష్కరణ పరిస్థితిని సమూలంగా మార్చింది. కంప్యూటర్లు తగినంతగా ఆధారపడదగినవిగా మారాయి, అవి కొంత అర్ధవంతమైన పనిని నిర్వహించడానికి చాలా కాలం పాటు పనిచేస్తాయనే ఊహతో వాటిని తయారు చేసి చెల్లించే వినియోగదారులకు విక్రయించవచ్చు. మెయిన్ఫ్రేమ్లు, ఈ మెషీన్లు ఇప్పుడు తెలిసినట్లుగా, భారీ, ప్రత్యేకించి ఎయిర్ కండిషన్డ్ కంప్యూటర్ రూమ్లలో బంధించబడ్డాయి, వాటిని నిర్వహించడానికి అర్హత కలిగిన ఆపరేటర్ల బృందాలు ఉన్నాయి. భారీ వ్యాపారాలు, ముఖ్యమైన ప్రభుత్వ సంస్థలు లేదా సంస్థలు మాత్రమే అనేక మిలియన్ డాలర్ల ధరను కొనుగోలు చేయగలవు.
-
మూడో తరం (1965-80): వ్యక్తిగత ట్రాన్సిస్టర్ల నుండి నిర్మించబడిన రెండవ తరం కంప్యూటర్లతో పోల్చితే, IBM 360 అనేది (చిన్న-స్థాయి) ICలను (ఇంటిగ్రేటెడ్ సర్క్యూట్లు) ఉపయోగించుకున్న మొదటి పెద్ద కంప్యూటర్ లైన్. ఫలితంగా, ఇది గణనీయమైన ధర/పనితీరు ప్రయోజనాన్ని అందించింది. ఇది తక్షణ హిట్ అయ్యింది మరియు ఇతర పెద్ద తయారీదారులందరూ ఇంటర్ఆపరబుల్ కంప్యూటర్ల కుటుంబం అనే భావనను త్వరగా స్వీకరించారు. OS/360 ఆపరేటింగ్ సిస్టమ్తో సహా అన్ని సాఫ్ట్వేర్లు అసలు డిజైన్లోని అన్ని మోడళ్లకు అనుకూలంగా ఉండాలి. ఇది భారీ గణన మరియు వాతావరణ సూచన కోసం తరచుగా 7094లను భర్తీ చేసే భారీ సిస్టమ్లపై అమలు చేయవలసి ఉంటుంది మరియు కార్డులను టేప్కు బదిలీ చేయడానికి 1401లను తరచుగా భర్తీ చేసే చిన్న వ్యవస్థలు. కొన్ని పెరిఫెరల్స్తో కూడిన రెండు సిస్టమ్లు మరియు అనేక పెరిఫెరల్స్తో కూడిన సిస్టమ్లు దానితో బాగా పనిచేయడానికి అవసరం. ఇది వృత్తిపరమైన మరియు అకడమిక్ సెట్టింగులలో పనిచేయాలి. అన్నింటికంటే మించి, ఈ అనేక అప్లికేషన్లలో ప్రతిదానికి ఇది ప్రభావవంతంగా ఉండాలి.
-
నాల్గవ తరం (1980-ప్రస్తుతం): వ్యక్తిగత కంప్యూటర్ యుగం LSI (లార్జ్ స్కేల్ ఇంటిగ్రేషన్) సర్క్యూట్లు, చదరపు సెంటీమీటర్ సిలికాన్పై వేల ట్రాన్సిస్టర్లతో ప్రాసెసర్ల సృష్టితో ప్రారంభమైంది. వాస్తవానికి మైక్రోకంప్యూటర్లుగా పిలవబడే వ్యక్తిగత కంప్యూటర్లు, PDP-11 తరగతికి చెందిన మినీకంప్యూటర్ల నుండి నిర్మాణంలో గణనీయంగా మారనప్పటికీ, అవి ధరలో గణనీయంగా తేడాను కలిగి ఉన్నాయి.
-
ఐదవ తరం (1990-ప్రస్తుతం): 1940ల కామిక్ స్ట్రిప్లోని డిటెక్టివ్ డిక్ ట్రేసీ తన "రెండు-మార్గం రేడియో చేతి గడియారం"తో సంభాషించడం ప్రారంభించినప్పటి నుండి ప్రజలు పోర్టబుల్ కమ్యూనికేషన్ గాడ్జెట్ కోసం ఆరాటపడ్డారు. 1946 లో, ఒక నిజమైన మొబైల్ ఫోన్ ప్రారంభమైంది మరియు దాని బరువు 40 కిలోగ్రాములు. మొదటి నిజమైన పోర్టబుల్ ఫోన్ 1970 లలో ప్రారంభమైంది మరియు ఒక కిలోగ్రాము వద్ద చాలా తేలికగా ఉంది. ఇది "ఇటుక" అని సరదాగా సూచించబడింది. కాసేపటికే, అందరూ ఒక్కటి కోసం తహతహలాడారు.
- సౌలభ్యం: OS కంప్యూటర్ను ఉపయోగించడానికి మరింత సౌకర్యవంతంగా చేస్తుంది.
- ** సమర్థత**: కంప్యూటర్ సిస్టమ్ వనరులను సమర్ధవంతంగా ఉపయోగించుకోవడానికి OS అనుమతిస్తుంది.
- ఎబిలిటీ టు ఎవాల్వ్: సర్వీస్లో జోక్యం చేసుకోకుండా అదే సమయంలో కొత్త సిస్టమ్ ఫంక్షన్లను ప్రభావవంతంగా అభివృద్ధి చేయడం, పరీక్షించడం మరియు పరిచయం చేయడం వంటి వాటిని అనుమతించే విధంగా OS నిర్మించబడాలి.
- త్రూపుట్: గరిష్ట నిర్గమాంశ (యూనిట్ సమయానికి టాస్క్ల సంఖ్య) ఇవ్వగలిగేలా ఒక OS నిర్మించబడాలి.
- రిసోర్స్ మేనేజ్మెంట్: OSలో సమాంతర యాక్సెస్ జరిగినప్పుడు, బహుళ వినియోగదారులు సిస్టమ్ను యాక్సెస్ చేస్తున్నప్పుడు, OS రిసోర్స్ మేనేజర్గా పని చేస్తుంది. వినియోగదారుకు హార్డ్వేర్ అందించడం దీని బాధ్యత. ఇది సిస్టమ్లో లోడ్ను తగ్గిస్తుంది.
- ప్రాసెస్ మేనేజ్మెంట్: ఇది ప్రక్రియ యొక్క షెడ్యూల్ మరియు ముగింపు వంటి వివిధ పనులను కలిగి ఉంటుంది. OS ఒకేసారి వివిధ పనులను నిర్వహిస్తుంది. ఇక్కడ CPU షెడ్యూలింగ్ జరుగుతుంది అంటే షెడ్యూలింగ్ కోసం ఉపయోగించే అనేక అల్గారిథమ్ల ద్వారా అన్ని పనులు జరుగుతాయి.
- స్టోరేజ్ మేనేజ్మెంట్: నిల్వ నిర్వహణ కోసం ఉపయోగించే ఫైల్ సిస్టమ్ మెకానిజం. NIFS, CFS, CIFS, NFS మొదలైనవి కొన్ని ఫైల్ సిస్టమ్లు. మొత్తం డేటా హార్డ్ డిస్క్ల యొక్క వివిధ ట్రాక్లలో నిల్వ చేయబడుతుంది, ఇవన్నీ స్టోరేజ్ మేనేజర్ ద్వారా నిర్వహించబడతాయి. అందులో హార్డ్ డిస్క్ ఉంది.
- మెమరీ మేనేజ్మెంట్: ప్రాథమిక మెమరీ నిర్వహణను సూచిస్తుంది. ఆపరేటింగ్ సిస్టమ్ ఎంత మెమరీని ఎవరు ఉపయోగించారు అనే విషయాలను ట్రాక్ చేయాలి. ఏ ప్రక్రియకు మెమరీ స్థలం అవసరం మరియు ఎంత అవసరమో నిర్ణయించుకోవాలి. OS కూడా మెమరీ స్థలాన్ని కేటాయించాలి మరియు డీలాకేట్ చేయాలి.
- భద్రత/గోప్యతా నిర్వహణ: పాస్వర్డ్లను ఉపయోగించి ఆపరేటింగ్ సిస్టమ్ ద్వారా గోప్యత కూడా అందించబడుతుంది, తద్వారా అనధికార అప్లికేషన్లు ప్రోగ్రామ్లు లేదా డేటాను యాక్సెస్ చేయలేవు. ఉదాహరణకు, డేటాకు అనధికార ప్రాప్యతను నిరోధించడానికి Windows Kerberos ప్రమాణీకరణను ఉపయోగిస్తుంది.
-
మెయిన్ఫ్రేమ్ OS: అధిక ముగింపులో మెయిన్ఫ్రేమ్ల కోసం ఆపరేటింగ్ సిస్టమ్లు ఉన్నాయి, ఆ గది పరిమాణం కంప్యూటర్లు ఇప్పటికీ ప్రధాన కార్పొరేట్ డేటా సెంటర్లలో కనుగొనబడ్డాయి. ఈ కంప్యూటర్లు భిన్నంగా ఉంటాయి వ్యక్తిగత కంప్యూటర్లు వాటి I/O సామర్థ్యం పరంగా. 1000 డిస్క్లతో కూడిన మెయిన్ఫ్రేమ్ మరియు మిలియన్ల గిగాబైట్ల డేటా అసాధారణమైనది కాదు; వీటితో కూడిన వ్యక్తిగత కంప్యూటర్ స్పెసిఫికేషన్లు దాని స్నేహితుల అసూయగా ఉంటాయి. మెయిన్ఫ్రేమ్లు కూడా కొన్ని తయారు చేస్తున్నాయి- హై-ఎండ్ వెబ్ సర్వర్లు, పెద్ద-స్థాయి ఎలక్ట్రానిక్ కోసం సర్వర్లుగా తిరిగి వచ్చే విషయం వాణిజ్య సైట్లు మరియు వ్యాపారం నుండి వ్యాపార లావాదేవీల కోసం సర్వర్లు. మెయిన్ఫ్రేమ్ల కోసం ఆపరేటింగ్ సిస్టమ్లు ప్రాసెసింగ్ వైపు ఎక్కువగా దృష్టి సారిస్తాయి ఒకేసారి అనేక ఉద్యోగాలు, వీటిలో చాలా వరకు I/O యొక్క అద్భుతమైన మొత్తాలు అవసరం. వారు సాధారణంగా మూడు రకాల సేవలను అందిస్తాయి: బ్యాచ్, లావాదేవీ ప్రాసెసింగ్ మరియు టైమ్షేరింగ్
-
సర్వర్ OS: ఒక స్థాయి డౌన్ సర్వర్ ఆపరేటింగ్ సిస్టమ్స్. అవి సర్వర్లపై నడుస్తాయి, ఇది చాలా పెద్ద వ్యక్తిగత కంప్యూటర్లు, వర్క్స్టేషన్లు లేదా మెయిన్ఫ్రేమ్లు కూడా. వాళ్ళు నెట్వర్క్లో ఒకేసారి బహుళ వినియోగదారులకు సేవలందించండి మరియు హార్డ్వేర్ను భాగస్వామ్యం చేయడానికి వినియోగదారులను అనుమతించండి మరియు సాఫ్ట్వేర్ వనరులు. సర్వర్లు ప్రింట్ సేవ, ఫైల్ సేవ లేదా వెబ్ సేవను అందించగలవు. ఇంటర్నెట్ ప్రొవైడర్లు తమ కస్టమర్లకు మద్దతు ఇవ్వడానికి అనేక సర్వర్ మెషీన్లను అమలు చేస్తారు , మరియు వెబ్సైట్లు వెబ్ పేజీలను నిల్వ చేయడానికి మరియు ఇన్కమింగ్ అభ్యర్థనలను నిర్వహించడానికి సర్వర్లను ఉపయోగిస్తాయి. సాధారణ సర్వర్ ఆపరేటింగ్ సిస్టమ్లు సోలారిస్, ఫ్రీబిఎస్డి, లైనక్స్ మరియు విండోస్ సర్వర్ 201x.
-
మల్టీప్రాసెసర్ OS: మేజర్-లీగ్ కంప్యూటింగ్ పవర్ని పొందడానికి పెరుగుతున్న సాధారణ మార్గం బహుళ CPUలను ఒకే సిస్టమ్లోకి కనెక్ట్ చేయడం. అవి ఎలా కనెక్ట్ చేయబడ్డాయి మరియు భాగస్వామ్యం చేయబడిన వాటిపై ఆధారపడి, ఈ వ్యవస్థలను సమాంతర కంప్యూటర్లు, బహుళ-కంప్యూటర్లు లేదా మల్టీప్రాసెసర్లు అంటారు. వారికి ప్రత్యేక ఆపరేటింగ్ సిస్టమ్లు అవసరం, కానీ తరచుగా ఇవి సర్వర్ ఆపరేటింగ్ సిస్టమ్లలో వైవిధ్యాలు, కమ్యూనికేషన్, కనెక్టివిటీ మరియు స్థిరత్వం కోసం ప్రత్యేక లక్షణాలతో.
-
పర్సనల్ కంప్యూటర్ OS: తదుపరి వర్గం వ్యక్తిగత కంప్యూటర్ ఆపరేటింగ్ సిస్టమ్. అన్నీ ఆధునికమైనవి మల్టీప్రోగ్రామింగ్కు మద్దతు ఇస్తుంది, తరచుగా డజన్ల కొద్దీ ప్రోగ్రామ్లు బూట్ సమయంలో ప్రారంభించబడతాయి. వారి పని ఒకే వినియోగదారుకు మంచి మద్దతును అందించడం. వారు విస్తృతంగా ఉపయోగిస్తారు వర్డ్ ప్రాసెసింగ్, స్ప్రెడ్షీట్లు, గేమ్లు మరియు ఇంటర్నెట్ యాక్సెస్. సాధారణ ఉదాహరణలు Linux, FreeBSD, Windows 7, Windows 8, మరియు Apple యొక్క OS X. వ్యక్తిగత కంప్యూటర్ ఆపరేటింగ్ సిస్టమ్స్ చాలా విస్తృతంగా ప్రసిద్ధి చెందాయి, బహుశా తక్కువ పరిచయం అవసరం. చాలా మందికి ఇతర రకాలు ఉన్నాయని కూడా తెలియదు.
-
ఎంబెడెడ్ OS: ఎంబెడెడ్ సిస్టమ్లు సాధారణంగా కంప్యూటర్లుగా పరిగణించబడని మరియు వినియోగదారు-ఇన్స్టాల్ చేసిన సాఫ్ట్వేర్ను ఆమోదించని పరికరాలను నియంత్రించే కంప్యూటర్లపై అమలవుతాయి. సాధారణ ఉదాహరణలు మైక్రోవేవ్ ఓవెన్లు, టీవీ సెట్లు, కార్లు, DVD రికార్డర్లు, సంప్రదాయమైనవి ఫోన్లు మరియు MP3 ప్లేయర్లు. ఎంబెడెడ్ సిస్టమ్లను హ్యాండ్హెల్డ్ల నుండి వేరుచేసే ప్రధాన ప్రాపర్టీ ఏమిటంటే, ఎటువంటి అవిశ్వసనీయ సాఫ్ట్వేర్ వాటిపై ఎప్పటికీ అమలు చేయబడదని నిశ్చయత. మీరు మీ మైక్రోవేవ్ ఓవెన్-అన్ని సాఫ్ట్వేర్లకు కొత్త అప్లికేషన్లను డౌన్లోడ్ చేయలేరు ROMలో ఉంది. అప్లికేషన్ల మధ్య రక్షణ అవసరం లేదని దీని అర్థం, సరళీకృత డిజైన్. పొందుపరిచిన Linux, QNX మరియు వంటి సిస్టమ్లు VxWorks ఈ డొమైన్లో ప్రసిద్ధి చెందింది.
-
స్మార్ట్ కార్డ్ OS: అతి చిన్న ఆపరేటింగ్ సిస్టమ్లు క్రెడిట్-కార్డ్-పరిమాణ స్మార్ట్ కార్డ్పై నడుస్తాయి CPU చిప్లతో పరికరాలు. వారు చాలా తీవ్రమైన ప్రాసెసింగ్ పవర్ మరియు మెమరీ పరిమితులను కలిగి ఉన్నారు. కొన్ని రీడర్లోని పరిచయాల ద్వారా ఆధారితమైనవి చొప్పించబడింది, కానీ కాంటాక్ట్లెస్ స్మార్ట్ కార్డ్లు ప్రేరేపకంగా శక్తిని కలిగి ఉంటాయి, చాలా పరిమితం చేస్తాయి వారు ఏమి చేయగలరు. కొందరు ఎలక్ట్రానిక్ చెల్లింపుల వంటి ఒకే ఫంక్షన్ను మాత్రమే నిర్వహించగలరు, అయితే ఇతరులు బహుళ ఫంక్షన్లను నిర్వహించగలరు. తరచుగా ఇవి యాజమాన్య వ్యవస్థలు. కొన్ని స్మార్ట్ కార్డ్లు జావా ఓరియెంటెడ్గా ఉంటాయి. అంటే స్మార్ట్లో ఉన్న ROM కార్డ్ జావా వర్చువల్ మెషిన్ (JVM) కోసం ఇంటర్ప్రెటర్ను కలిగి ఉంది. జావా ఆప్లెట్స్ (చిన్న ప్రోగ్రామ్లు) కార్డ్కి డౌన్లోడ్ చేయబడతాయి మరియు JVM ఇంటర్ప్రెటర్ ద్వారా వివరించబడతాయి. ఈ కార్డ్లలో కొన్ని ఒకే సమయంలో బహుళ జావా ఆప్లెట్లను హ్యాండిల్ చేయగలవు మల్టీప్రోగ్రామింగ్ మరియు వాటిని షెడ్యూల్ చేయవలసిన అవసరం. రెండు లేదా అంతకంటే ఎక్కువ ఆప్లెట్లు ఏకకాలంలో ఉన్నప్పుడు వనరుల నిర్వహణ మరియు రక్షణ కూడా సమస్యగా మారుతుంది. ఈ సమస్యలు తప్పనిసరిగా కార్డ్లో ఉన్న (సాధారణంగా అత్యంత ప్రాచీనమైన) ఆపరేటింగ్ సిస్టమ్ ద్వారా నిర్వహించబడాలి.
memory అనే పదం మీ కంప్యూటర్లోని స్వల్పకాలిక డేటా యాక్సెస్ను అనుమతించే భాగాన్ని సూచిస్తుంది. మీరు ఈ భాగాన్ని DRAM లేదా డైనమిక్ రాండమ్-యాక్సెస్ మెమరీగా గుర్తించవచ్చు. మీ కంప్యూటర్ దాని స్వల్పకాలిక మెమరీలో నిల్వ చేయబడిన డేటాను యాక్సెస్ చేయడం ద్వారా అనేక కార్యకలాపాలను నిర్వహిస్తుంది. అటువంటి కార్యకలాపాలకు కొన్ని ఉదాహరణలు పత్రాన్ని సవరించడం, అప్లికేషన్లను లోడ్ చేయడం మరియు ఇంటర్నెట్ను బ్రౌజ్ చేయడం వంటివి. మీ సిస్టమ్ యొక్క వేగం మరియు పనితీరు మీ కంప్యూటర్లో ఇన్స్టాల్ చేయబడిన మెమరీ పరిమాణంపై ఆధారపడి ఉంటుంది.
మీకు డెస్క్ మరియు ఫైలింగ్ క్యాబినెట్ ఉంటే, డెస్క్ మీ కంప్యూటర్ మెమరీని సూచిస్తుంది. మీరు వెంటనే ఉపయోగించాల్సిన అంశాలు సులభంగా యాక్సెస్ చేయడానికి మీ డెస్క్పై ఉంచబడతాయి. అయినప్పటికీ, దాని పరిమాణ పరిమితుల కారణంగా డెస్క్పై ఎక్కువ నిల్వ చేయబడదు.
మెమరీ అనేది స్వల్పకాలిక డేటా యొక్క స్థానాన్ని సూచిస్తుంది, అయితే storage అనేది మీ కంప్యూటర్లోని భాగం, ఇది డేటాను దీర్ఘకాలికంగా నిల్వ చేయడానికి మరియు యాక్సెస్ చేయడానికి మిమ్మల్ని అనుమతిస్తుంది. సాధారణంగా, నిల్వ అనేది సాలిడ్-స్టేట్ డ్రైవ్ లేదా హార్డ్ డ్రైవ్ రూపంలో వస్తుంది. నిల్వ మీ అప్లికేషన్లు, ఆపరేటింగ్ సిస్టమ్ మరియు ఫైల్లను నిరవధికంగా ఉంచుతుంది. కంప్యూటర్లు స్టోరేజ్ సిస్టమ్ నుండి సమాచారాన్ని చదవాలి మరియు వ్రాయాలి, కాబట్టి మీరు సేవ్ చేసిన వాటిని మీ సిస్టమ్ ఎంత వేగంగా బూట్ చేయవచ్చో, లోడ్ చేయగలదో మరియు యాక్సెస్ చేయగలదో స్టోరేజ్ వేగం నిర్ణయిస్తుంది.
డెస్క్ కంప్యూటర్ మెమరీని సూచిస్తుంది, ఫైలింగ్ క్యాబినెట్ మీ కంప్యూటర్ నిల్వను సూచిస్తుంది. ఇది సేవ్ చేయవలసిన మరియు నిల్వ చేయవలసిన ఐటెమ్లను కలిగి ఉంటుంది కానీ తక్షణ ప్రాప్యత కోసం అవసరం లేదు. ఫైలింగ్ క్యాబినెట్ పరిమాణం అంటే అది చాలా విషయాలను కలిగి ఉంటుంది.
మెమొరీ మరియు స్టోరేజ్ మధ్య ఒక ముఖ్యమైన వ్యత్యాసం కంప్యూటర్ ఆఫ్ చేయబడినప్పుడు మెమరీ క్లియర్ అవుతుంది. మరోవైపు, మీరు మీ కంప్యూటర్ను ఎంత తరచుగా ఆపివేసినప్పటికీ నిల్వ చెక్కుచెదరకుండా ఉంటుంది. అందువల్ల, డెస్క్ మరియు ఫైలింగ్ క్యాబినెట్ సారూప్యతలో, మీరు కార్యాలయం నుండి బయలుదేరినప్పుడు మీ డెస్క్పై మిగిలి ఉన్న ఏవైనా ఫైల్లు విసిరివేయబడతాయి. మీ ఫైలింగ్ క్యాబినెట్లోని ప్రతిదీ అలాగే ఉంటుంది.
కంప్యూటర్ సిస్టమ్స్ యొక్క గుండె వద్ద మెమరీ ఉంది, ప్రోగ్రామ్లు రన్ అయ్యే స్థలం మరియు డేటా నిల్వ చేయబడుతుంది. కానీ మీరు అమలు చేస్తున్న ప్రోగ్రామ్లు మరియు మీరు పని చేస్తున్న డేటా మీ కంప్యూటర్ మెమరీ యొక్క భౌతిక సామర్థ్యాన్ని మించిపోయినప్పుడు ఏమి జరుగుతుంది? ఇక్కడే వర్చువల్ మెమరీ మీ కంప్యూటర్ మెమరీకి స్మార్ట్ ఎక్స్టెన్షన్గా పనిచేస్తుంది మరియు దాని సామర్థ్యాలను మెరుగుపరుస్తుంది.
వర్చువల్ మెమరీ యొక్క నిర్వచనం మరియు ప్రయోజనం:
వర్చువల్ మెమరీ అనేది ఫిజికల్ మెమరీ (RAM) పరిమితులను అధిగమించడానికి ఆపరేటింగ్ సిస్టమ్లచే ఉపయోగించబడే మెమరీ మేనేజ్మెంట్ టెక్నిక్. ఇది కంప్యూటర్లో భౌతికంగా ఇన్స్టాల్ చేయబడిన దాని కంటే ఎక్కువ మెమరీని కలిగి ఉన్న సాఫ్ట్వేర్ అప్లికేషన్లకు ఒక భ్రమను సృష్టిస్తుంది. సారాంశంలో, ఇది కంప్యూటర్ యొక్క భౌతిక RAM యొక్క పరిమితులకు మించి మెమరీ స్థలాన్ని ఉపయోగించుకునేలా ప్రోగ్రామ్లను అనుమతిస్తుంది.
వర్చువల్ మెమొరీ యొక్క ప్రాథమిక ఉద్దేశ్యం సమర్థవంతమైన మల్టీ టాస్కింగ్ మరియు పెద్ద ప్రోగ్రామ్ల అమలును ప్రారంభించడం, ఇవన్నీ సిస్టమ్ యొక్క ప్రతిస్పందనను కొనసాగించడం. ఇది భౌతిక RAM మరియు హార్డ్ డ్రైవ్ లేదా SSD వంటి సెకండరీ స్టోరేజ్ పరికరాల మధ్య అతుకులు లేని పరస్పర చర్యను సృష్టించడం ద్వారా దీనిని సాధిస్తుంది.
వర్చువల్ మెమరీ భౌతిక మెమరీని ఎలా విస్తరింపజేస్తుంది:
వర్చువల్ మెమరీని మీ కంప్యూటర్ యొక్క RAM మరియు దాని ద్వితీయ నిల్వ (డిస్క్ డ్రైవ్లు) కలిపే వంతెనగా భావించండి. మీరు ప్రోగ్రామ్ను అమలు చేసినప్పుడు, దానిలోని భాగాలు వేగవంతమైన భౌతిక మెమరీ (RAM)లోకి లోడ్ చేయబడతాయి. అయితే, ప్రోగ్రామ్లోని అన్ని భాగాలు వెంటనే ఉపయోగించబడవు.
వర్చువల్ మెమరీ ఈ పరిస్థితిని యాక్టివ్గా ఉపయోగించని ప్రోగ్రామ్లోని విభాగాలను RAM నుండి సెకండరీ స్టోరేజ్కి తరలించడం ద్వారా ఉపయోగించుకుంటుంది, చురుకుగా ఉపయోగంలో ఉన్న భాగాలకు RAMలో ఎక్కువ స్థలాన్ని సృష్టిస్తుంది. ఈ ప్రక్రియ వినియోగదారుకు మరియు నడుస్తున్న ప్రోగ్రామ్లకు పారదర్శకంగా ఉంటుంది. తరలించబడిన భాగాలు మళ్లీ అవసరమైనప్పుడు, అవి తిరిగి RAMలోకి మార్చబడతాయి, అయితే ఇతర తక్కువ క్రియాశీల భాగాలు ద్వితీయ నిల్వకు తరలించబడతాయి.
భౌతిక మెమరీలో మరియు వెలుపల డేటా యొక్క ఈ డైనమిక్ స్వాపింగ్ ఆపరేటింగ్ సిస్టమ్ ద్వారా నిర్వహించబడుతుంది. ఇది ప్రోగ్రామ్లు అందుబాటులో ఉన్న RAM కంటే పెద్దగా ఉన్నప్పటికీ అమలు చేయడానికి అనుమతిస్తుంది, ఎందుకంటే ఆపరేటింగ్ సిస్టమ్ సరైన పనితీరు కోసం RAMలో ఏ డేటా ఉండాలో తెలివిగా నిర్ణయిస్తుంది.
సారాంశంలో, వర్చువల్ మెమరీ అనేది ర్యామ్ మరియు సెకండరీ స్టోరేజ్ మధ్య ప్రోగ్రామ్లు మరియు డేటా యొక్క భాగాలను తాత్కాలికంగా బదిలీ చేయడం ద్వారా అందుబాటులో ఉన్న భౌతిక మెమరీని విస్తరించే వర్చువలైజేషన్ లేయర్గా పనిచేస్తుంది. ఈ ప్రక్రియ కంప్యూటర్ పెద్ద టాస్క్లను మరియు అనేక ప్రోగ్రామ్లను ఏకకాలంలో నిర్వహించగలదని నిర్ధారిస్తుంది, అదే సమయంలో సమర్ధవంతమైన పనితీరు మరియు ప్రతిస్పందనను కొనసాగిస్తుంది.
కంప్యూటింగ్లో, ఫైల్ సిస్టమ్ లేదా ఫైల్సిస్టమ్ (తరచుగా fs అని సంక్షిప్తీకరించబడుతుంది) అనేది డేటా ఎలా నిల్వ చేయబడి మరియు తిరిగి పొందబడుతుందో నియంత్రించడానికి ఆపరేటింగ్ సిస్టమ్ ఉపయోగించే ఒక పద్ధతి మరియు డేటా నిర్మాణం. ఫైల్ సిస్టమ్ లేకుండా, స్టోరేజ్ మీడియంలో ఉంచిన డేటా ఒక పెద్ద డేటాగా ఉంటుంది, ఒక డేటా ఎక్కడ ఆగిపోయింది మరియు తదుపరిది ఎక్కడ ప్రారంభమైంది లేదా దాన్ని తిరిగి పొందే సమయం వచ్చినప్పుడు ఏదైనా డేటా ఎక్కడ ఉందో చెప్పడానికి మార్గం లేదు. డేటాను ముక్కలుగా విభజించి, ప్రతి భాగానికి పేరు పెట్టడం ద్వారా, డేటా సులభంగా వేరు చేయబడి, గుర్తించబడుతుంది. పేపర్ ఆధారిత డేటా మేనేజ్మెంట్ సిస్టమ్కు ఎలా పేరు పెట్టారు అనే దాని నుండి దాని పేరును తీసుకొని, ప్రతి డేటా సమూహాన్ని "ఫైల్" అంటారు. డేటా సమూహాలు మరియు వాటి పేర్లను నిర్వహించడానికి ఉపయోగించే నిర్మాణం మరియు లాజిక్ నియమాలను "ఫైల్ సిస్టమ్" అంటారు.
అనేక రకాల ఫైల్ సిస్టమ్లు ఉన్నాయి, ప్రతి ఒక్కటి ప్రత్యేకమైన నిర్మాణం మరియు తర్కం, వేగం యొక్క లక్షణాలు, సౌలభ్యం, భద్రత, పరిమాణం మరియు మరిన్ని. కొన్ని ఫైల్ సిస్టమ్లు నిర్దిష్ట అప్లికేషన్ల కోసం ఉపయోగించేందుకు రూపొందించబడ్డాయి. ఉదాహరణకు, ISO 9660 ఫైల్ సిస్టమ్ ప్రత్యేకంగా ఆప్టికల్ డిస్క్ల కోసం రూపొందించబడింది.
వివిధ మాధ్యమాలను ఉపయోగించి అనేక రకాల నిల్వ పరికరాలలో ఫైల్ సిస్టమ్లను ఉపయోగించవచ్చు. 2019 నాటికి, హార్డ్ డిస్క్ డ్రైవ్లు కీలకమైన స్టోరేజ్ డివైజ్లుగా ఉన్నాయి మరియు భవిష్యత్తులో కూడా అలాగే ఉంటాయని అంచనా వేయబడింది. SSDలు, మాగ్నెటిక్ టేపులు మరియు ఆప్టికల్ డిస్క్లు ఉపయోగించబడే ఇతర రకాల మీడియా. tmpfs వంటి కొన్ని సందర్భాల్లో, కంప్యూటర్ యొక్క ప్రధాన మెమరీ (రాండమ్-యాక్సెస్ మెమరీ, RAM) స్వల్పకాలిక ఉపయోగం కోసం తాత్కాలిక ఫైల్ సిస్టమ్ను సృష్టిస్తుంది.
కొన్ని ఫైల్ సిస్టమ్లు స్థానిక డేటా నిల్వ పరికరాలలో ఉపయోగించబడతాయి; ఇతరులు నెట్వర్క్ ప్రోటోకాల్ ద్వారా ఫైల్ యాక్సెస్ను అందిస్తారు (ఉదాహరణకు, NFS, SMB లేదా 9P క్లయింట్లు). కొన్ని ఫైల్ సిస్టమ్లు "వర్చువల్", అంటే సరఫరా చేయబడిన "ఫైల్స్" (వర్చువల్ ఫైల్స్ అని పిలుస్తారు) అభ్యర్థనపై (procfs మరియు sysfs వంటివి) గణించబడతాయి లేదా బ్యాకింగ్ స్టోర్గా ఉపయోగించే వేరే ఫైల్ సిస్టమ్లోకి మ్యాపింగ్ మాత్రమే. ఫైల్ సిస్టమ్ ఫైల్ల కంటెంట్ మరియు ఆ ఫైల్ల గురించి మెటాడేటా రెండింటికి యాక్సెస్ను నిర్వహిస్తుంది. నిల్వ స్థలాన్ని ఏర్పాటు చేయడానికి ఇది బాధ్యత వహిస్తుంది; భౌతిక నిల్వ మాధ్యమానికి సంబంధించి విశ్వసనీయత, సామర్థ్యం మరియు ట్యూనింగ్ ముఖ్యమైన డిజైన్ పరిగణనలు.
ఫైల్ సిస్టమ్ డేటాను నిల్వ చేస్తుంది మరియు నిర్వహిస్తుంది మరియు నిల్వ పరికరంలో ఉన్న మొత్తం డేటా కోసం ఒక రకమైన సూచికగా పరిగణించబడుతుంది. ఈ పరికరాలు హార్డ్ డ్రైవ్లు, ఆప్టికల్ డ్రైవ్లు మరియు ఫ్లాష్ డ్రైవ్లను కలిగి ఉంటాయి.
ఫైల్ సిస్టమ్లు ఫైల్లకు పేరు పెట్టడం కోసం సంప్రదాయాలను పేర్కొంటాయి, పేరులోని గరిష్ట సంఖ్యలో అక్షరాలు, ఏ అక్షరాలను ఉపయోగించవచ్చు మరియు కొన్ని సిస్టమ్లలో, ఫైల్ పేరు ప్రత్యయం ఎంత వరకు ఉంటుంది. అనేక ఫైల్ సిస్టమ్లలో, ఫైల్ పేర్లు కేస్-సెన్సిటివ్ కాదు.
ఫైల్తో పాటు, ఫైల్ సిస్టమ్లు మెటాడేటాలోని డైరెక్టరీలో ఫైల్ పరిమాణం మరియు దాని లక్షణాలు, స్థానం మరియు సోపానక్రమం వంటి సమాచారాన్ని కలిగి ఉంటాయి. మెటాడేటా డ్రైవ్లో అందుబాటులో ఉన్న ఉచిత స్టోరేజ్ బ్లాక్లను మరియు ఎంత స్థలం అందుబాటులో ఉందో కూడా గుర్తించగలదు.
డైరెక్టరీల నిర్మాణం ద్వారా ఫైల్కు మార్గాన్ని పేర్కొనడానికి ఫైల్ సిస్టమ్ ఫార్మాట్ను కూడా కలిగి ఉంటుంది. ఒక ఫైల్ డైరెక్టరీలో -- లేదా Windows OSలోని ఫోల్డర్లో -- లేదా ట్రీ స్ట్రక్చర్లో కావలసిన ప్రదేశంలో సబ్డైరెక్టరీలో ఉంచబడుతుంది. PC మరియు మొబైల్ OSలు ఫైల్ సిస్టమ్లను కలిగి ఉంటాయి, వీటిలో ఫైల్లు క్రమానుగత చెట్టు నిర్మాణంలో ఉంచబడతాయి.
నిల్వ మాధ్యమంలో ఫైల్లు మరియు డైరెక్టరీలను సృష్టించే ముందు, విభజనలను ఉంచాలి. విభజన అనేది హార్డ్ డిస్క్ యొక్క ప్రాంతం లేదా OS విడిగా నిర్వహించే ఇతర నిల్వ. ఒక ఫైల్ సిస్టమ్ ప్రాథమిక విభజనలో ఉంటుంది మరియు కొన్ని OSలు ఒక డిస్క్లో బహుళ విభజనలను అనుమతిస్తాయి. ఈ పరిస్థితిలో, ఒక ఫైల్ సిస్టమ్ పాడైతే, వేరే విభజనలోని డేటా సురక్షితంగా ఉంటుంది.
అనేక రకాల ఫైల్ సిస్టమ్లు ఉన్నాయి, అన్నీ వేర్వేరు తార్కిక నిర్మాణాలు మరియు వేగం మరియు పరిమాణం వంటి లక్షణాలతో ఉంటాయి. ఫైల్ సిస్టమ్ రకం OS మరియు ఆ OS అవసరాలను బట్టి మారవచ్చు. Microsoft Windows, Mac OS X మరియు Linux మూడు అత్యంత సాధారణ PC ఆపరేటింగ్ సిస్టమ్లు. మొబైల్ OSలలో Apple iOS మరియు Google Android ఉన్నాయి.
ప్రధాన ఫైల్ సిస్టమ్లు క్రింది వాటిని కలిగి ఉంటాయి:
-
ఫైల్ కేటాయింపు పట్టిక (FAT)కి Microsoft Windows OS మద్దతు ఇస్తుంది. FAT సాధారణ మరియు నమ్మదగినదిగా పరిగణించబడుతుంది మరియు లెగసీ ఫైల్ సిస్టమ్ల తర్వాత రూపొందించబడింది. FAT 1977లో ఫ్లాపీ డిస్క్ల కోసం రూపొందించబడింది కానీ తర్వాత హార్డ్ డిస్క్ల కోసం రూపొందించబడింది. చాలా ప్రస్తుత OSలతో సమర్థవంతంగా మరియు అనుకూలంగా ఉన్నప్పటికీ, FAT మరింత ఆధునిక ఫైల్ సిస్టమ్ల పనితీరు మరియు స్కేలబిలిటీతో సరిపోలలేదు.
-
గ్లోబల్ ఫైల్ సిస్టమ్ (GFS) అనేది Linux OS కోసం ఒక ఫైల్ సిస్టమ్, మరియు ఇది షేర్డ్ డిస్క్ ఫైల్ సిస్టమ్. GFS భాగస్వామ్య బ్లాక్ నిల్వకు ప్రత్యక్ష ప్రాప్యతను అందిస్తుంది మరియు స్థానిక ఫైల్ సిస్టమ్గా ఉపయోగించవచ్చు.
-
GFS2 అనేది నవీకరించబడిన మెటాడేటా సిస్టమ్ వంటి ఒరిజినల్ GFSలో చేర్చబడని లక్షణాలతో కూడిన నవీకరించబడిన సంస్కరణ. GNU జనరల్ పబ్లిక్ లైసెన్స్ నిబంధనల ప్రకారం, GFS మరియు GFS2 ఫైల్ సిస్టమ్లు రెండూ ఉచిత సాఫ్ట్వేర్గా అందుబాటులో ఉన్నాయి.
-
Mac ఆపరేటింగ్ సిస్టమ్లతో ఉపయోగం కోసం క్రమానుగత ఫైల్ సిస్టమ్ (HFS) అభివృద్ధి చేయబడింది. HFSని Mac OS స్టాండర్డ్ అని కూడా పిలుస్తారు, Mac OS ఎక్స్టెండెడ్ ద్వారా విజయం సాధించింది. వాస్తవానికి 1985లో ఫ్లాపీ మరియు హార్డ్ డిస్క్ల కోసం ప్రవేశపెట్టబడింది, HFS అసలు Macintosh ఫైల్ సిస్టమ్ను భర్తీ చేసింది. దీనిని CD-ROMలలో కూడా ఉపయోగించవచ్చు.
-
NT ఫైల్ సిస్టమ్ -- న్యూ టెక్నాలజీ ఫైల్ సిస్టమ్ (NTFS) అని కూడా పిలుస్తారు -- Windows NT 3.1 OS నుండి Windows ఉత్పత్తుల కోసం డిఫాల్ట్ ఫైల్ సిస్టమ్. మునుపటి FAT ఫైల్ సిస్టమ్ నుండి మెరుగుదలలు మెరుగైన మెటాడేటా మద్దతు, పనితీరు మరియు డిస్క్ స్థలాన్ని ఉపయోగించడం. NTFSకి ఉచిత, ఓపెన్ సోర్స్ NTFS డ్రైవర్ ద్వారా Linux OSలో కూడా మద్దతు ఉంది. Mac OSలు NTFS కోసం చదవడానికి మాత్రమే మద్దతుని కలిగి ఉన్నాయి.
-
యూనివర్సల్ డిస్క్ ఫార్మాట్ (UDF) అనేది ఆప్టికల్ మీడియా మరియు DVDల కోసం వెండర్-న్యూట్రల్ ఫైల్ సిస్టమ్. UDF ISO 9660 ఫైల్ సిస్టమ్ను భర్తీ చేస్తుంది మరియు DVD ఫోరమ్ ద్వారా ఎంపిక చేయబడిన DVD వీడియో మరియు ఆడియో కోసం అధికారిక ఫైల్ సిస్టమ్.
క్లౌడ్ కంప్యూటింగ్ అంటే ఇంటర్నెట్ ద్వారా సమాచారం మరియు అప్లికేషన్లను యాక్సెస్ చేయగల సామర్థ్యం. క్లౌడ్ కంప్యూటింగ్ ఇంటర్నెట్ కనెక్షన్తో ఏ ప్రదేశం నుండి అయినా అప్లికేషన్లు మరియు డేటాను యాక్సెస్ చేయడానికి వినియోగదారులను అనుమతిస్తుంది.
క్లౌడ్ కంప్యూటింగ్ అనేది ఒక రకమైన ఇంటర్నెట్ ఆధారిత కంప్యూటింగ్, ఇది కంప్యూటర్లు మరియు డిమాండ్పై ఇతర పరికరాలకు షేర్డ్ కంప్యూటర్ ప్రాసెసింగ్ వనరులు మరియు డేటాను అందిస్తుంది.
కాన్ఫిగర్ చేయదగిన కంప్యూటింగ్ వనరుల (ఉదా., నెట్వర్క్లు, సర్వర్లు, నిల్వ, అప్లికేషన్లు మరియు సేవలు) భాగస్వామ్య పూల్కు సర్వత్రా, అనుకూలమైన, ఆన్-డిమాండ్ నెట్వర్క్ యాక్సెస్ను ప్రారంభించడం కోసం ఇది ఒక నమూనా, వీటిని వేగంగా అందించవచ్చు మరియు తక్కువ నిర్వహణ ప్రయత్నం లేదా సేవతో విడుదల చేయవచ్చు. ప్రొవైడర్ పరస్పర చర్య.
క్లౌడ్ కంప్యూటింగ్ అనేది IT వనరుల గురించి వ్యాపారాలు ఎలా ఆలోచిస్తాయి అనే దాని నుండి పెద్ద మార్పు. సంస్థలు క్లౌడ్ కంప్యూటింగ్ సేవల వైపు మొగ్గు చూపడానికి ఇక్కడ ఏడు సాధారణ కారణాలు ఉన్నాయి:
ఖరీదు క్లౌడ్ కంప్యూటింగ్ హార్డ్వేర్ మరియు సాఫ్ట్వేర్లను కొనుగోలు చేయడం మరియు ఆన్-సైట్ డేటా సెంటర్లను సెటప్ చేయడం మరియు రన్ చేయడం వంటి మూలధన వ్యయాన్ని తొలగిస్తుంది-సర్వర్ల రాక్లు, పవర్ మరియు శీతలీకరణ కోసం రౌండ్-ది-క్లాక్ విద్యుత్ మరియు ఇన్ఫ్రాస్ట్రక్చర్ నిర్వహణ కోసం IT నిపుణులు. ఇది వేగంగా జతచేస్తుంది.
వేగం చాలా క్లౌడ్ కంప్యూటింగ్ సేవలు స్వీయ-సేవ మరియు డిమాండ్పై అందించబడతాయి, కాబట్టి పెద్ద మొత్తంలో కంప్యూటింగ్ వనరులను కూడా నిమిషాల్లో అందించవచ్చు, సాధారణంగా కేవలం కొన్ని మౌస్ క్లిక్లతో, వ్యాపారాలకు చాలా సౌలభ్యాన్ని ఇస్తుంది మరియు సామర్థ్య ప్రణాళికపై ఒత్తిడిని తగ్గిస్తుంది.
ప్రపంచ స్థాయి క్లౌడ్ కంప్యూటింగ్ సేవల ప్రయోజనాలు సాగే సామర్థ్యాన్ని కలిగి ఉంటాయి. క్లౌడ్ స్పీచ్లో, అంటే సరైన మొత్తంలో IT వనరులను అందించడం-ఉదాహరణకు, ఎక్కువ లేదా తక్కువ కంప్యూటింగ్ శక్తి, నిల్వ మరియు బ్యాండ్విడ్త్-అవసరమైనప్పుడు మరియు సరైన భౌగోళిక స్థానం నుండి.
ఉత్పాదకత ఆన్-సైట్ డేటా సెంటర్లకు సాధారణంగా చాలా "ర్యాకింగ్ మరియు స్టాకింగ్" అవసరం-హార్డ్వేర్ సెటప్, సాఫ్ట్వేర్ ప్యాచింగ్ మరియు ఇతర సమయం తీసుకునే IT నిర్వహణ పనులు. క్లౌడ్ కంప్యూటింగ్ ఈ అనేక పనుల అవసరాన్ని తొలగిస్తుంది, కాబట్టి IT బృందాలు మరింత ముఖ్యమైన వ్యాపార లక్ష్యాలను సాధించడంలో సమయాన్ని వెచ్చించవచ్చు.
ప్రదర్శన అతిపెద్ద క్లౌడ్ కంప్యూటింగ్ సేవలు ప్రపంచవ్యాప్త సురక్షిత డేటా సెంటర్ల నెట్వర్క్లో నడుస్తాయి, ఇవి తాజా తరం వేగవంతమైన మరియు సమర్థవంతమైన కంప్యూటింగ్ హార్డ్వేర్కు క్రమం తప్పకుండా అప్గ్రేడ్ చేయబడతాయి. ఇది ఒకే కార్పొరేట్ డేటా సెంటర్లో అనేక ప్రయోజనాలను అందిస్తుంది, అప్లికేషన్ల కోసం తగ్గిన నెట్వర్క్ జాప్యం మరియు గ్రేటర్ ఎకానమీ ఆఫ్ స్కేల్తో సహా.
విశ్వసనీయత క్లౌడ్ కంప్యూటింగ్ డేటా బ్యాకప్, విపత్తు పునరుద్ధరణ మరియు వ్యాపార కొనసాగింపును సులభతరం చేస్తుంది మరియు తక్కువ ఖర్చుతో కూడుకున్నది ఎందుకంటే క్లౌడ్ ప్రొవైడర్ నెట్వర్క్లోని బహుళ పునరావృత సైట్లలో డేటా ప్రతిబింబించబడుతుంది.
భద్రత చాలా మంది క్లౌడ్ ప్రొవైడర్లు మీ డేటా, యాప్లు మరియు ఇన్ఫ్రాస్ట్రక్చర్ను సంభావ్య బెదిరింపుల నుండి రక్షించడంలో సహాయపడటానికి, మీ భద్రతా భంగిమను మొత్తంగా పటిష్టపరిచే విస్తృతమైన విధానాలు, సాంకేతికతలు మరియు నియంత్రణలను అందిస్తారు.
- ఇన్ఫ్రాస్ట్రక్చర్ యాజ్ ఎ సర్వీస్ (IaaS)
- ప్లాట్ఫారమ్గా సేవ (PaaS)
- సాఫ్ట్వేర్ యాజ్ ఎ సర్వీస్ (SaaS)
మెషిన్ లెర్నింగ్ అంటే కంప్యూటర్ నేర్చుకోవడానికి నేర్పించే అభ్యాసం. ఇన్కమింగ్ డేటాపై తీర్పులు ఇవ్వడానికి కాన్సెప్ట్ నమూనా గుర్తింపును, అలాగే ఇతర రకాల ప్రిడిక్టివ్ అల్గారిథమ్లను ఉపయోగిస్తుంది. ఈ ఫీల్డ్ కృత్రిమ మేధస్సు మరియు గణన గణాంకాలకు దగ్గరి సంబంధం కలిగి ఉంది.
దీనిలో, మెషీన్ లెర్నింగ్ మోడల్లు లేబుల్ చేయబడిన డేటా సెట్లతో శిక్షణ పొందుతాయి, ఇవి మోడల్లు కాలక్రమేణా మరింత ఖచ్చితంగా తెలుసుకోవడానికి మరియు పెరగడానికి అనుమతిస్తాయి. ఉదాహరణకు, ఒక అల్గారిథమ్ కుక్కల చిత్రాలు మరియు ఇతర వస్తువులతో శిక్షణ పొందుతుంది, అన్నీ మనుషులచే లేబుల్ చేయబడతాయి మరియు యంత్రం కుక్కల చిత్రాలను స్వయంగా గుర్తించే మార్గాలను నేర్చుకుంటుంది. పర్యవేక్షించబడే యంత్ర అభ్యాసం అనేది నేడు ఉపయోగించే అత్యంత సాధారణ రకం.
పర్యవేక్షించబడిన అభ్యాసం యొక్క ప్రాక్టికల్ అప్లికేషన్లు -
- బయోఇన్ఫర్మేటిక్స్: బయోఇన్ఫర్మేటిక్స్ అనేది వ్యక్తులు వేలిముద్రలు, కంటి ఆకృతి, ఇయర్లోబ్లు మొదలైన జీవశాస్త్ర పరిజ్ఞానాన్ని ఎలా నిలుపుకుంటారో అధ్యయనం చేస్తుంది. మొబైల్ ఫోన్లు ఇప్పుడు మన బయోలాజికల్ డేటాను గ్రహించి, సిస్టమ్ భద్రతను పెంచడానికి మమ్మల్ని ధృవీకరించడానికి తగినంత తెలివైనవి.
- స్పీచ్ రికగ్నిషన్: ఇది ప్రోగ్రామ్ రకం, ఇక్కడ మీరు ప్రోగ్రామ్కి మీ వాయిస్ని తెలియజేయవచ్చు మరియు ఇది మిమ్మల్ని గుర్తిస్తుంది. అత్యంత ప్రసిద్ధ వాస్తవ-ప్రపంచ గాడ్జెట్లు Google అసిస్టెంట్ లేదా సిరి వంటి డిజిటల్ అసిస్టెంట్లు, ఇవి మీ వాయిస్తో మాత్రమే పదానికి ప్రతిస్పందిస్తాయి.
- స్పామ్ గుర్తింపు: ఈ సాధనం కల్పిత లేదా యంత్ర ఆధారిత కమ్యూనికేషన్లను పంపకుండా నిరోధించడానికి ఉపయోగించబడుతుంది. Gmail అనేక తప్పుడు నిబంధనలను నేర్చుకునే అల్గారిథమ్ని కలిగి ఉంది. Oneplus Messages యాప్ ఏ నిబంధనలను నిషేధించాలో పేర్కొనమని వినియోగదారుని అడుగుతుంది మరియు యాప్ నుండి అటువంటి టెక్స్ట్లను కీవర్డ్ నిరోధిస్తుంది.
- ** దృష్టి కోసం వస్తువు గుర్తింపు:** మీరు ఏదైనా నిర్వచించవలసి వచ్చినప్పుడు ఈ రకమైన సాఫ్ట్వేర్ ఉపయోగించబడుతుంది. మీరు అల్గారిథమ్కు శిక్షణ ఇవ్వడానికి ఉపయోగించే పెద్ద డేటాసెట్ను కలిగి ఉన్నారు మరియు ఇది దీన్ని ఉపయోగించి కొత్త వస్తువును గుర్తించగలదు.
పర్యవేక్షించబడని మెషీన్ లెర్నింగ్లో, ప్రోగ్రామ్ లేబుల్ చేయని డేటాలో నమూనాల కోసం చూస్తుంది. పర్యవేక్షించబడని యంత్ర అభ్యాసం వ్యక్తులు స్పష్టంగా వెతకని నమూనాలు లేదా ట్రెండ్లను కనుగొనవచ్చు. ఉదాహరణకు, పర్యవేక్షించబడని మెషీన్ లెర్నింగ్ ప్రోగ్రామ్ ఆన్లైన్ విక్రయాల డేటాను పరిశీలించి, కొనుగోళ్లు చేసే వివిధ రకాల క్లయింట్లను గుర్తించగలదు.
పర్యవేక్షించబడని అభ్యాసం యొక్క ప్రాక్టికల్ అప్లికేషన్లు
- క్లస్టరింగ్: క్లస్టరింగ్ అనేది డేటాను ప్రత్యేక సమూహాలుగా వర్గీకరించే ప్రక్రియ. క్లస్టర్ల గురించిన అన్ని వివరాలు మనకు తెలియనప్పుడు, వాటిని క్లస్టర్ చేయడానికి మేము పర్యవేక్షించబడని అభ్యాసాన్ని ఉపయోగించుకోవచ్చు. ముందుగా లేబుల్ చేయబడిన తరగతులు లేదా తరగతి లక్షణాలను కలిగి లేని డేటాను విశ్లేషించడానికి మరియు నిర్వహించడానికి పర్యవేక్షించబడని అభ్యాసం ఉపయోగించబడుతుంది. క్లస్టరింగ్ సంస్థలు తమ డేటాను మరింత సమర్థవంతంగా నిర్వహించడానికి సహాయపడుతుంది. మీకు యూట్యూబ్ ఛానెల్ ఉందనుకోండి. మీ సబ్స్క్రైబర్ల గురించి మీకు చాలా సమాచారం ఉండవచ్చు. మీరు ఇలాంటి సబ్స్క్రైబర్లను కనుగొనాలనుకుంటే, మీరు క్లస్టరింగ్ టెక్నిక్ని ఉపయోగించాల్సి ఉంటుంది.
- విజువలైజేషన్: రేఖాచిత్రాలు, ఫోటోలు, గ్రాఫ్లు, చార్ట్లు మరియు ఇతర సమాచారాన్ని ప్రదర్శించే ప్రక్రియను విజువలైజేషన్ అంటారు. ఈ వ్యూహాన్ని అమలు చేయడానికి పర్యవేక్షించబడని యంత్ర అభ్యాసాన్ని ఉపయోగించవచ్చు. టోర్నమెంట్లో మీ జట్టు ప్రదర్శనకు సంబంధించిన సమాచారంతో మీరు క్రికెట్ కోచ్ అని అనుకుందాం. మీరు మ్యాచ్ గణాంకాలన్నింటినీ త్వరగా గుర్తించాలనుకోవచ్చు. మీరు లేబుల్ చేయని మరియు సంక్లిష్టమైన డేటాను విజువలైజేషన్ అల్గారిథమ్కి పంపవచ్చు.
- అనామలీ డిటెక్షన్: అసాధారణమైన విషయాలు, సంఘటనలు లేదా సాధారణ డేటా నుండి పెద్దగా వైదొలగడం ద్వారా అనుమానాలను రేకెత్తించే పరిశీలనలను కనుగొనడాన్ని అనోమలీ డిటెక్షన్ అంటారు. ఈ పరిస్థితిలో, సిస్టమ్ పెద్ద సంఖ్యలో సాధారణ కేసులతో ప్రోగ్రామ్ చేయబడింది. ఫలితంగా, ఇది ఊహించని సంఘటనను గుర్తించినప్పుడు, అది అసాధారణమైనదా కాదా అని నిర్ధారించగలదు. క్రెడిట్ కార్డ్ మోసాన్ని గుర్తించడం దీనికి మంచి ఉదాహరణ. ఈ సమస్య ఇప్పుడు పర్యవేక్షించబడని మెషిన్ లెర్నింగ్ అనోమలీ డిటెక్షన్ విధానాలను ఉపయోగించి పరిష్కరించబడుతోంది. మోసాన్ని నివారించడానికి, సిస్టమ్ ఊహించని క్రెడిట్ కార్డ్ లావాదేవీలను గుర్తిస్తుంది.
పర్యవేక్షించబడే అభ్యాసం యొక్క ప్రతికూలత ఏమిటంటే, దీనికి ML నిపుణులు లేదా డేటా శాస్త్రవేత్తలచే చేతితో లేబులింగ్ అవసరం మరియు ప్రాసెస్ చేయడానికి అధిక ధర అవసరం. పర్యవేక్షించబడని అభ్యాసం దాని అనువర్తనాల కోసం పరిమిత స్పెక్ట్రమ్ను కూడా కలిగి ఉంది. పర్యవేక్షించబడే అభ్యాసం మరియు పర్యవేక్షించబడని అభ్యాస అల్గారిథమ్ల యొక్క ఈ లోపాలను అధిగమించడానికి, సెమీ-పర్యవేక్షించిన అభ్యాసం అనే భావన ప్రవేశపెట్టబడింది. సాధారణంగా, ఈ కలయిక చాలా తక్కువ మొత్తంలో లేబుల్ చేయబడిన డేటాను మరియు పెద్ద మొత్తంలో లేబుల్ చేయని డేటాను కలిగి ఉంటుంది. ఇందులో ఉన్న ప్రాథమిక విధానం ఏమిటంటే, ముందుగా, ప్రోగ్రామర్ పర్యవేక్షించబడని లెర్నింగ్ అల్గారిథమ్ని ఉపయోగించి సారూప్య డేటాను క్లస్టర్ చేస్తాడు మరియు లేబుల్ చేయని మిగిలిన డేటాను లేబుల్ చేయడానికి ఇప్పటికే లేబుల్ చేయబడిన డేటాను ఉపయోగిస్తాడు.
సెమీ-పర్వైజ్డ్ లెర్నింగ్ యొక్క ప్రాక్టికల్ అప్లికేషన్లు –
- స్పీచ్ అనాలిసిస్: ఆడియో ఫైల్లను లేబుల్ చేయడం చాలా ఇంటెన్సివ్ టాస్క్ కాబట్టి, ఈ సమస్యను పరిష్కరించడానికి సెమీ-పర్యవేజ్డ్ లెర్నింగ్ అనేది చాలా సహజమైన విధానం.
- ఇంటర్నెట్ కంటెంట్: వర్గీకరణ: ప్రతి వెబ్పేజీని లేబుల్ చేయడం అనేది అసాధ్యమైన మరియు అసాధ్యమైన ప్రక్రియ మరియు అందువలన సెమీ-పర్యవేక్షించబడిన అభ్యాస అల్గారిథమ్లను ఉపయోగిస్తుంది. Google శోధన అల్గారిథమ్ కూడా ఇచ్చిన ప్రశ్న కోసం వెబ్పేజీ యొక్క ఔచిత్యాన్ని ర్యాంక్ చేయడానికి సెమీ-పర్వైజ్డ్ లెర్నింగ్ యొక్క వేరియంట్ను ఉపయోగిస్తుంది.
- ప్రోటీన్ సీక్వెన్స్ వర్గీకరణ: DNA తంతువులు సాధారణంగా చాలా పెద్దవి కాబట్టి, సెమీ-పర్యవేక్షించిన అభ్యాసం ఈ రంగంలో ఆసన్నమైంది.
ఇది రివార్డ్ సిస్టమ్ను ఏర్పాటు చేయడం ద్వారా ఉత్తమ చర్య తీసుకోవడానికి ట్రయల్ మరియు ఎర్రర్ ద్వారా యంత్రాలకు శిక్షణ ఇస్తుంది. రీన్ఫోర్స్మెంట్ లెర్నింగ్ అనేది మెషీన్ సరైన నిర్ణయాలు తీసుకున్నప్పుడు చెప్పడం ద్వారా గేమ్లు ఆడేందుకు లేదా స్వయంప్రతిపత్త వాహనాలను నడపడానికి మోడల్లకు శిక్షణ ఇస్తుంది, ఇది ఏ చర్యలు తీసుకోవాలో కాలక్రమేణా తెలుసుకోవడానికి సహాయపడుతుంది.
రీన్ఫోర్స్మెంట్ లెర్నింగ్ యొక్క ప్రాక్టికల్ అప్లికేషన్లు -
- ఉత్పత్తి వ్యవస్థలు ఉదా Google Cloud AutoML, Facebook హారిజన్, సిఫార్సు, ప్రకటన, శోధన
- అటానమస్ డ్రైవింగ్
- వ్యాపార నిర్వహణ ఉదా వాహన రూటింగ్ సమస్యను పరిష్కరించడం, ఇ-కామర్స్లో మోసపూరిత ప్రవర్తన, కస్టమర్ పరస్పర చర్యల నుండి ఏకకాల ఉపబల అభ్యాసం
- సిఫార్సు వ్యవస్థలు ఉదా శోధన, సిఫార్సు మరియు ఆన్లైన్ ప్రకటనల కోసం
నేచురల్ లాంగ్వేజ్ ప్రాసెసింగ్ అనేది మెషీన్ లెర్నింగ్ యొక్క ఒక రంగం, దీనిలో కంప్యూటర్లను ప్రోగ్రామ్ చేయడానికి సాధారణంగా ఉపయోగించే డేటా మరియు నంబర్లకు బదులుగా మానవులు మాట్లాడే మరియు వ్రాసిన సహజ భాషను అర్థం చేసుకోవడానికి యంత్రాలు నేర్చుకుంటాయి. ఇది యంత్రాలు భాషను గుర్తించడానికి, అర్థం చేసుకోవడానికి మరియు దానికి ప్రతిస్పందించడానికి, అలాగే కొత్త వచనాన్ని సృష్టించడానికి మరియు భాషల మధ్య అనువదించడానికి అనుమతిస్తుంది. సహజ భాషా ప్రాసెసింగ్ చాట్బాట్ల వంటి సుపరిచితమైన సాంకేతికతను మరియు సిరి లేదా అలెక్సా వంటి డిజిటల్ సహాయకులను అనుమతిస్తుంది.
NLP యొక్క ప్రాక్టికల్ అప్లికేషన్లు:
- ప్రశ్న సమాధానం: మానవులు అడిగే ప్రశ్నలకు సహజమైన భాషలో స్వయంచాలకంగా సమాధానమిచ్చే వ్యవస్థలను నిర్మించడంపై ప్రశ్న సమాధానాలు దృష్టి సారిస్తాయి.
- స్పామ్ డిటెక్షన్: యూజర్ ఇన్బాక్స్కు వచ్చే అవాంఛిత ఇ-మెయిల్లను గుర్తించడానికి స్పామ్ డిటెక్షన్ ఉపయోగించబడుతుంది.
- సెంటిమెంట్ విశ్లేషణ: సెంటిమెంట్ విశ్లేషణను ఒపీనియన్ మైనింగ్ అని కూడా అంటారు. పంపినవారి వైఖరి, ప్రవర్తన మరియు భావోద్వేగ స్థితిని విశ్లేషించడానికి ఇది వెబ్లో ఉపయోగించబడుతుంది. ఈ అప్లికేషన్ NLP (నేచురల్ లాంగ్వేజ్ ప్రాసెసింగ్) మరియు గణాంకాల కలయిక ద్వారా టెక్స్ట్కు (పాజిటివ్, నెగటివ్, లేదా నేచురల్) విలువలను కేటాయించడం ద్వారా మరియు సందర్భం (సంతోషం, విచారం, కోపం మొదలైనవి) యొక్క మానసిక స్థితిని గుర్తించడం ద్వారా అమలు చేయబడుతుంది.
- యంత్ర అనువాదం: ఒక సహజ భాష నుండి మరొక సహజ భాషకు వచనం లేదా ప్రసంగాన్ని అనువదించడానికి యంత్ర అనువాదం ఉపయోగించబడుతుంది. ఉదా Google అనువాదం
- స్పెల్లింగ్ దిద్దుబాటు: మైక్రోసాఫ్ట్ కార్పొరేషన్ స్పెల్లింగ్ దిద్దుబాటు కోసం MS-word మరియు PowerPoint వంటి వర్డ్ ప్రాసెసర్ సాఫ్ట్వేర్ను అందిస్తుంది.
న్యూరల్ నెట్వర్క్లు సాధారణంగా ఉపయోగించే, నిర్దిష్ట తరగతి యంత్ర అభ్యాస అల్గారిథమ్లు. కృత్రిమ న్యూరల్ నెట్వర్క్లు మానవ మెదడుపై రూపొందించబడ్డాయి, దీనిలో వేల లేదా మిలియన్ల ప్రాసెసింగ్ నోడ్లు పరస్పరం అనుసంధానించబడి లేయర్లుగా నిర్వహించబడతాయి.
ఒక కృత్రిమ న్యూరల్ నెట్వర్క్లో, కణాలు లేదా నోడ్లు అనుసంధానించబడి ఉంటాయి, ప్రతి సెల్ ప్రాసెసింగ్ ఇన్పుట్లతో మరియు ఇతర న్యూరాన్లకు పంపబడే అవుట్పుట్ను ఉత్పత్తి చేస్తుంది. లేబుల్ చేయబడిన డేటా నోడ్లు లేదా సెల్ల ద్వారా కదులుతుంది, ప్రతి సెల్ వేరే ఫంక్షన్ను నిర్వహిస్తుంది. చిత్రంలో పిల్లి ఉందా లేదా అని గుర్తించడానికి శిక్షణ పొందిన న్యూరల్ నెట్వర్క్లో, వివిధ నోడ్లు సమాచారాన్ని అంచనా వేస్తాయి మరియు చిత్రంలో పిల్లి ఉందా లేదా అని సూచించే అవుట్పుట్కు చేరుకుంటుంది.
న్యూరల్ నెట్వర్క్ల ప్రాక్టికల్ అప్లికేషన్లు:
- స్టాక్ మార్కెట్ అంచనా: నిజ-సమయంలో విజయవంతమైన స్టాక్ ప్రిడిక్షన్ చేయడానికి, మల్టీలేయర్ పెర్సెప్ట్రాన్ MLP (క్లాస్ ఆఫ్ ఫీడ్ఫార్వర్డ్ ఆర్టిఫిషియల్ ఇంటెలిజెన్స్ అల్గారిథమ్) ఉపయోగించబడుతుంది. MLP నోడ్ల యొక్క బహుళ లేయర్లను కలిగి ఉంటుంది మరియు ఈ పొరల్లో ప్రతి ఒక్కటి తదుపరి నోడ్లకు పూర్తిగా అనుసంధానించబడి ఉంటుంది. MLP మోడల్ను రూపొందించడానికి స్టాక్ యొక్క గత ప్రదర్శనలు, వార్షిక రాబడి మరియు లాభాపేక్ష లేని నిష్పత్తులు పరిగణించబడతాయి.
- సోషల్ మీడియా: మల్టీ-లేయర్డ్ పర్సెప్ట్రాన్లు సోషల్ మీడియా ట్రెండ్లను అంచనా వేస్తాయి. ఇది మీన్ అబ్సొల్యూట్ ఎర్రర్ (MAE), రూట్ మీన్ స్క్వేర్డ్ ఎర్రర్ (RMSE) మరియు మీన్ స్క్వేర్డ్ ఎర్రర్ (MSE) వంటి విభిన్న శిక్షణా పద్ధతులను ఉపయోగిస్తుంది. MLP వినియోగదారుకు ఇష్టమైన ఇన్స్టాగ్రామ్ పేజీలు, బుక్మార్క్ ఎంపికలు మొదలైన అనేక అంశాలను పరిగణనలోకి తీసుకుంటుంది. సోషల్ మీడియా నెట్వర్క్ల ద్వారా వ్యక్తుల ప్రవర్తనలను విశ్లేషించిన తర్వాత, డేటాను వ్యక్తుల ఖర్చు అలవాట్లకు లింక్ చేయవచ్చు. MLP ANN సోషల్ మీడియా అప్లికేషన్ల నుండి డేటాను తీయడానికి ఉపయోగించబడుతుంది.
- ఏరోస్పేస్: ఏరోస్పేస్ ఇంజనీరింగ్ అనేది స్పేస్క్రాఫ్ట్ మరియు ఎయిర్క్రాఫ్ట్ల అభివృద్ధిని కవర్ చేసే విస్తారమైన పదం. తప్పు నిర్ధారణ, అధిక-పనితీరు గల ఆటో-పైలటింగ్, ఎయిర్క్రాఫ్ట్ కంట్రోల్ సిస్టమ్లను సురక్షితం చేయడం మరియు మోడలింగ్ కీ డైనమిక్ సిమ్యులేషన్లు న్యూరల్ నెట్వర్క్లు స్వాధీనం చేసుకున్న కొన్ని కీలక రంగాలు. సమయం ఆలస్యం నాన్-లీనియర్ టైమ్ డైనమిక్ సిస్టమ్లను మోడలింగ్ చేయడానికి న్యూరల్ నెట్వర్క్లను ఉపయోగించవచ్చు.
డీప్ లెర్నింగ్ నెట్వర్క్లు అనేక లేయర్లతో కూడిన న్యూరల్ నెట్వర్క్లు. లేయర్డ్ నెట్వర్క్ విస్తృతమైన డేటాను ప్రాసెస్ చేయగలదు మరియు నెట్వర్క్లోని ప్రతి లింక్ యొక్క "బరువు"ని నిర్ణయించగలదు - ఉదాహరణకు, ఇమేజ్ రికగ్నిషన్ సిస్టమ్లో, న్యూరల్ నెట్వర్క్లోని కొన్ని లేయర్లు కళ్ళు, ముక్కు వంటి ముఖం యొక్క వ్యక్తిగత లక్షణాలను గుర్తించవచ్చు. లేదా నోరు, మరొక పొర ఆ లక్షణాలు ముఖాన్ని సూచించే విధంగా కనిపిస్తాయో లేదో చెప్పగలదు.
డీప్ లెర్నింగ్ యొక్క ప్రాక్టికల్ అప్లికేషన్స్:
- ఆటోమేటిక్ టెక్స్ట్ జనరేషన్ - టెక్స్ట్ యొక్క కార్పస్ నేర్చుకుంటారు మరియు ఈ మోడల్ నుండి, కొత్త టెక్స్ట్ రూపొందించబడింది, పదం-పదం లేదా అక్షరం-వారీగా. అప్పుడు ఈ మోడల్ స్పెల్లింగ్, విరామచిహ్నాలు మరియు వాక్యాలను ఏర్పరచడం ఎలాగో నేర్చుకోగలదు, లేదా అది శైలిని కూడా సంగ్రహించవచ్చు.
- ఆరోగ్య సంరక్షణ – వివిధ వ్యాధులను గుర్తించడంలో మరియు వాటికి చికిత్స చేయడంలో సహాయపడుతుంది.
- ఆటోమేటిక్ మెషిన్ ట్రాన్స్లేషన్ – ఒక భాషలోని కొన్ని పదాలు, వాక్యాలు లేదా పదబంధాలు మరొక భాషలోకి రూపాంతరం చెందుతాయి (డీప్ లెర్నింగ్ అనేది టెక్స్ట్ మరియు ఇమేజ్ల రంగాలలో అత్యుత్తమ ఫలితాలను సాధించడం).
- ఇమేజ్ రికగ్నిషన్ - ఇమేజ్లలో వ్యక్తులను మరియు వస్తువులను గుర్తిస్తుంది మరియు గుర్తిస్తుంది అలాగే కంటెంట్ మరియు సందర్భాన్ని అర్థం చేసుకుంటుంది. ఈ ప్రాంతం ఇప్పటికే గేమింగ్, రిటైల్, టూరిజం మొదలైన వాటిలో ఉపయోగించబడుతోంది.
- భూకంపాలను అంచనా వేయడం – భూకంపాలను అంచనా వేయడంలో ఉపయోగించే విస్కోలాస్టిక్ గణనలను నిర్వహించడానికి కంప్యూటర్కు బోధిస్తుంది.
వెబ్ టెక్నాలజీ అనేది ఇంటర్నెట్లో వివిధ రకాల పరికరాల మధ్య కమ్యూనికేషన్ ప్రక్రియలో ఉపయోగించే వివిధ సాధనాలు మరియు సాంకేతికతలను సూచిస్తుంది. వెబ్ పేజీలను యాక్సెస్ చేయడానికి వెబ్ బ్రౌజర్ ఉపయోగించబడుతుంది. వెబ్ బ్రౌజర్లను ఇంటర్నెట్లో టెక్స్ట్, డేటా, చిత్రాలు, యానిమేషన్ మరియు వీడియోను ప్రదర్శించే ప్రోగ్రామ్లుగా నిర్వచించవచ్చు. వెబ్ బ్రౌజర్లు అందించిన సాఫ్ట్వేర్ ఇంటర్ఫేస్లను ఉపయోగించి వరల్డ్ వైడ్ వెబ్లోని హైపర్లింక్డ్ వనరులను యాక్సెస్ చేయవచ్చు.
- వరల్డ్ వైడ్ వెబ్ (WWW) వరల్డ్ వైడ్ వెబ్ అనేక విభిన్న సాంకేతికతలపై ఆధారపడి ఉంది: వెబ్ బ్రౌజర్లు, హైపర్టెక్స్ట్ మార్కప్ లాంగ్వేజ్ (HTML), మరియు హైపర్టెక్స్ట్ ట్రాన్స్ఫర్ ప్రోటోకాల్ (HTTP).
- వెబ్ బ్రౌజర్ వెబ్ బ్రౌజర్ www (వరల్డ్ వైడ్ వెబ్) అన్వేషించడానికి ఒక అప్లికేషన్ సాఫ్ట్వేర్. ఇది సర్వర్ మరియు క్లయింట్ మధ్య ఇంటర్ఫేస్ను అందిస్తుంది మరియు వెబ్ పత్రాలు మరియు సేవల కోసం సర్వర్కు అభ్యర్థనలను అందిస్తుంది.
- వెబ్ సర్వర్ వెబ్ సర్వర్ అనేది వినియోగదారుల యొక్క నెట్వర్క్ అభ్యర్థనలను ప్రాసెస్ చేసే మరియు వెబ్ పేజీలను సృష్టించే ఫైల్లతో వారికి అందించే ప్రోగ్రామ్. ఈ మార్పిడి హైపర్టెక్స్ట్ ట్రాన్స్ఫర్ ప్రోటోకాల్ (HTTP)ని ఉపయోగించి జరుగుతుంది.
- వెబ్ పేజీలు వెబ్పేజీ అనేది వరల్డ్ వైడ్ వెబ్కి లింక్ చేయబడిన డిజిటల్ డాక్యుమెంట్ మరియు వెబ్ బ్రౌజర్ని కలిగి ఉన్న ఇంటర్నెట్కి కనెక్ట్ చేయబడిన ఎవరైనా వీక్షించవచ్చు.
- వెబ్ అభివృద్ధి వెబ్ అభివృద్ధి అనేది వెబ్సైట్లను నిర్మించడం, సృష్టించడం మరియు నిర్వహించడం సూచిస్తుంది. ఇది వెబ్ డిజైన్, వెబ్ పబ్లిషింగ్, వెబ్ ప్రోగ్రామింగ్ మరియు డేటాబేస్ మేనేజ్మెంట్ వంటి అంశాలను కలిగి ఉంటుంది. ఇది ఇంటర్నెట్లో పని చేసే అప్లికేషన్ యొక్క సృష్టి, అంటే వెబ్సైట్లు.
వినియోగదారు నేరుగా పరస్పర చర్య చేసే వెబ్సైట్ భాగాన్ని ఫ్రంట్ ఎండ్ అంటారు. ఇది అప్లికేషన్ యొక్క 'క్లయింట్ వైపు' అని కూడా సూచించబడుతుంది.
బ్యాకెండ్ అనేది వెబ్సైట్ యొక్క సర్వర్ వైపు. ఇది వెబ్సైట్లో భాగం, వినియోగదారులు చూడలేరు మరియు పరస్పర చర్య చేయలేరు. ఇది వినియోగదారులతో ప్రత్యక్ష సంబంధంలోకి రాని సాఫ్ట్వేర్ భాగం. ఇది డేటాను నిల్వ చేయడానికి మరియు అమర్చడానికి ఉపయోగించబడుతుంది.
కంప్యూటర్ నెట్వర్క్ అనేది నెట్వర్క్ నోడ్లలో ఉన్న లేదా అందించబడిన వనరులను పంచుకునే కంప్యూటర్ల సమితి. కంప్యూటర్లు ఒకదానితో ఒకటి కమ్యూనికేట్ చేయడానికి డిజిటల్ ఇంటర్కనెక్షన్లపై సాధారణ కమ్యూనికేషన్ ప్రోటోకాల్లను ఉపయోగిస్తాయి. ఈ ఇంటర్కనెక్షన్లు భౌతికంగా వైర్డు, ఆప్టికల్ మరియు వైర్లెస్ రేడియో-ఫ్రీక్వెన్సీ పద్ధతులపై ఆధారపడిన టెలికమ్యూనికేషన్ నెట్వర్క్ సాంకేతికతలతో రూపొందించబడ్డాయి, వీటిని వివిధ రకాల నెట్వర్క్ టోపోలాజీలలో అమర్చవచ్చు.
కంప్యూటర్ నెట్వర్క్ యొక్క నోడ్లు వ్యక్తిగత కంప్యూటర్లు, సర్వర్లు, నెట్వర్కింగ్ హార్డ్వేర్ లేదా ఇతర ప్రత్యేక లేదా సాధారణ-ప్రయోజన హోస్ట్లను కలిగి ఉంటాయి. అవి నెట్వర్క్ చిరునామాల ద్వారా గుర్తించబడతాయి మరియు హోస్ట్ పేర్లను కలిగి ఉండవచ్చు. హోస్ట్ పేర్లు నోడ్లకు గుర్తుండిపోయే లేబుల్లుగా ఉపయోగపడతాయి, ప్రారంభ అసైన్మెంట్ తర్వాత చాలా అరుదుగా మార్చబడతాయి. ఇంటర్నెట్ ప్రోటోకాల్ వంటి కమ్యూనికేషన్ ప్రోటోకాల్ల ద్వారా నోడ్లను గుర్తించడం మరియు గుర్తించడం కోసం నెట్వర్క్ చిరునామాలు ఉపయోగపడతాయి.
సిగ్నల్స్, బ్యాండ్విడ్త్, నెట్వర్క్ ట్రాఫిక్ను నిర్వహించడానికి కమ్యూనికేషన్ ప్రోటోకాల్లు, నెట్వర్క్ పరిమాణం, టోపోలాజీ, ట్రాఫిక్ కంట్రోల్ మెకానిజం మరియు సంస్థాగత ఉద్దేశం వంటి వాటిని తీసుకువెళ్లడానికి ఉపయోగించే ప్రసార మాధ్యమంతో సహా కంప్యూటర్ నెట్వర్క్లను అనేక ప్రమాణాల ద్వారా వర్గీకరించవచ్చు.
కంప్యూటర్ నెట్వర్కింగ్లో రెండు ప్రాథమిక రకాలు ఉన్నాయి:
- వైర్డ్ నెట్వర్కింగ్: వైర్డ్ నెట్వర్కింగ్కు నోడ్ల మధ్య రవాణా కోసం భౌతిక మాధ్యమాన్ని ఉపయోగించడం అవసరం. రాగి-ఆధారిత ఈథర్నెట్ కేబులింగ్, తక్కువ ధర మరియు మన్నిక కారణంగా ప్రజాదరణ పొందింది, సాధారణంగా వ్యాపారాలు మరియు గృహాలలో డిజిటల్ కమ్యూనికేషన్ల కోసం ఉపయోగించబడుతుంది. ప్రత్యామ్నాయంగా, ఆప్టికల్ ఫైబర్ ఎక్కువ దూరాలకు మరియు వేగవంతమైన వేగంతో డేటాను రవాణా చేయడానికి ఉపయోగించబడుతుంది, అయితే ఇది అధిక ఖర్చులు మరియు మరింత పెళుసుగా ఉండే భాగాలతో సహా అనేక లావాదేవీలను కలిగి ఉంది.
- వైర్లెస్ నెట్వర్కింగ్: వైర్లెస్ నెట్వర్కింగ్ రేడియో తరంగాలను గాలిలో డేటాను రవాణా చేయడానికి ఉపయోగిస్తుంది, పరికరాలను ఎలాంటి కేబులింగ్ లేకుండా నెట్వర్క్కి కనెక్ట్ చేయడానికి వీలు కల్పిస్తుంది. వైర్లెస్ LANలు వైర్లెస్ నెట్వర్కింగ్ యొక్క అత్యంత ప్రసిద్ధ మరియు విస్తృతంగా అమలు చేయబడిన రూపం. ప్రత్యామ్నాయాలలో మైక్రోవేవ్, శాటిలైట్, సెల్యులార్ మరియు బ్లూటూత్ ఉన్నాయి.
OSI అంటే ఓపెన్ సిస్టమ్స్ ఇంటర్కనెక్షన్. ఇది ISO – ‘ఇంటర్నేషనల్ ఆర్గనైజేషన్ ఫర్ స్టాండర్డైజేషన్’ సంవత్సరంలో 1984లో అభివృద్ధి చేయబడింది. ఇది 7-లేయర్ ఆర్కిటెక్చర్, ప్రతి లేయర్ నిర్దిష్ట కార్యాచరణను కలిగి ఉంటుంది. ప్రపంచవ్యాప్తంగా ఒక వ్యక్తి నుండి మరొకరికి డేటాను ప్రసారం చేయడానికి ఈ ఏడు పొరలన్నీ కలిసి పనిచేస్తాయి.
OSI రిఫరెన్స్ మోడల్ యొక్క అత్యల్ప పొర భౌతిక పొర. పరికరాల మధ్య వాస్తవ భౌతిక కనెక్షన్కు ఇది బాధ్యత వహిస్తుంది. భౌతిక పొర ** బిట్ల రూపంలో సమాచారాన్ని కలిగి ఉంటుంది.** ఇది ఒక నోడ్ నుండి మరొక నోడ్కు వ్యక్తిగత బిట్లను ప్రసారం చేయడానికి బాధ్యత వహిస్తుంది. డేటాను స్వీకరించేటప్పుడు, ఈ లేయర్ అందుకున్న సిగ్నల్ను పొందుతుంది మరియు దానిని 0సె మరియు 1లకి మారుస్తుంది మరియు వాటిని డేటా లింక్ లేయర్కి పంపుతుంది, ఇది ఫ్రేమ్ను తిరిగి కలిపి ఉంచుతుంది.
భౌతిక పొర యొక్క విధులు క్రింది విధంగా ఉన్నాయి:
- బిట్ సింక్రొనైజేషన్: ఫిజికల్ లేయర్ గడియారాన్ని అందించడం ద్వారా బిట్ల సమకాలీకరణను అందిస్తుంది. ఈ గడియారం పంపినవారు మరియు రిసీవర్ రెండింటినీ నియంత్రిస్తుంది, తద్వారా బిట్ స్థాయిలో సమకాలీకరణను అందిస్తుంది.
- బిట్ రేట్ నియంత్రణ: ఫిజికల్ లేయర్ ట్రాన్స్మిషన్ రేట్ను కూడా నిర్వచిస్తుంది, అనగా సెకనుకు పంపిన బిట్ల సంఖ్య.
- ఫిజికల్ టోపోలాజీలు: ఫిజికల్ లేయర్ నెట్వర్క్లో వివిధ పరికరాలు/నోడ్లు ఎలా అమర్చబడిందో పేర్కొంటుంది, అనగా బస్, స్టార్ లేదా మెష్ టోపోలాజీ.
- ట్రాన్స్మిషన్ మోడ్: కనెక్ట్ చేయబడిన రెండు పరికరాల మధ్య డేటా ఎలా ప్రవహిస్తుందో కూడా ఫిజికల్ లేయర్ నిర్వచిస్తుంది. సాధ్యమయ్యే వివిధ ప్రసార మోడ్లు సింప్లెక్స్, హాఫ్-డ్యూప్లెక్స్ మరియు ఫుల్-డి
సందేశం యొక్క నోడ్-టు-నోడ్ డెలివరీకి డేటా లింక్ లేయర్ బాధ్యత వహిస్తుంది. ఫిజికల్ లేయర్పై ఒక నోడ్ నుండి మరొక నోడ్కి డేటా బదిలీ లోపం లేకుండా ఉండేలా చూసుకోవడం ఈ లేయర్ యొక్క ప్రధాన విధి. నెట్వర్క్లో ప్యాకెట్ వచ్చినప్పుడు, దాని MAC చిరునామాను ఉపయోగించి దానిని హోస్ట్కు ప్రసారం చేయడం DLL యొక్క బాధ్యత. డేటా లింక్ లేయర్ రెండు సబ్లేయర్లుగా విభజించబడింది:
- లాజికల్ లింక్ కంట్రోల్ (LLC)
- మీడియా యాక్సెస్ కంట్రోల్ (MAC)
NIC(నెట్వర్క్ ఇంటర్ఫేస్ కార్డ్) యొక్క ఫ్రేమ్ పరిమాణంపై ఆధారపడి నెట్వర్క్ లేయర్ నుండి అందుకున్న ప్యాకెట్ మరింత ఫ్రేమ్లుగా విభజించబడింది. DLL హెడర్లో పంపినవారు మరియు స్వీకర్త యొక్క MAC చిరునామాను కూడా కలుపుతుంది.
"ఆ IP చిరునామా ఎవరి వద్ద ఉంది?" అని అడిగే వైర్పై ARP (అడ్రస్ రిజల్యూషన్ ప్రోటోకాల్) అభ్యర్థనను ఉంచడం ద్వారా స్వీకర్త యొక్క MAC చిరునామా పొందబడుతుంది. మరియు గమ్యస్థాన హోస్ట్ దాని MAC చిరునామాతో ప్రత్యుత్తరం ఇస్తుంది.
డేటా లింక్ లేయర్ యొక్క విధులు:
- ఫ్రేమింగ్: ఫ్రేమింగ్ అనేది డేటా లింక్ లేయర్ యొక్క ఫంక్షన్. ఇది రిసీవర్కు అర్థవంతమైన బిట్ల సెట్ను పంపడానికి పంపినవారికి ఒక మార్గాన్ని అందిస్తుంది. ఫ్రేమ్ యొక్క ప్రారంభం మరియు ముగింపుకు ప్రత్యేక బిట్ నమూనాలను జోడించడం ద్వారా దీనిని సాధించవచ్చు.
- ఫిజికల్ అడ్రసింగ్: ఫ్రేమ్లను సృష్టించిన తర్వాత, డేటా లింక్ లేయర్ ప్రతి ఫ్రేమ్ యొక్క హెడర్లో పంపినవారు మరియు/లేదా రిసీవర్ యొక్క భౌతిక చిరునామాలను (MAC చిరునామాలు) జోడిస్తుంది.
- ఎర్రర్ కంట్రోల్: డేటా లింక్ లేయర్ ఎర్రర్ కంట్రోల్ మెకానిజంను అందిస్తుంది, దీనిలో దెబ్బతిన్న లేదా కోల్పోయిన ఫ్రేమ్లను గుర్తించి తిరిగి ప్రసారం చేస్తుంది.
- ఫ్లో కంట్రోల్: డేటా రేటు రెండు వైపులా స్థిరంగా ఉండాలి లేదా డేటా పాడైపోవచ్చు; అందువల్ల, ప్రవాహ నియంత్రణ రసీదుని స్వీకరించడానికి ముందు పంపగల డేటా మొత్తాన్ని సమన్వయపరుస్తుంది.
- యాక్సెస్ నియంత్రణ: ఒకే కమ్యూనికేషన్ ఛానెల్ని బహుళ పరికరాల ద్వారా భాగస్వామ్యం చేసినప్పుడు, డేటా లింక్ లేయర్ యొక్క MAC ఉప-లేయర్ నిర్దిష్ట సమయంలో ఛానెల్పై ఏ పరికరం నియంత్రణను కలిగి ఉందో గుర్తించడంలో సహాయపడుతుంది.
నెట్వర్క్ లేయర్ వివిధ నెట్వర్క్లలో ఉన్న ఒక హోస్ట్ నుండి మరొకదానికి డేటాను ప్రసారం చేయడానికి పనిచేస్తుంది. ఇది ప్యాకెట్ రూటింగ్ను కూడా చూసుకుంటుంది, అనగా, అందుబాటులో ఉన్న మార్గాల సంఖ్య నుండి ప్యాకెట్ను ప్రసారం చేయడానికి అతి తక్కువ మార్గం ఎంపిక. పంపినవారు & రిసీవర్ యొక్క IP చిరునామాలు నెట్వర్క్ లేయర్ ద్వారా హెడర్లో ఉంచబడతాయి.
నెట్వర్క్ లేయర్ యొక్క విధులు:
- రూటింగ్: నెట్వర్క్ లేయర్ ప్రోటోకాల్లు సోర్స్ నుండి గమ్యస్థానానికి ఏ మార్గాన్ని అనుకూలంగా ఉందో నిర్ణయిస్తాయి. నెట్వర్క్ లేయర్ యొక్క ఈ ఫంక్షన్ను రౌటింగ్ అంటారు.
- లాజికల్ అడ్రసింగ్: ఇంటర్నెట్వర్క్లోని ప్రతి పరికరాన్ని ప్రత్యేకంగా గుర్తించడానికి, నెట్వర్క్ లేయర్ అడ్రసింగ్ స్కీమ్ను నిర్వచిస్తుంది. పంపినవారు & రిసీవర్ యొక్క IP చిరునామాలు నెట్వర్క్ లేయర్ ద్వారా హెడర్లో ఉంచబడతాయి. అటువంటి చిరునామా ప్రతి పరికరాన్ని ప్రత్యేకంగా మరియు విశ్వవ్యాప్తంగా వేరు చేస్తుంది.
ఇంటర్నెట్ అనేది ప్రపంచవ్యాప్తంగా బిలియన్ల కొద్దీ వినియోగదారులకు సేవలందించేందుకు ప్రామాణిక ఇంటర్నెట్ ప్రోటోకాల్ సూట్ (TCP/IPని ఉపయోగించే ఇంటర్కనెక్టడ్ కంప్యూటర్ నెట్వర్క్ల యొక్క గ్లోబల్ సిస్టమ్. ఇది ఎలక్ట్రానిక్, వైర్లెస్ మరియు ఆప్టికల్ నెట్వర్కింగ్ టెక్నాలజీల విస్తృత శ్రేణితో అనుసంధానించబడిన స్థానిక నుండి ప్రపంచ పరిధికి సంబంధించిన మిలియన్ల కొద్దీ ప్రైవేట్, పబ్లిక్, అకడమిక్, బిజినెస్ మరియు ప్రభుత్వ నెట్వర్క్లను కలిగి ఉన్న నెట్వర్క్ల నెట్వర్క్. ఇంటర్లింక్ చేయబడిన హైపర్టెక్స్ట్ డాక్యుమెంట్లు మరియు వరల్డ్ వైడ్ వెబ్ (WWW) మరియు మద్దతిచ్చే మౌలిక సదుపాయాల వంటి విస్తృతమైన సమాచార వనరులు మరియు సేవలను ఇంటర్నెట్ అందిస్తుంది. ఇమెయిల్.
వరల్డ్ వైడ్ వెబ్ (WWW) అనేది ఒక సమాచార స్థలం, దీనిలో పత్రాలు మరియు ఇతర వెబ్ వనరులు యూనిఫాం రిసోర్స్ లొకేటర్స్ (URLలు) ద్వారా గుర్తించబడతాయి, హైపర్టెక్స్ట్ లింక్ల ద్వారా ఇంటర్లింక్ చేయబడతాయి మరియు ఇంటర్నెట్ ద్వారా యాక్సెస్ చేయబడతాయి. ఆంగ్ల శాస్త్రవేత్త టిమ్ బెర్నర్స్-లీ 1989లో వరల్డ్ వైడ్ వెబ్ను కనుగొన్నారు. అతను 1990లో స్విట్జర్లాండ్లోని CERNలో ఉద్యోగం చేస్తున్నప్పుడు మొదటి వెబ్ బ్రౌజర్ను రాశాడు. బ్రౌజర్ 1991లో CERN వెలుపల విడుదల చేయబడింది, మొదట జనవరి 1991 నుండి ఇతర పరిశోధనా సంస్థలకు మరియు ఆగస్టు 1991లో ఇంటర్నెట్లో సాధారణ ప్రజలకు అందించబడింది.
ఇంటర్నెట్ ప్రోటోకాల్ (IP) అనేది డేటా ప్యాకెట్లను రూటింగ్ చేయడానికి మరియు అడ్రస్ చేయడానికి ప్రోటోకాల్ లేదా నియమాల సమితి, తద్వారా అవి నెట్వర్క్లలో ప్రయాణించి సరైన గమ్యాన్ని చేరుకోగలవు. ఇంటర్నెట్లో ప్రయాణించే డేటా ప్యాకెట్లు అని పిలువబడే చిన్న ముక్కలుగా విభజించబడింది.
డేటాబేస్ అనేది వాస్తవ ప్రపంచంలోని కొన్ని అంశాలను సూచించే సంబంధిత డేటా యొక్క సమాహారం. ఒక డేటాబేస్ సిస్టమ్ ఒక నిర్దిష్ట పని కోసం డేటాతో నిర్మించబడటానికి మరియు జనాభాతో రూపొందించబడింది.
డేటాబేస్ మేనేజ్మెంట్ సిస్టమ్ (DBMS) అనేది తగిన భద్రతా చర్యలను పరిగణనలోకి తీసుకుంటూ వినియోగదారుల డేటాను నిల్వ చేయడానికి మరియు తిరిగి పొందడానికి సాఫ్ట్వేర్. ఇది డేటాబేస్ను మార్చే ప్రోగ్రామ్ల సమూహాన్ని కలిగి ఉంటుంది. DBMS అప్లికేషన్ నుండి డేటా కోసం అభ్యర్థనను అంగీకరిస్తుంది మరియు నిర్దిష్ట డేటాను అందించమని ఆపరేటింగ్ సిస్టమ్కు నిర్దేశిస్తుంది. పెద్ద సిస్టమ్లలో, DBMS వినియోగదారులు మరియు ఇతర మూడవ పక్ష సాఫ్ట్వేర్ డేటాను నిల్వ చేయడం మరియు తిరిగి పొందడంలో సహాయపడుతుంది.
DBMS వినియోగదారులు వారి అవసరాలకు అనుగుణంగా వారి డేటాబేస్లను సృష్టించడానికి అనుమతిస్తుంది. "DBMS" అనే పదం డేటాబేస్ మరియు ఇతర అప్లికేషన్ ప్రోగ్రామ్ల వినియోగాన్ని కలిగి ఉంటుంది. ఇది డేటా మరియు సాఫ్ట్వేర్ అప్లికేషన్ మధ్య ఇంటర్ఫేస్ను అందిస్తుంది.
విశ్వవిద్యాలయ డేటాబేస్ యొక్క సాధారణ ఉదాహరణను చూద్దాం. ఈ డేటాబేస్ విశ్వవిద్యాలయ వాతావరణంలో విద్యార్థులు, కోర్సులు మరియు గ్రేడ్లకు సంబంధించిన సమాచారాన్ని నిర్వహిస్తుంది. డేటాబేస్ ఐదు ఫైల్లుగా నిర్వహించబడింది:
- STUDENT ఫైల్ ప్రతి విద్యార్థి డేటాను నిల్వ చేస్తుంది
- COURSE ఫైల్ స్టోర్లు ప్రతి కోర్సులో డేటాను కలిగి ఉంటాయి.
- సెక్షన్ నిర్దిష్ట కోర్సులోని విభాగాల గురించి సమాచారాన్ని నిల్వ చేస్తుంది.
- GRADE ఫైల్ వివిధ విభాగాలలో విద్యార్థులు పొందే గ్రేడ్లను నిల్వ చేస్తుంది
- TUTOR ఫైల్లో ప్రతి ప్రొఫెసర్ గురించిన సమాచారం ఉంటుంది.
DBMSని నిర్వచించడానికి:
- ప్రతి రికార్డ్లో నిల్వ చేయబడే వివిధ రకాల డేటా ఎలిమెంట్లను నిర్వచించడం ద్వారా మేము ప్రతి ఫైల్ యొక్క రికార్డ్ల నిర్మాణాన్ని పేర్కొనాలి.
- మేము డేటా అంశం విలువలను సూచించడానికి కోడింగ్ స్కీమ్ను కూడా ఉపయోగించవచ్చు.
- ప్రాథమికంగా, మీ డేటాబేస్ వివిధ పట్టికలలో నిర్వచించబడిన విదేశీ కీతో ఐదు పట్టికలను కలిగి ఉంటుంది.
చరిత్ర నుండి ముఖ్యమైన మైలురాళ్లు ఇక్కడ ఉన్నాయి:
- 1960 – చార్లెస్ బాచ్మన్ మొదటి DBMS వ్యవస్థను రూపొందించారు
- 1970 – కాడ్ IBM'S ఇన్ఫర్మేషన్ మేనేజ్మెంట్ సిస్టమ్ (IMS)ని ప్రవేశపెట్టాడు
- 1976- పీటర్ చెన్ ఎంటిటీ-రిలేషన్షిప్ మోడల్ను రూపొందించారు మరియు నిర్వచించారు, దీనిని ER మోడల్ అని కూడా పిలుస్తారు.
- 1980 – రిలేషనల్ మోడల్ విస్తృతంగా ఆమోదించబడిన డేటాబేస్ భాగం
- 1985- ఆబ్జెక్ట్-ఓరియెంటెడ్ DBMS అభివృద్ధి చేయబడింది.
- 1990లు- రిలేషనల్ DBMSలో ఆబ్జెక్ట్ ఓరియంటేషన్ను చేర్చడం.
- 1991- మైక్రోసాఫ్ట్ MS యాక్సెస్ను రవాణా చేస్తుంది, ఇది అన్ని ఇతర వ్యక్తిగత DBMS ఉత్పత్తులను స్థానభ్రంశం చేసే వ్యక్తిగత DBMS.
- 1995: మొదటి ఇంటర్నెట్ డేటాబేస్ అప్లికేషన్స్
- 1997: డేటాబేస్ ప్రాసెసింగ్కు XML వర్తింపజేయబడింది. చాలా మంది విక్రేతలు XMLని DBMS ఉత్పత్తుల్లోకి చేర్చడం ప్రారంభించారు.
డేటాబేస్ మేనేజ్మెంట్ సిస్టమ్ యొక్క లక్షణాలు మరియు లక్షణాలు ఇక్కడ ఉన్నాయి:
- భద్రతను అందిస్తుంది మరియు రిడెండెన్సీని తొలగిస్తుంది
- డేటాబేస్ సిస్టమ్ స్వభావాన్ని స్వయంగా వివరించడం
- ప్రోగ్రామ్లు మరియు డేటా సంగ్రహణ మధ్య ఇన్సులేషన్
- డేటా యొక్క బహుళ వీక్షణల మద్దతు
- డేటా భాగస్వామ్యం మరియు బహుళ-వినియోగదారు లావాదేవీల ప్రాసెసింగ్
- డేటాబేస్ మేనేజ్మెంట్ సాఫ్ట్వేర్ పట్టికలను రూపొందించడానికి ఎంటిటీలు మరియు వాటి మధ్య సంబంధాలను అనుమతిస్తుంది.
- ఇది ACID కాన్సెప్ట్ను అనుసరిస్తుంది (అటామిసిటీ, కన్సిస్టెన్సీ, ఐసోలేషన్ మరియు డ్యూరబిలిటీ).
- DBMS బహుళ-వినియోగదారు వాతావరణానికి మద్దతు ఇస్తుంది, ఇది వినియోగదారులు డేటాను సమాంతరంగా యాక్సెస్ చేయడానికి మరియు మార్చడానికి అనుమతిస్తుంది.
ఇక్కడ కొన్ని ప్రసిద్ధ DBMS సిస్టమ్ల జాబితా ఉంది:
- MySQL
- మైక్రోసాఫ్ట్ యాక్సెస్
- ఒరాకిల్
- PostgreSQL
- dBASE
- ఫాక్స్ప్రో
- SQLite
- IBM DB2
- లిబ్రే ఆఫీస్ బేస్
- మరియాడిబి
- Microsoft SQL సర్వర్ మొదలైనవి.
క్రిప్టోగ్రఫీ అనేది డేటా మరియు కమ్యూనికేషన్ను భద్రపరచడానికి ఒక సాంకేతికత. ఇది కోడ్లను ఉపయోగించడం ద్వారా సమాచారాన్ని మరియు కమ్యూనికేషన్లను రక్షించే పద్ధతి, తద్వారా సమాచారాన్ని ఉద్దేశించిన వారు మాత్రమే చదవగలరు మరియు ప్రాసెస్ చేయగలరు. క్రిప్టోగ్రఫీ రవాణాలో, విశ్రాంతి సమయంలో మరియు ఉపయోగంలో ఉన్న డేటాను రక్షించడానికి ఉపయోగించబడుతుంది. ఉపసర్గ crypt అంటే "దాచిన" లేదా "రహస్యం", మరియు ప్రత్యయం graphy అంటే "వ్రాయడం".
గూఢ లిపి శాస్త్రంలో రెండు రకాలు ఉన్నాయి:
క్రిప్టోకరెన్సీ అనేది డిజిటల్ కరెన్సీ, దీనిలో కరెన్సీ యూనిట్ల ఉత్పత్తిని నియంత్రించడానికి మరియు నిధుల బదిలీని ధృవీకరించడానికి ఎన్క్రిప్షన్ పద్ధతులు ఉపయోగించబడతాయి, ఇది సెంట్రల్ బ్యాంక్ నుండి స్వతంత్రంగా పనిచేస్తుంది. క్రిప్టోకరెన్సీలు కేంద్రీకృత డిజిటల్ కరెన్సీ మరియు సెంట్రల్ బ్యాంకింగ్ వ్యవస్థలకు విరుద్ధంగా వికేంద్రీకృత నియంత్రణను ఉపయోగిస్తాయి. ప్రతి క్రిప్టోకరెన్సీ యొక్క వికేంద్రీకృత నియంత్రణ పంపిణీ చేయబడిన లెడ్జర్ టెక్నాలజీ ద్వారా పనిచేస్తుంది, సాధారణంగా బ్లాక్చెయిన్, ఇది పబ్లిక్ ఫైనాన్షియల్ లావాదేవీల డేటాబేస్గా పనిచేస్తుంది. క్రిప్టోకరెన్సీ యొక్క నిర్వచించే లక్షణం, మరియు నిస్సందేహంగా దాని అత్యంత మనోహరమైన ఆకర్షణ, దాని సేంద్రీయ స్వభావం; ఇది ఏ కేంద్ర అధికారంచే జారీ చేయబడదు, ఇది ప్రభుత్వ జోక్యం లేదా అవకతవకలకు సిద్ధాంతపరంగా రోగనిరోధక శక్తిని అందిస్తుంది.
- [పని యొక్క రుజువు](క్రిప్టోగ్రఫీ/క్రిప్టోకరెన్సీ/ప్రూఫ్ఆఫ్వర్క్/రీడ్మే.ఎమ్డి#పని యొక్క ప్రూఫ్)
- ప్రూఫ్ ఆఫ్ స్టేక్
సైద్ధాంతిక కంప్యూటర్ సైన్స్ మరియు గణిత శాస్త్రంలో, గణన సిద్ధాంతం అనేది ఒక అల్గారిథమ్ని ఉపయోగించి గణన నమూనాలో ఏ సమస్యలను పరిష్కరించవచ్చు, వాటిని ఎంత సమర్థవంతంగా పరిష్కరించవచ్చు లేదా ఏ స్థాయిలో (ఉదా., ఖచ్చితమైన పరిష్కారాలు మరియు ఖచ్చితమైన పరిష్కారాలు) అనే వాటితో వ్యవహరించే శాఖ. ) ఫీల్డ్ మూడు ప్రధాన శాఖలుగా విభజించబడింది: ఆటోమేటా సిద్ధాంతం మరియు అధికారిక భాషలు, కంప్యూటబిలిటీ సిద్ధాంతం మరియు గణన సంక్లిష్టత సిద్ధాంతం, ఇవి ప్రశ్నతో అనుసంధానించబడ్డాయి: "కంప్యూటర్ల ప్రాథమిక సామర్థ్యాలు మరియు పరిమితులు ఏమిటి?".
ఆటోమేటా సిద్ధాంతం అనేది నైరూప్య యంత్రాలు మరియు ఆటోమాటా, అలాగే వాటిని ఉపయోగించి పరిష్కరించగల గణన సమస్యలను అధ్యయనం చేస్తుంది. ఇది సైద్ధాంతిక కంప్యూటర్ సైన్స్లో ఒక సిద్ధాంతం. ఆటోమాటా అనే పదం గ్రీకు పదం αὐτόματος నుండి వచ్చింది, దీని అర్థం "స్వీయ-నటన, స్వీయ-సంకల్పం, స్వీయ-కదిలే". ఆటోమేటన్ (బహువచనంలో ఆటోమాటా) అనేది ఒక వియుక్త స్వీయ-చోదక కంప్యూటింగ్ పరికరం, ఇది స్వయంచాలకంగా ముందుగా నిర్ణయించిన కార్యకలాపాల క్రమాన్ని అనుసరిస్తుంది. పరిమిత సంఖ్యలో రాష్ట్రాలతో కూడిన ఆటోమేటన్ని ఫినైట్ ఆటోమేటన్ (FA) లేదా ఫినైట్-స్టేట్ మెషిన్ (FSM) అంటారు. కుడివైపున ఉన్న బొమ్మ పరిమిత-స్థితి యంత్రాన్ని వివరిస్తుంది, ఇది ఆటోమేటన్ యొక్క ప్రసిద్ధ రకం. ఈ ఆటోమేటన్ స్టేట్లను (ఫిగర్లో సర్కిల్ల ద్వారా సూచించబడుతుంది) మరియు పరివర్తనాలు (బాణాల ద్వారా సూచించబడుతుంది) కలిగి ఉంటుంది. ఆటోమేటన్ ఇన్పుట్ యొక్క చిహ్నాన్ని చూసినప్పుడు, దాని పరివర్తన ఫంక్షన్ ప్రకారం, ఇది మరొక స్థితికి పరివర్తన (లేదా జంప్) చేస్తుంది, ఇది మునుపటి స్థితి మరియు ప్రస్తుత ఇన్పుట్ చిహ్నాన్ని దాని వాదనలుగా తీసుకుంటుంది.
తర్కం, గణితం, కంప్యూటర్ సైన్స్ మరియు భాషాశాస్త్రంలో, ఒక అధికారిక భాషలో అక్షరాలు వర్ణమాల నుండి తీసుకోబడిన పదాలను కలిగి ఉంటాయి మరియు నిర్దిష్ట నియమాల ప్రకారం బాగా రూపొందించబడ్డాయి.
అధికారిక భాష యొక్క వర్ణమాల చిహ్నాలు, అక్షరాలు లేదా టోకెన్లను కలిగి ఉంటుంది, ఇవి భాష యొక్క తీగలను కలిగి ఉంటాయి.[1] ఈ వర్ణమాల యొక్క చిహ్నాల నుండి సంగ్రహించబడిన ప్రతి స్ట్రింగ్ను ఒక పదం అని పిలుస్తారు మరియు నిర్దిష్ట అధికారిక భాషకు చెందిన పదాలను కొన్నిసార్లు బాగా రూపొందించిన పదాలు లేదా బాగా రూపొందించిన సూత్రాలు అని పిలుస్తారు. ఒక అధికారిక భాష తరచుగా అధికారిక వ్యాకరణాన్ని ఉపయోగించి నిర్వచించబడుతుంది, సాధారణ వ్యాకరణం లేదా సందర్భం-రహిత వ్యాకరణం, దాని నిర్మాణ నియమాలను కలిగి ఉంటుంది.
కంప్యూటర్ సైన్స్లో, లాంఛనప్రాయ భాషలను ప్రోగ్రామింగ్ భాషల వ్యాకరణాన్ని మరియు సహజ భాషల ఉపసమితుల యొక్క అధికారిక సంస్కరణలను నిర్వచించడానికి ప్రాతిపదికగా ఉపయోగిస్తారు, దీనిలో భాష యొక్క పదాలు నిర్దిష్ట అర్థాలు లేదా సెమాంటిక్స్తో అనుబంధించబడిన భావనలను సూచిస్తాయి. గణన సంక్లిష్టత సిద్ధాంతంలో, నిర్ణయ సమస్యలు సాధారణంగా అధికారిక భాషలుగా నిర్వచించబడతాయి మరియు సంక్లిష్టత తరగతులు పరిమిత గణన శక్తితో యంత్రాల ద్వారా అన్వయించబడే అధికారిక భాషల సెట్లుగా నిర్వచించబడతాయి. తర్కం మరియు గణిత శాస్త్రపు పునాదులలో, అక్షసంబంధ వ్యవస్థల వాక్యనిర్మాణాన్ని సూచించడానికి అధికారిక భాషలు ఉపయోగించబడతాయి మరియు గణిత ఫార్మలిజం అనేది అన్ని గణితాలను ఈ విధంగా అధికారిక భాషల వాక్యనిర్మాణ తారుమారుకి తగ్గించగల తత్వశాస్త్రం.
కంప్యూటబిలిటీ థియరీ, రికర్షన్ థియరీ అని కూడా పిలుస్తారు, ఇది గణిత తర్కం, కంప్యూటర్ సైన్స్ మరియు కంప్యూటేషన్ సిద్ధాంతం యొక్క శాఖ, ఇది 1930లలో కంప్యూటబుల్ ఫంక్షన్లు మరియు ట్యూరింగ్ డిగ్రీల అధ్యయనంతో ఉద్భవించింది. సాధారణీకరించిన కంప్యూటబిలిటీ మరియు డెఫినిబిలిటీ అధ్యయనాన్ని చేర్చడానికి ఈ క్షేత్రం విస్తరించింది. ఈ ప్రాంతాల్లో, ప్రూఫ్ థియరీ మరియు ఎఫెక్టివ్ డిస్క్రిప్టివ్ సెట్ థియరీతో కంప్యూటబిలిటీ థియరీ అతివ్యాప్తి చెందుతుంది.
సైద్ధాంతిక కంప్యూటర్ సైన్స్ మరియు గణితంలో, గణన సంక్లిష్టత సిద్ధాంతం వాటి వనరుల వినియోగం ప్రకారం గణన సమస్యలను వర్గీకరించడం మరియు ఈ తరగతులను ఒకదానికొకటి సంబంధం కలిగి ఉండటంపై దృష్టి పెడుతుంది. గణన సమస్య అనేది కంప్యూటర్ ద్వారా పరిష్కరించబడే పని. అల్గోరిథం వంటి గణిత దశల యాంత్రిక అనువర్తనం ద్వారా గణన సమస్య పరిష్కరించబడుతుంది.
ఏదైనా అల్గోరిథం ఉపయోగించిన దాని పరిష్కారానికి ముఖ్యమైన వనరులు అవసరమైతే సమస్య అంతర్లీనంగా కష్టంగా పరిగణించబడుతుంది. సిద్ధాంతం ఈ సమస్యలను అధ్యయనం చేయడానికి గణన యొక్క గణిత నమూనాలను పరిచయం చేయడం ద్వారా మరియు వాటి గణన సంక్లిష్టతను లెక్కించడం ద్వారా ఈ అంతర్ దృష్టిని అధికారికం చేస్తుంది, అనగా, వాటిని పరిష్కరించడానికి అవసరమైన వనరుల సంఖ్య, సమయం మరియు నిల్వ వంటివి. కమ్యూనికేషన్ మొత్తం (కమ్యూనికేషన్ సంక్లిష్టతలో ఉపయోగించబడుతుంది), సర్క్యూట్లోని గేట్ల సంఖ్య (సర్క్యూట్ సంక్లిష్టతలో ఉపయోగించబడుతుంది) మరియు ప్రాసెసర్ల సంఖ్య (సమాంతర కంప్యూటింగ్లో ఉపయోగించబడుతుంది) వంటి సంక్లిష్టత యొక్క ఇతర కొలతలు కూడా ఉపయోగించబడతాయి. గణన సంక్లిష్టత సిద్ధాంతం యొక్క పాత్రలలో ఒకటి కంప్యూటర్లు ఏమి చేయగలవు మరియు చేయలేవు అనే వాటిపై ఆచరణాత్మక పరిమితులను నిర్ణయించడం. P వర్సెస్ NP సమస్య, ఏడు మిలీనియం ప్రైజ్ ప్రాబ్లమ్స్లో ఒకటి, గణన సంక్లిష్టత రంగానికి అంకితం చేయబడింది.[1]
సైద్ధాంతిక కంప్యూటర్ సైన్స్లో దగ్గరి సంబంధిత రంగాలు అల్గారిథమ్ల విశ్లేషణ మరియు గణన సిద్ధాంతం. అల్గారిథమ్ల విశ్లేషణ మరియు గణన సంక్లిష్టత సిద్ధాంతం మధ్య ఉన్న ముఖ్యమైన వ్యత్యాసం ఏమిటంటే, ఒక సమస్యను పరిష్కరించడానికి ఒక నిర్దిష్ట అల్గారిథమ్కు అవసరమైన వనరుల సంఖ్యను విశ్లేషించడానికి మొదటిది అంకితం చేయబడింది, అయితే రెండోది ఉపయోగించగల అన్ని అల్గారిథమ్ల గురించి మరింత సాధారణ ప్రశ్న అడుగుతుంది. అదే సమస్యను పరిష్కరించడానికి. మరింత ఖచ్చితంగా, గణన సంక్లిష్టత సిద్ధాంతం సముచితంగా పరిమితం చేయబడిన వనరులతో పరిష్కరించగల లేదా పరిష్కరించలేని సమస్యలను వర్గీకరించడానికి ప్రయత్నిస్తుంది. ప్రతిగా, అందుబాటులో ఉన్న వనరులపై పరిమితులను విధించడం అనేది గణన సంక్లిష్టతను కంప్యూటబిలిటీ సిద్ధాంతం నుండి వేరు చేస్తుంది: తరువాతి సిద్ధాంతం ఏ విధమైన సమస్యలను సూత్రప్రాయంగా, అల్గారిథమిక్గా పరిష్కరించగలదని అడుగుతుంది.