আমি একটি প্রসঙ্গ-সংবেদনশীল ব্যাকরণের সন্ধান করছি যা নীচের ভাষাটি বর্ণনা করে: ।
মতো কোনও নিয়মের অনুমতি নেই এবং এই কারণে আমি শব্দের "মাঝারি" নির্দেশ করে কোনও অবিচ্ছিন্ন রাখতে পারি না এই সমস্যাটি নিয়ে আমার সমস্যা হয়েছে। সমস্যার কোন কৌশল আছে?
আমি একটি প্রসঙ্গ-সংবেদনশীল ব্যাকরণের সন্ধান করছি যা নীচের ভাষাটি বর্ণনা করে: ।
মতো কোনও নিয়মের অনুমতি নেই এবং এই কারণে আমি শব্দের "মাঝারি" নির্দেশ করে কোনও অবিচ্ছিন্ন রাখতে পারি না এই সমস্যাটি নিয়ে আমার সমস্যা হয়েছে। সমস্যার কোন কৌশল আছে?
উত্তর:
প্রকৃতপক্ষে, একটি সহজ কৌশল আছে যা আপনাকে একটি নির্দিষ্ট অবস্থানে অতিরিক্ত তথ্য যুক্ত করতে দেয়: কেবলমাত্র অবস্থানের সংলগ্ন একটি চিঠি প্রতিস্থাপন করুন এবং তথ্য এবং মূল চিঠিটি দিয়ে চিহ্নিত করুন।
আপনার উদাহরণে, একটি অযৌক্তিক থাকুন মাঝের জন্য, তবে এটি মুছে ফেলা যায় না, এটি একটি সাধারণ চিঠি হিসাবেও গণনা করা হয়। এইভাবে আমাদের দুটি কপি আছে এবং প্রতিস্থাপিত অক্ষর নির্দেশ করতে। ডেরাইভেশন শেষে চিহ্নিতকারীগুলিকে তাদের অক্ষরের সামগ্রী দ্বারা, পছন্দ মতো সাধারণ প্রোডাকশন দ্বারা প্রতিস্থাপন করা উচিত।
বেশিরভাগ ক্ষেত্রেই অ্যাপ্লিকেশন ডেরাইভেশন প্রক্রিয়া শেষে সঞ্চালন করা প্রয়োজন। কিছু নির্মাণে এটি "সময়োপযোগী" হওয়ার দরকার পড়ে না: কখনখুব শীঘ্রই অদৃশ্য হয়ে যায়, ডেরাইভেশনটি একটি সঠিক অবস্থান খুঁজে পেতে পারে না এবং প্রক্রিয়াটি সফলভাবে থামবে না will অন্যান্য ক্ষেত্রে এক ধরনের নিয়ন্ত্রণ প্রয়োজন। এটি কখনও কখনও অক্ষর বরাবর সরানো একটি সংকেত হিসাবে একটি ননটার্মিনালাল পরিচয় করিয়ে সম্পন্ন করা হয়। আবার, এই সংকেতটিতে একটি টার্মিনালও বহন করা উচিত অন্যথায় আপনি একই সমস্যার মধ্যে পড়ে।
তথাকথিত মনোোটোনিক ব্যাকরণগুলিতে চারদিকে তথ্য সঞ্চার করা সহজ ( সঙ্গে ) মত নিয়ম ব্যবহার করে , যা হিসাবে দেখা যেতে পারে ঝাঁপিয়ে পড়া । যথাযথ প্রসঙ্গে সংবেদনশীল ব্যাকরণগুলির জন্য এইটিকে তিনটি ধাপে বিভক্ত করা দরকার:। প্রতিটি উত্পাদনে একটি বর্ণ যথাযথ প্রসঙ্গে পরিবর্তিত হয়। এই প্রক্রিয়াটি বংশগতির অন্যান্য অংশের সাথে ইন্টারঅ্যাক্ট করে না তা দেখতে বেশ কিছুটা কল্পনা লাগে। যেমন, যখন হয় শেষ ধাপে প্রথমে অন্য একটি উত্কৃষ্ট পদক্ষেপের সাথে জড়িত?
এটি খুব সংক্ষিপ্ত শব্দের জন্য কাজ করতে পারে না, যখন পজিশনের চেয়ে আরও বেশি তথ্য থাকে। এর সর্বাধিক সহজ সমাধান হ'ল আপনার নির্মাণে সংক্ষিপ্ত স্ট্রিংগুলি উপেক্ষা করা এবং সেগুলি পৃথকভাবে উত্পন্ন করা।
সংক্ষিপ্ত ডিফল্ট উত্তর: একটি এলবিএ নিয়ে আসুন যা ভাষাটি গ্রহণ করে এবং প্রসঙ্গ-সংবেদনশীল ব্যাকরণ এবং এলবিএ একই ভাষার সেট সংজ্ঞায়িত করে তা প্রমাণ করতে ব্যবহৃত সিমুলেশন ব্যবহার করে। তবে তা অবশ্যই আপনার পরে নয়।
এই নির্দিষ্ট ক্ষেত্রে, এর জন্য একটি ডান-লিনিয়ার ব্যাকরণ ব্যবহার করার কথা ভাবার চেষ্টা করুন দু'বার, একটি বাম দিকে এবং একটি ডান অর্ধেকের জন্য। আপনার উভয় ব্যাকরণই "সিঙ্কে" সঞ্চারিত হয়েছে তা নিশ্চিত করতে হবে।
এটি একটি নিয়ন্ত্রণ টোকেনের চারপাশে অদলবদলের মাধ্যমে করা যেতে পারে। এটি বলার জন্য, বাম ব্যাকরণগুলি একটি নিয়ম বেছে নেয়, ফিটিং নিয়ন্ত্রণের টোকেন উত্পন্ন করে ডান ব্যাকরণে দেয়। ডান ব্যাকরণটি নিয়ন্ত্রণ টোকেনটি দেখে এবং ফিটিংয়ের নিয়মটি কার্যকর করে। নোট করুন যে আপনি এইভাবে দ্বি-মুখী যোগাযোগ বাস্তবায়ন করতে পারেন, তবে এটি এখানে প্রয়োজনীয় নয়।
প্রসঙ্গে সংবেদনশীল ব্যাকরণগুলির সাথে একটি সমস্যা রয়েছে: এগুলি কখনই অ-টার্মিনালগুলি মুছতে পারে না (ব্যতীত) যদি খালি শব্দটি ভাষাতে থাকে)। অতএব, আমাদের কেবল যতগুলি নন-টার্মিনাল প্রয়োজন হবে তা তৈরি করতে হবে; কেউই বাড়াবাড়ি হতে পারে না।
এটি অর্জনের একটি উপায় হ'ল এলবিএ সম্পর্কে নির্দিষ্ট প্রমাণের মতো একই কৌশলটি ব্যবহার করা: আপনার প্রথমে যে সমস্ত নন-টার্মিনালগুলির প্রয়োজন হবে তা তৈরি করুন, অর্থাৎ "টেপ" প্রস্তুত করুন। পরে, সেই টেপটিতে "ঘোরাফেরা করুন"। কেবলমাত্র "শেষে", সমস্ত অ-টার্মিনালগুলিকে টার্মিনালগুলির সাথে প্রতিস্থাপন করুন।
বেশ দেরি সঙ্গে (নির্মাণটি সহজেই বৃহত্তর বর্ণমালা পর্যন্ত প্রসারিত হয়) এবং , নিম্নলিখিত বিধি দ্বারা প্রদত্ত
"টেপ" তৈরির নিয়ম are লক্ষ্য করুন যে টুপি "মাথা অবস্থান" এবং সূচকগুলি বোঝায়নন-টার্মিনাল শব্দের অর্ধেকটি বোঝান। নীচে কিছু নিয়ম সুরক্ষিত করার জন্য এইভাবে সংক্ষিপ্ত শব্দগুলি উত্পন্ন হয়। বাম অংশে একটি প্রতীক প্রাপ্ত করার জন্য এখন আমাদের বিধিগুলির প্রয়োজন:
সবার জন্য । উত্সাহিত চিহ্নটি ডানদিকে নিয়ে যাওয়ার জন্য আমরা কীভাবে উপরের সূচকটি ব্যবহার করব তা নোট করুন। এবং "চূড়ান্ত" নন-টার্মিনালগুলি যা কেবলমাত্র নিয়ন্ত্রণ টোকেনকে চারপাশে স্থানান্তর করতে এবং পরে টার্মিনালগুলি আহরণের জন্য ব্যবহৃত হবে। আরও মনে রাখবেন যে দ্বিতীয় নিয়মটি (কেবল) ডান অর্ধের শেষ চিহ্নের জন্য ব্যবহৃত হয়।
ক্যারিটি ডান অর্ধে নিয়ে যাওয়ার জন্য, আমাদের উভয়কেই রেখে যেতে হবে এবং ইতিমধ্যে উত্পন্ন :
সবার জন্য । এখন একবার বাহনটি ডান কন্ট্রোল টোকনে পৌঁছে গেলে, আমাদের বামদিকে ব্যবহৃত নিয়মের নকল করতে হবে:
সবার জন্য । মনে রাখবেন যে প্রথম বিধিটি ডান অর্ধের প্রথম প্রতীক হিসাবে ব্যবহৃত হয় এবং শেষ বিধিটি কেবলমাত্র সর্বশেষ চিহ্নের জন্য ব্যবহার করা যেতে পারে, অন্যথায় ডাইরিভিশনটি কখনই শেষ হয় না। এখন আমাদের কেবল সমাপ্তির বিধিগুলির প্রয়োজন
সবার জন্য এবং আমরা সম্পন্ন। এই বিধিগুলিও, সমস্ত কিছু (বাম দিকে) সম্পন্ন হওয়ার পরে প্রয়োগ করা যেতে পারে, অন্যথায় ডাইরিভিশনটি শেষ হবে না।
মনে রাখবেন যে এই ব্যাকরণটি অস্পষ্ট। শুধু পারে না(নিরাপদে) যেকোন সময় বাম "মাথা" এর বামদিকে যে কোনও জায়গায় প্রয়োগ করা যেতে পারে, তবে একই সাথে একাধিক বহন করাও চলতে পারে। যেহেতু তারা একে অপরকে কখনই ছাড়তে পারে না সঠিক ক্রম বজায় থাকে।
এক মন্তব্য এখনও তৈরি করা আছে: উপরে ব্যাকরণ হয় না কনটেক্সট সংবেদনশীল অনেক নিয়ম পরিবর্তন হিসাবে উভয় বাম দিকে চিহ্ন। প্রসঙ্গ-সংবেদনশীল ব্যাকরণগুলির জন্য এটি অনুমোদিত নয়। ভাগ্যক্রমে, আমরা যে কোনও নিয়ম অনুকরণ করতে পারি ফর্মের
দ্বারা
সুতরাং আমরা ভাল এবং ছোট ব্যাকরণ নিয়ে কাজ করতে পারি। এই জাতীয় একাধিক সিমুলেশনগুলির মধ্যে হস্তক্ষেপটি ব্যথা না করে তা অনুশীলন হিসাবে ছেড়ে দেওয়া হয়েছে।
আপনি কীভাবে এটি প্রসারিত করবেন তা দেখেন ? Does it also work for ? Can you use the same construction for any for regular ?
Although I don't know how the context-sensitive grammar will look like, you can circumvent your problem with the symbol as follows.
You know that your concatenated words must be at least of length . Hence, you could simply "encode" those -rules of your grammar by some rules like:
যদিও, আমি সামগ্রিক সমাধানটি এখনও দেখতে পাচ্ছি না, কারণ আমার মনে হচ্ছে আপনার ব্যাকরণের নিয়মের বাম দিকগুলি সম্ভবত নির্বিচারে দীর্ঘ হয়ে যায়, কারণ আমি মনে করি আপনি এর উপসর্গগুলি বিবেচনা করার চেষ্টা করবেন একরকম আপনার বিধি।