Heuristic શોધ એ એક શક્તિશાળી અલ્ગોરિધમિક અભિગમ છે જેનો ઉપયોગ હ્યુરિસ્ટિક્સ અથવા અંગૂઠાના નિયમોના આધારે જાણકાર નિર્ણયો લઈને જટિલ સમસ્યાની જગ્યાઓમાં ઉકેલો શોધવા માટે થાય છે. તે ખાસ કરીને ઉપયોગી છે જ્યારે વિશાળ શોધ જગ્યાને કારણે સંપૂર્ણ શોધ અવ્યવહારુ હોય.
તે કેવી રીતે કામ કરે છે
- Heuristic મૂલ્યાંકન: અલ્ગોરિધમ ફંક્શનનો ઉપયોગ કરીને સમસ્યાની જગ્યામાં દરેક સ્થિતિનું મૂલ્યાંકન કરે છે heuristic. આ ફંક્શન દરેક રાજ્યની ધ્યેય સ્થિતિની નજીકના સંદર્ભમાં તેની "આશાજનકતા" નો અંદાજ કાઢે છે.
- શોધ વ્યૂહરચના: અલ્ગોરિધમ મૂલ્યાંકનના આધારે સૌથી આશાસ્પદ સ્થિતિ પસંદ કરે છે heuristic. Best-First તે શોધ, A* શોધ અથવા Greedy શોધ જેવી શોધ વ્યૂહરચનાનો ઉપયોગ કરે છે .
- રાજ્ય વિસ્તરણ: પસંદ કરેલ રાજ્ય તેના પડોશી રાજ્યો પેદા કરીને વિસ્તરણ કરવામાં આવે છે. આ આગામી પગલા માટે સંભવિત ઉમેદવારો છે.
- પુનરાવર્તન કરો: પ્રક્રિયાને પુનરાવર્તિત રીતે પુનરાવર્તિત કરવામાં આવે છે, જ્યાં સુધી ધ્યેય સ્થિતિ ન મળે અથવા સમાપ્તિની સ્થિતિ પૂરી ન થાય ત્યાં સુધી રાજ્યોને પસંદ કરીને અને વિસ્તરણ કરવામાં આવે છે.
ઉદાહરણ: ટ્રાવેલિંગ સેલ્સમેન પ્રોબ્લેમ(TSP)
ટ્રાવેલિંગ સેલ્સમેન પ્રોબ્લેમનો વિચાર કરો, જ્યાં સેલ્સમેનને શહેરોના સમૂહની મુલાકાત લેવાની જરૂર છે અને મુસાફરી કરેલ કુલ અંતર ઘટાડીને પ્રારંભિક શહેરમાં પાછા ફરવું પડશે. અભિગમ heuristic નજીકના નેબર અલ્ગોરિધમ હોઈ શકે છે:
- રેન્ડમ શહેરથી પ્રારંભ કરો.
- દરેક પગલા પર, આગલા ગંતવ્ય તરીકે નજીકના અવિચારી શહેરને પસંદ કરો.
- જ્યાં સુધી બધા શહેરોની મુલાકાત લેવામાં ન આવે ત્યાં સુધી પુનરાવર્તન કરો, પછી પ્રારંભિક શહેરમાં પાછા ફરો.
C++ માં કોડનું ઉદાહરણ
આ ઉદાહરણમાં, નજીકના નેબર અલ્ગોરિધમનો ઉપયોગ ટ્રાવેલિંગ સેલ્સમેનની સમસ્યાને ઉકેલવા માટે થાય છે. તે એક એવો heuristic અભિગમ છે જે દરેક પગલા પર સૌથી નજીકના અવિવેચન શહેરને પસંદ કરે છે, પરિણામે તે ઉકેલમાં પરિણમે છે જે ઘણીવાર શ્રેષ્ઠની નજીક હોય છે.