मुझे विश्वास है कि इस तरह की चीजें constraint logic programming में नियमित रूप से की जाती हैं। दुर्भाग्य से मुझे अधिक सटीक विवरण देने के लिए पर्याप्त अनुभव नहीं हुआ है, लेकिन यह एक अच्छा प्रारंभिक बिंदु होना चाहिए।
सामान्य सिद्धांत सरल है: एक अनबाउंड चर के पास कोई मूल्य हो सकता है; जैसा कि आप असमानताओं के खिलाफ परीक्षण करते हैं, यह संभव मूल्यों का सेट एक या अधिक अंतराल से प्रतिबंधित है। जब/अगर उन अंतराल एक बिंदु पर अभिसरण होते हैं, तो वह चर उस मान से बंधी होती है। यदि, ओटीओएच, इनमें से किसी भी असमानता को अंतराल में प्रत्येक मूल्य के लिए असफल समझा जाता है, तो [प्रोग्रामिंग] तर्क विफलता होती है।
this भी देखें, उदाहरण के लिए यह स्विई-प्रोलॉग का उपयोग करके अभ्यास में कैसे किया जाता है। उम्मीद है कि आपको अंतर्निहित एल्गोरिदम के लिंक या संदर्भ मिलेगा, ताकि आप उन्हें अपने पसंद के प्लेटफ़ॉर्म में पुन: उत्पन्न कर सकें (शायद तैयार किए गए पुस्तकालयों को भी ढूंढें)।
अद्यतन: मैंने स्विई-प्रोलॉग और सीएलपीएफडी का उपयोग करके अपने उदाहरण को पुन: पेश करने का प्रयास किया, लेकिन मुझे अपेक्षित नतीजे नहीं मिले, केवल नज़दीक ही। उलटे पांव लौटने पर
?- [library(clpfd)].
simplify(A,B,C,D) :-
A #= 1 ,
(B #= 1 ; B #\= 0) ,
(C#>= 35 ; D #\= 5) ,
(C#>= 38 ; D #= 6).
और मेरे परिणाम, (पंक्ति विराम पठनीयता के लिए डाला): यहाँ मेरी कोड है
10 ?- simplify(A,B,C,D).
A = 1,
B = 1,
C in 38..sup ;
A = 1,
B = 1,
D = 6,
C in 35..sup ;
A = 1,
B = 1,
C in 38..sup,
D in inf..4\/6..sup ;
A = 1,
B = 1,
D = 6 ;
A = 1,
B in inf.. -1\/1..sup,
C in 38..sup ;
A = 1,
D = 6,
B in inf.. -1\/1..sup,
C in 35..sup ;
A = 1,
B in inf.. -1\/1..sup,
C in 38..sup,
D in inf..4\/6..sup ;
A = 1,
D = 6,
B in inf.. -1\/1..sup.
11 ?-
तो, कार्यक्रम झुकेंगे 8 परिणाम उन लोगों के बीच, 2 तुम पर रुचि (5 वीं थे और 8 वीं):
A = 1,
B in inf.. -1\/1..sup,
C in 38..sup ;
A = 1,
D = 6,
B in inf.. -1\/1..sup.
अन्य अनावश्यक थे, और शायद सरल, automatable तर्क नियमों का उपयोग कर समाप्त किया जा सकता:
1st or 5th ==> 5th [B == 1 or B != 0 --> B != 0]
2nd or 4th ==> 4th [C >= 35 or True --> True ]
3rd or 1st ==> 1st ==> 5th [D != 5 or True --> True ]
4th or 8th ==> 8th [B == 1 or B != 0 --> B != 0]
6th or 8th ==> 8th [C >= 35 or True --> True ]
7th or 3rd ==> 3rd ==> 5th [B == 1 or B != 0 --> B != 0]
मैं जानता हूँ कि यह एक सामान्य समाधान किया जा रहा है के पीछे एक लंबा रास्ता है, लेकिन जैसा कि मैंने कहा, उम्मीद है कि यह एक शुरुआत है ...
पी.एस. मैंने "नियमित" और OR (,
और ;
) का उपयोग किया क्योंकि clpfd के (#/\
और #\/
) ने एक बहुत ही अजीब परिणाम दिया कि मैं खुद को समझ नहीं पाया ... शायद कोई और अनुभवी इस पर कुछ प्रकाश डाल सकता है ...
बहुपद समय में कितनी कमी हो सकती है इसकी सीमाएं हैं। उदाहरण के लिए, यदि आप हमेशा अपने सरल रूप में किसी भी संयोजन सामान्य रूप अभिव्यक्ति को कम कर सकते हैं, तो आप खुली 3 एसएटी समस्या हल कर लेते। – mbeckish
@mbeckish: यह मुझे डरावना लगता है। असल में, मुझे इन चीजों के बारे में पता नहीं था जब तक कि आप लोगों ने मुझे सही दिशा में नहीं चलाया। मैं सिर्फ 3 एसएटी, लेकिन एनएसएटी समस्याओं के बारे में सोच रहा था। अब, यह सब असंभव लगता है। –
एनपी-हार्ड समस्याओं से निपटने के लिए डरो मत। उनमें से ज्यादातर के लिए, कठिन हिस्सा समस्याग्रस्त और आसान समस्याओं के बीच चरण संक्रमण में समस्या स्थान के अपेक्षाकृत छोटे क्षेत्र में होगा। यदि एनपी-हार्ड समस्याओं को हल करना हमेशा असंभव था, तो मैं अपने काम से बाहर रहूंगा। यह इस बात पर निर्भर करता है कि आप अपने एल्गोरिदम को कितनी दूर स्केल करते हैं। – twinterer