एक समझने योग्य वाक्य उत्पन्न करें


55

मुसीबत:

एक ऐसा वाक्य तैयार करें जिसे पढ़ा और समझा जा सके। इसमें एक विषय, क्रिया, और ऑब्जेक्ट होना चाहिए, और काल और प्लुरल का मिलान होना चाहिए। अर्हता प्राप्त करने के लिए कार्यक्रम को कई अलग-अलग वाक्य उत्पन्न करने में भी सक्षम होना चाहिए।

नियम:

  • हार्ड-कोडिंग वाक्यों की अनुमति नहीं है, और न ही उन्हें एक फ़ाइल से सीधे पढ़ा जा रहा है (मैं आपको देख रहा हूं, चाचा)
  • आपके पास कोई भी शब्द सूची हो सकती है
  • एक उदाहरण वाक्य या 2 जमा करें जो आपके प्रोग्राम द्वारा उत्पन्न किया गया है
  • किसी भी भाषा को स्वीकार किया जाता है
  • यह एक , इसलिए सबसे अधिक उत्कीर्ण उत्तर जीतता है

7
मुझे लगता है कि यह कुछ उत्तरों ( मैटलैब मैं आपको देख रहा हूं) से स्पष्ट है कि आपको नियमों को संशोधित करना चाहिए ताकि डेटा-माइनिंग को किसी भी स्रोत से लगातार शब्दों को खींचने की अनुमति न हो।
कार्ल विट्ठॉफ्ट

जबकि मैं एक स्मार्टस रहा हूँ: क्योंकि यह विशुद्ध रूप से एक लोकप्रियता प्रतियोगिता है, किसी को सिर्फ एक हॉटमॉडेल बिकनी jpg पोस्ट करना चाहिए। कि कुछ से अधिक वोट मिल जाएगा।
कार्ल विटथॉफ्ट

7
मैं ऐसे किसी भी व्यक्ति को उकसाऊंगा जो "भैंस" या "मछली" के दोहराव का उपयोग नमूना वाक्यों के रूप में करता है!

7
यहां अधिकांश उत्तर या तो मान्य हैं, पाठ स्रोतों से पूर्ण वाक्य हैं, या मानदंड को पूरा नहीं करने वाले आउटपुट उत्पन्न करते हैं। मेरे लिए, दोनों दृष्टिकोण प्रश्न की भावना के खिलाफ हैं! यदि कोई वास्तव में प्रभावित करना चाहता है, तो क्या मैं एक ऐसे प्रोग्राम का सुझाव दे सकता हूं, [Adjective] [pl. noun] [verb] [adjective] [pl. noun]जो रिक्त वाक्य संरचनाओं के एक सेट से शुरू होता है जैसे रिक्त स्थान में भरने के लिए एक वास्तविक शब्दकोश (शायद वहां उपलब्ध शब्दकोश एपीआई में से एक का उपयोग करके) से खींचता है? अगर मैं कुछ मिनट के लिए छोड़ देता, तो मैं इसे खुद लिखता! :( आखिर ...Lazy Developers Write Lousy Programs.
ब्रायन लेसी

1
@Pureferret शब्द सूची व्यक्तिगत शब्दों की सूची होगी। हार्ड कोडिंग पूरे वाक्यों की सूची होगी। शब्द सूचियों के साथ, आपको आम तौर पर कार्यक्रम में कुछ तर्क की आवश्यकता होगी ताकि पूरा वाक्य एक साथ हो सके। कठिन कूट वाक्यों के साथ, आपको मूल रूप से केवल एक प्रिंट स्टेटमेंट की आवश्यकता होती है।
8bittree

जवाबों:


87

दे घुमा के

fgrep '/* ' /usr/src/linux* -r | cut -d '*' -f 2 | head -$((RANDOM)) | tail -1

आवश्यकताएँ: लिनक्स कर्नेल स्रोत / usr / src में स्थापित

यह कर्नेल स्रोत से यादृच्छिक टिप्पणियों को खींचता है। क्या वाक़ई समझ में आने वाले वाक्य बहस के लिए खुले हैं।

वास्तविक उत्पादन के उदाहरण:

  • end of packet for rx
  • I don't know what to do
  • 256 byte packet data buffer.
  • The rest of this junk is to help gdb figure out what goes where
  • Convert page list back to physical addresses, what a mess.
  • ???
  • Only Sun can take such nice parts and fuck up the programming interface

12
अच्छा था! आपको उन सभी को खींचना चाहिए और इसे एक आधिकारिक fortuneडेटाबेस के रूप में प्रस्तुत करना चाहिए ।
जेसन सी

18
"???" सर्वश्रेष्ठ टिप्पणी कभी
रे

4
क्या पहला नियम 'नहीं है और न ही उन्हें एक फ़ाइल से सीधे पढ़ा जा रहा है' का उल्लंघन होता है?
kuldeep.kamboj

6
मैं कहूंगा कि सिस्टम सोर्स कोड के माध्यम से खोज करना और टिप्पणियों से पाठ को फ़िल्टर करना वास्तव में "सीधे पढ़ने" के रूप में नहीं गिना जाता है।
दंगा

7
और Slave Overflow। एसई वेबसाइट के लिए अच्छा नाम
TheDoctor

95

Matlab

why

आउटपुट का उदाहरण:

>> why
The programmer suggested it.
>> why
To please a very terrified and smart and tall engineer.
>> why
The tall system manager obeyed some engineer.
>> why
He wanted it that way.

[यह मतलब के ईस्टर अंडे में से एक है]

EDIT: आप इस फ़ंक्शन का कोड यहां देख सकते हैं: Why.m


3
आप यहाँ कोड देख सकते हैं: opg1.ucsd.edu/~sio221/SIO_221A_2009/SIO_221_Data/Matlab5/…
एलीशा

8
दूसरा उदाहरण एक वाक्य नहीं है। यह एक असीम वाक्यांश है।
वॅर्चिनिन

2
यहां उत्तरों की अवश्यता न केवल वाक्य उत्पन्न करती है (उदाहरण के लिए अन्य उच्च मतदान उत्तरों को देखें)। कार्य यह नहीं कहता है कि उसे केवल वाक्य बनाने होंगे, यह कहता है कि उसे वाक्य बनाने में सक्षम होना चाहिए।
एलिशा

51

पीएचपी

पर्याप्त समय को देखते हुए, यह सभी साहित्य, अतीत, वर्तमान और भविष्य का निर्माण करेगा। नियमों में यह उल्लेख नहीं किया गया है कि किसी अन्य पाठ का उत्पादन नहीं किया जा सकता है।

स्ट्रिंग 'TOS...'अधिक बारीकी से अंग्रेजी से मेल करने के लिए अक्षरों का एक लघुगणक पैमाने आवृत्ति प्रदान करता है। यह अनुमानित रिश्तेदार पत्र आवृत्तियों के साथ एक बड़ा स्ट्रिंग उत्पन्न करने के लिए उपयोग किया जाता है।

$a = ord('A');
$s = '';

foreach (str_split('TOSRWQPPUALRQTTRGUUUQMMLMFZ') as $i=>$f)
{
    if (!ctype_alpha($c = chr($a + $i)))
        $c = ' ';
    $s .= str_repeat($c, round(exp((ord($f) - $a) / 3.976)));
}

$l = strlen($s) - 1;
for (;;)
    echo substr($s, mt_rand(0, $l), 1);

इसे चलाते हुए, मैंने ऐसे साहित्यिक रत्नों की खोज की है:

  • GO NOW- आप एक विषय के रूप में निहित हैं।
  • IM AOK - मैं ए-ओके हूं
  • IM FDR - मैं एफ (रैंक्लिन) डी (एलीनो) आर (ऑज़वेल्ट) हूं

साथ ही, वर्तमान स्थिति के साथ कई आभार प्रकट रूप से नाराजगी व्यक्त करने के लिए। [कुछ पत्र फिर से प्रकाशित किए गए।]

  • F**K
  • S**T

साथ ही, ठीक-ठीक स्केलिंग का उपयोग करते हुए निम्नलिखित है:

  • IS IT ON
  • I AM STU
  • I SEE HTML

60
क्यों, बंदरों का झुंड ही ऐसा कर सकता है!
टिम एस।

11
मुझे पसंद! अब एक प्रोग्राम बनाएं जो उस से आने वाले अक्षरों को संसाधित करता है और समझने योग्य वाक्य पाता है! :)
TheDoctor

2
+1 - खोज वाले हिस्से को स्वचालित करने का कोई चांस? यह कार्य प्रतीत होता है कि * एक * (?) वाक्य का उत्पादन करता है। BTW: आपने कितना समय बिताया?)
वुल्फ

20
आपको कैसे प्रदान किया गया F**Kऔर S**Tप्रदान किया गया है, इसमें कोई नहीं *है 'ABCDEFGHIJKMLNOPQRSTUVWXYZ '?
ग्लोगल

3
@Ypnypn - 'TOS...'स्ट्रिंग एक लघुगणकीय पैमाने में प्रत्येक अक्षर की आवृत्ति का प्रतिनिधित्व करता है। तो Aआवृत्ति है T, Bआवृत्ति है OJसबसे कम आवृत्ति होती है, Aजिसका अनुवाद 0 में होता है, जिसमें से व्युत्क्रम लॉग होता है। 1. अंतिम वर्ण वह स्थान होता है, जिसमें आवृत्ति Z, या राउंड (एक्सप (25 / 3.976)) = 538 होती है, इसलिए रिक्त स्थान 538 गुना अधिक बार होते हैं J। बस यह सोचा कि यह बंदर-ए-टाइपराइटर समस्या पर एक साफ मोड़ देता है।

42

सी

char*strerror(),i;main(){for(;--i;)puts(strerror(i));}

उदाहरण आउटपुट:

सॉफ्टवेयर के कारण कनेक्शन निरस्त हुआ
बाधित सिस्टम कॉल को फिर से शुरू किया जाना चाहिए

वहाँ भी बहुत सारे वैध वाक्य आउटपुट हैं जिनमें एक विषय, क्रिया और वस्तु नहीं है:

समयसीमा समाप्त
फ़ाइल मौजूद है


यह कैसे और कब समाप्त होता है? (यह करता है, लेकिन मुझे समझ में नहीं आता क्यों)
phil294

1
@Blauhirn लूप समाप्ति की स्थिति का --iमूल्यांकन तब गलत होता है जब i( charप्रारंभिक मान 0 के साथ एक प्रकार का चर ) 0 पर फिर से पहुंचता है। यदि charअहस्ताक्षरित (उदाहरण के लिए एआरएम) है, iतो तुरंत अपने सबसे बड़े मूल्य (आमतौर पर 255) के चारों ओर लपेट जाएगा और 0. पर गिना जाएगा। यदि charहस्ताक्षर किए गए हैं (अधिकांश इंटेल सिस्टम) व्यवहार सख्ती से अपरिभाषित बोल रहा है, लेकिन आमतौर पर एक बार यह अपने न्यूनतम मूल्य तक पहुंच जाता है ( आम तौर पर -128) यह अपनी अधिकतम (आम तौर पर 127) के चारों ओर लपेटेगा और 0. तक गिना जाएगा। इसलिए कार्यक्रम आम तौर पर कुल 256 लाइनों को प्रिंट करेगा।
इकतुर

37

जावा

एक यादृच्छिक विकिपीडिया लेख से परिचय वाक्य को खींचता है:

import java.io.InputStream;
import java.net.URL;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;

public class RandomSentence {
    public static void main (String[] args) throws Exception {
        String sentence;
        do {
            InputStream in = new URL("https://en.wikipedia.org/wiki/Special:Random").openStream();
            Document doc = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(in);
            String intro = doc.getElementsByTagName("p").item(0).getTextContent();
            sentence = intro.replaceAll("\\([^(]*\\) *", "").replaceAll("\\[[^\\[]*\\]", "").split("\\.( +[A-Z0-9]|$)")[0];
        } while (sentence.endsWith(":") || sentence.length() < 30 || sentence.contains("?"));
        System.out.println(sentence + ".");
    }
}

कभी-कभी आप अशुभ हो जाते हैं; मैं एक न्यूनतम वाक्य लंबाई निर्धारित करके और ":" (सभी विस्मयादिबोधक पृष्ठों को इस तरह से शुरू करता हूं) या "शामिल हैं?" (प्रश्नवाचक चिन्हों द्वारा चिन्हित अनसुलझे अज्ञात जानकारी वाले कई लेख प्रतीत होते हैं)। वाक्य सीमाएं एक अवधि है जिसके बाद व्हाट्सएप नंबर या कैपिटल लेटर होता है।

मैं कोष्ठक में पाठ को भी फ़िल्टर करता हूं (परिणाम अभी भी एक वैध वाक्य है) कुछ अवधि की कोशिश करने और हटाने के लिए जो कि सीमाएं नहीं हैं। मैं स्रोत उद्धरण संख्या निकालने के लिए वर्ग ब्रेसिज़ को फ़िल्टर करता हूं। उदाहरण:

  • आइडल क्योर कैलिफोर्निया के लॉन्ग बीच से एक एरीना रॉक बैंड था।
  • आत्म-ध्यान एक गैर-रैखिक ऑप्टिकल प्रक्रिया है जो तीव्र विद्युत चुम्बकीय विकिरण के संपर्क में आने वाली सामग्रियों के अपवर्तक सूचकांक में परिवर्तन से प्रेरित है।
  • TB10Cs4H3 गैर-कोडिंग आरएनए अणु के एच / एसीए-जैसे वर्ग का सदस्य है जो सब्सट्रेट आरएनए के pseudouridines को यूरीडाइन के संशोधन की साइटों का मार्गदर्शन करता है।
  • सुमेरियन पौराणिक कथाओं में छह सिर वाला जंगली राम प्राचीन इराक में लागेश के संरक्षक देवता निनुरता द्वारा मारे गए नायकों में से एक था।
  • चीनी डैडी एक ऐसे व्यक्ति के लिए एक शब्द है जो आमतौर पर यौन संबंध बनाने के बाद आमतौर पर छोटी महिला या पुरुष का समर्थन करने की पेशकश करता है।
  • ओल्ड बेथेल यूनाइटेड मेथोडिस्ट चर्च 222 कैलहौन सेंट, चार्ल्सटन, दक्षिण कैरोलिना में स्थित है।
  • डगलस गेयर्स एक अमेरिकी संगीतकार हैं।

यदि आप किसी भी व्याकरण के मुद्दों को नोटिस करते हैं, तो ठीक है, एक मेहनती विकिपीडिया संपादक नहीं होने के लिए आपकी गलती है! ;-)


4
निश्चित रूप से "मान्य" और "समझने योग्य" के बीच अंतर है। मैं तुम्हारे लिए कुछ सब्सट्रेट आरएनए स्यूडोउरीडाइन्स यहीं ले आया हूँ, बेबी।
जेसन सी

1
मुझे यह पहली बार मिला जब मैंने इसे चलाया: इचिनोलिटोरिना अफ्रिका / लिटोरिना अफ्रिका फिलिप्पी, 1847 / लिटोरिना डिकोलाटा फिलिप्पी, 1847 / लिटोरीना अफ्रिका / लिटोरिना एप्लेक्सा टरटन, 1932 / नोडेलिटोरिना अफ्रिका ।/ ऐसा लगता है कि कुछ विकी पृष्ठ हैं। खोज! ;) हाहा! ओएमजी, दूसरी बार जब मैंने इसे चलाया, तो यह मिखाइल गोर्बाचेव के विकी पृष्ठ से एक पंक्ति में लौट आया। कौन मेरा पहला नाम साझा करता है काफी अजीब है।
mikhailcazi

2
'/' वास्तव में वहाँ नहीं थे! हाहा: पीआई ने नई लाइनों का प्रतिनिधित्व करने के लिए इसका इस्तेमाल किया। शायद मैं \ n का उपयोग करूं। यह यहाँ से है: en.wikipedia.org/wiki/Afrolittorina_africana । दाईं ओर टेबल, समानार्थी के तहत :) वैसे भी, यह एक बुरा प्रभाव नहीं था, इसलिए चिंता न करें, क्योंकि मिखाइल गोर्बाचेव की बात बहुत अच्छी थी। और उसके बाद के सभी वाक्य सामान्य थे।
मिखाइलक़ाज़ी

2
आप पा सकते हैं कि यह भौतिकी उन लेखों में से एक के दिलचस्प, हाल के सह-उपयोगकर्ता का जवाब देती है
ईपी

2
यह प्रायिकता का एक सामान्य लेकिन अत्यधिक अनपेक्षित पहलू हो सकता है: एक बार में एक मिलियन की घटना दुनिया के अरबों लोगों के साथ काफी आम हो सकती है। उस ने कहा, मुझे यकीन नहीं है कि एक औपचारिक विश्लेषण क्या कहेगा। मैं भी काफी हैरान था! आप यह भी नोट कर सकते हैं कि कोई 'अन्य आदमी' शामिल नहीं है।
ईपी

34

Soooo ... चूँकि यह , इसलिए मुझे कुछ मज़ा आया evalऔर इसके साथ। मूल रूप से मैं एक यादृच्छिक संख्या उत्पन्न करता हूं और फिर उस संख्या (आपके चेहरे पर switch!) के आधार पर एक यादृच्छिक फ़ंक्शन निष्पादित करता हूं eval

PHP, ~ 9k वैध आउटपुट

<?php

//Subjects
function s1(){ echo "I "; $m = rand(1,20); eval ("v".$m."(0);");}
function s2(){ echo "You "; $m = rand(1,20); eval ("v".$m."(0);");}
function s3(){ echo "He "; $m = rand(1,20); eval ("v".$m."(1);");}
function s4(){ echo "She "; $m = rand(1,20); eval ("v".$m."(1);");}
function s5(){ echo "We "; $m = rand(1,20); eval ("v".$m."(0);");}
function s6(){ echo "They "; $m = rand(1,20); eval ("v".$m."(0);");}

//Verbs
function v1($n){ echo "want"; if($n==1)echo"s"; echo " to "; $z = rand(1,10); eval ("a".$z."();");}
function v2($n){ echo "need"; if($n==1)echo"s"; echo " to "; $z = rand(1,10); eval ("a".$z."();");}
function v3($n){ echo "ha"; if($n==1){echo"s";}else{echo"ve";} echo " to "; $z = rand(1,10); eval ("a".$z."();");}
function v4($n){ echo "wanted to "; $z = rand(1,10); eval ("a".$z."();");}
function v5($n){ echo "needed to "; $z = rand(1,10); eval ("a".$z."();");}
function v6($n){ echo "had to "; $z = rand(1,10); eval ("a".$z."();");}
function v7($n){ echo "eat"; if($n==1)echo"s"; echo " "; $w = rand(1,20); eval ("o".$w."();");}
function v8($n){ echo "think"; if($n==1)echo"s"; echo " about "; $w = rand(1,20); eval ("o".$w."();");}
function v9($n){ echo "ate "; $w = rand(1,20); eval ("o".$w."();");}
function v10($n){ echo "thought about "; $w = rand(1,20); eval ("o".$w."();");}
function v11($n){ echo "draw"; if($n==1)echo"s"; echo " "; $w = rand(1,20); eval ("o".$w."();");}
function v12($n){ echo "drew "; $w = rand(1,20); eval ("o".$w."();");}
function v13($n){ echo "smell"; if($n==1)echo"s"; echo " like "; $w = rand(1,20); eval ("o".$w."();");}
function v14($n){ echo "shot "; $w = rand(1,20); eval ("o".$w."();");}
function v15($n){ echo "destroy"; if($n==1)echo"s"; echo " "; $w = rand(1,20); eval ("o".$w."();");}
function v16($n){ echo "destroyed "; $w = rand(1,20); eval ("o".$w."();");}
function v17($n){ echo "melt"; if($n==1)echo"s"; echo " "; $w = rand(1,20); eval ("o".$w."();");}
function v18($n){ echo "saw "; $w = rand(1,20); eval ("o".$w."();");}
function v19($n){ echo "ha"; if($n==1){echo"s";}else{echo"ve";} echo " "; $w = rand(1,20); eval ("o".$w."();");}
function v20($n){ echo "had "; $w = rand(1,20); eval ("o".$w."();");}

//Auxiliaries
function a1(){ echo "punch "; $w = rand(1,20); eval ("o".$w."();");}
function a2(){ echo "drive "; $w = rand(1,20); eval ("o".$w."();");}
function a3(){ echo "mount "; $w = rand(1,20); eval ("o".$w."();");}
function a4(){ echo "see "; $w = rand(1,20); eval ("o".$w."();");}
function a5(){ echo "have "; $w = rand(1,20); eval ("o".$w."();");}
function a6(){ echo "eat "; $w = rand(1,20); eval ("o".$w."();");}
function a7(){ echo "stun "; $w = rand(1,20); eval ("o".$w."();");}
function a8(){ echo "kiss "; $w = rand(1,20); eval ("o".$w."();");}
function a9(){ echo "Ted "; $w = rand(1,20); eval ("o".$w."();");} //See "How I met Your Mother" for further informations :)
function a10(){ echo "blow "; $w = rand(1,20); eval ("o".$w."();");}

//Objects
function o1(){ echo "a cow!<br>";}
function o2(){ echo "a meatball!<br>";} 
function o3(){ echo "a car!<br>";} 
function o4(){ echo "shoes!<br>";} 
function o5(){ echo "pigs!<br>";} 
function o6(){ echo "a telephone!<br>";} 
function o7(){ echo "some bottles of water!<br>";} 
function o8(){ echo "a laptop!<br>";} 
function o9(){ echo "my shorts!<br>";} //Quote needed
function o10(){ echo "anchovies!<br>";}
function o11(){ echo "an alarm clock!<br>";}
function o12(){ echo "every second!<br>";}
function o13(){ echo "until the end!<br>";}
function o14(){ echo "sitting!<br>";}
function o15(){ echo "a sword!<br>";}
function o16(){ echo "fire!<br>";}
function o17(){ echo "the dust!<br>";}
function o18(){ echo "in the bedroom!<br>";}
function o19(){ echo "a poor ant!<br>";}
function o20(){ echo "a pencil!<br>";}

//Testing
$n = rand(1,6); eval ("s".$n."();");
$n = rand(1,6); eval ("s".$n."();");
$n = rand(1,6); eval ("s".$n."();");
$n = rand(1,6); eval ("s".$n."();");

?>

कुछ आउटपुट ...

She draws a sword!
They thought about sitting!
You eat my shorts!
He wanted to Ted a cow!
You want to mount a poor ant!
She smells like anchovies!
He wanted to have shoes!
They wanted to see a pencil!

@ nyuszika7h, PHP_EOLही कभी बराबर करने के लिए है \nया \r\n, ऑपरेटिंग सिस्टम के आधार, लेकिन कभी नहीं <br>या इसी तरह की।
टाइममीआरएस

@timmyRS हां, आप सही कह रहे हैं, यह एक पुरानी टिप्पणी है, मुझे नहीं पता कि मैंने उस समय क्यों लिखा था।
nyuszika7h

33

PHP + प्रोजेक्ट गुटेनबर्ग

मैंने एक PHP स्क्रिप्ट लिखी है जो एक सादे टेक्स्ट डॉक्यूमेंट को शब्द बिग्रेड के एक सेट में बदल देती है , जिसका उपयोग वह यादृच्छिक वाक्य बनाने के लिए करता है। पैट्रिक हेनरी के "गिव मी लिबर्टी या गिव मी डेथ" भाषण के संपूर्ण सादे पाठ संस्करण से उत्पन्न कुछ बेहतर उदाहरण यहां दिए गए हैं , जिसमें प्रोजेक्ट गुटेनबर्ग छोटा प्रिंट भी शामिल है:

  • राष्ट्रों का प्रोजेक्ट गुटेनबर्ग एटेक्स्ट, और गुलामी!

  • हम इस छोटे प्रिंट की 200 वीं वर्षगांठ के लिए क्षमा चाहते हैं!

  • आप किसी भी तरह का कोई अन्य युद्ध नहीं करते हैं, एक्सप्रेस या आकस्मिक डैमेज, लेकिन मेरे लिए, मौत!

आप इसे यहां अपने लिए आजमा सकते हैं। नए बैच के वाक्यों के लिए पेज को रिफ्रेश करें।

यदि आप स्रोत कोड स्वयं चलाना चाहते हैं, तो $src_textअपने चुने हुए सादे पाठ के साथ लोड करना न भूलें ।

<html>
<head>
<title>Give Me Liberty Or Give Me Death</title>
<style>
body { margin:4em 6em; text-align:center; background-color:#feb; }
h1 { font-weight:normal; font-size:2em; margin-bottom:2em; }
blockquote { font-style:italic; }
</style>
</head>
<body>
<h1>A collection of quotes randomly generated from Patrick Henry's speech
<a href="http://www.gutenberg.org/ebooks/6">Give Me Liberty Or Give Me Death</a>
(and its accompanying Project Gutenberg blurb).</h1>
<?php

/* Give Me Liberty Or Give Me Death */
/* Plain text available from http://www.gutenberg.org/ebooks/6 */
$src_text = file_get_contents('libertyordeath.txt');

$bigrams = array();
$openers = array();
$loc = 0;
$new_sentence = true;
$last = false;
while (preg_match('/\'?\w+[^\s\[\]\*\(\)"#@]*/',$src_text,$matches,PREG_OFFSET_CAPTURE,$loc)) {
  $w = $matches[0][0];
  $loc = $matches[0][1]+strlen($w);
  $bareword = preg_replace('/\W/','',$w);
  if ($last) {
    if (!isset($bigrams[$last][$w])) $bigrams[$last][$w] = 1;
    else $bigrams[$last][$w]++;
  }
  if (!isset($bigrams[$bareword])) $bigrams[$bareword] = array();
  $last = $bareword;
  if ($new_sentence && preg_match('/^[A-Z]/',$w)) {
    if (!isset($openers[$w])) $openers[$w] = 1;
    else $openers[$w]++;
    $new_sentence = false;
  }
  if (ends_sentence($w)) {
    $new_sentence = true;
    $last = false;
  }
}

/* Now generate ten random sentences */

for ($ns=0; $ns<10; $ns++) {

  echo "<blockquote><p>";

  /* Choose a starting word */

  $sum = 0;
  foreach ($openers as $w=>$c) $sum += $c;
  $r = mt_rand(0,$sum);
  foreach ($openers as $w=>$c) {
    $r -= $c;
    if ($r<=0) break;
  }

  /* Barf out additional words until end of sentence reached */

  while(1) {
    echo "$w ";
    if (ends_sentence($w)) break;
    $bareword = preg_replace('/\W/','',$w);
    $sum = 0;
    foreach ($bigrams[$bareword] as $w=>$c) $sum += $c;
    $r = mt_rand(0,$sum);
    foreach ($bigrams[$bareword] as $w=>$c) {
      $r -= $c;
      if ($r<=0) break;
    }
  }

  echo "</p></blockquote>\n";
}

function ends_sentence($w) {
  if (!preg_match('/[\.\?!]$/',$w)) return false;
  if (preg_match('/^(\w|St|Mr|Ms|Mrs|Messrs|i\.e|e\.g|etc|Rd)\./i',$w)) return false;
  return true;
}

?>
</body>
</html>

+10 यह वास्तव में चुनौती की भावना को दर्शाता है! मैं इसे अब नहीं ढूँढ सकता, लेकिन एक ऑनलाइन Google-आधारित वाक्य जनरेटर हुआ करता था जो एक समान तरीके से काम करता था, लेकिन एक शब्द की खोज और अवलोकन द्वारा Google खोज परिणामों में से बीग्राम (या वैकल्पिक रूप से बड़ा n-ग्राम) प्राप्त किए गए थे खोज परिणाम पूर्वावलोकन स्निपेट में इसका अनुसरण किया गया। शायद मैं इसे फिर से बनाऊंगा और इसे यहां पोस्ट करूंगा।
जेसन सी

इसके बारे में क्या खयाल है! "सर, हम पाते हैं कि प्रतियोगिता को सुधारने की कृपा हुई है।" या यह एक! "वे आपको बताते हैं कि आप बहुत
उत्साहित हैं

1
But for me, death!: DI इच्छा है कि सभी लाइसेंस / समझौते दृढ़ता से समाप्त हो जाएं।
नवीन

Haha, "अकेले हमारी लड़ाई के लिए आधिकारिक तौर पर जारी किया गया।"
जेसन सी

1
मुझे कुछ नहीं मिला।" :(
द नम्बरन

29

अजगर

यह प्रविष्टि पूरे सिस्टम शब्दकोश से शब्दों का चयन करती है। यह इस तथ्य का लाभ उठाता है कि आप अधिकांश संज्ञाओं को क्रिया और इसके विपरीत बना सकते हैं। यह शब्दों को वर्गीकृत करने और स्पष्ट बाधाओं से बचने के लिए कुछ अनुमानों का उपयोग करता है।

यह कुछ लगभग बयान बयान करता है:

The snigger westernizes the bacteriologist.
A drizzle stoked the sentiments.

कई पागल हैं:

Tipper's orthopaedic knitwear plates a payroll.
A fibula teletypewritered a yogi.
The protozoan's spiralling skydive coats this veterinarian

और बहुत सारा सामान जो लगता है कि मोंटी पाइथन को भोला बना रहा है:

That rolling indictment tarries some bang's bulge.
Some inflammatory tush's intermarriage sextants some postman.
Some pentagon's manufacturer squeaked the wolverine.
A disagreeable participant is entertaining my optimized spoonful.

संस्करण 3 को किसी भी पाठ फ़ाइल को इनपुट के रूप में लेने के लिए संशोधित किया गया है:

$ man python | python words.py
The disabled comma-separated source is using those wizards at exit.
$ cat COPYING | python words.py  #GPL
My user accord actions a gnu of software.
$ cat pg2591.txt | python words.py #Grimm's Fairy Tales 
Some bargain receives my threepence.
Any wrong worms your world.
$ cat words.py | python words.py #self reflection
Your filter_possesive not_nouned those prepositions.
$ ls /usr/bin | python words.py  #directory lists
Their dropbox funziped an arch.

कोड (संस्करण 3) :

import random
import string
import sys
import re

#words = open("/usr/share/dict/words").readlines()
words = re.sub("[]:;.,:?!<>{}()|=\"`[]",' ',sys.stdin.read(),flags=re.M).split()
words = list(set(words))

articles=('','a ','the ','some ','this ','that ','my ','any ','your ','their ',
             'all ','more '
             'an ') #an must be last
pl_articles=('','some ','those ','many ','the ','these ')
prepositions = ('of','by','to','for','from','in','with','on','which','when','at',
                     'into','as','if','near')
conjunctions = ('and','or','but')
verbs = ('is','are','was', 'be','do','came','been','had','have')
pronouns_s = ('he','she','it','we','you')
pronouns_o = ('him','her','them')

possesive=False
modifiers=0
use_prep = None

MAX_MODIFIERS=2

def is_modifier(w):
    return ("'" in w or
        w[-2:] in ('ry','ed','er','ic','al')  or
        w[-3:] in ('ing','est','ble','ous') or
        w[-4:] in ('less','ical','mmon') )

def is_verb(w):
    return (w in verbs or 
        w[-2:] in ('ed',) or
        w[-3:] in ('ing','ize') )

def is_article(w):
    return w+' ' in articles or w+' ' in pl_articles

def is_conjunction(w):
    return w in conjunctions

def filter_possesive(w,always=False): 
    global possesive
    #allow only one
    result = True if "'" in w else False
    if result:
        if always: return False
        if not possesive: 
            possesive = True
            return False
    return result

def is_preposition(w):
    global use_prep
    if w in prepositions:
        use_prep = w
        return True
    return False

def is_adverb(w):
    return w[-2:]=='ly'

def is_gerund(w):
    return w[-3:]=='ing'

def is_plural(w):
    return w[-1]=='s'

def not_verb(w):
    return (w in ('you','they','our','yes') or 
              w[-4:] in ('ness','such') or
              w in pronouns_o or w in pronouns_s
              )

def not_noun(w):
    return (w in verbs)


def getword():
    while True:
        w=words[random.randrange(len(words))].rstrip()
        if w[0] in string.ascii_uppercase: continue
        if is_article(w) or is_preposition(w):  continue
        if filter_possesive(w): continue 
        #print w
        return w

def get_article():
    return articles[random.randrange(len(articles)-1)]

#print '--s--'
substr=''
conjunction = False
while True:
    w=getword()
    if is_modifier(w):
        if modifiers < MAX_MODIFIERS:
            substr+=w+' '
            modifiers+=1
        else: continue
    elif is_adverb(w) or is_plural(w) or not_noun(w): continue
    else:
        if is_conjunction(w): 
            conjunction = w
            continue    
        substr= substr+w+' '
        if conjunction:
            substr+=conjunction+' '
            conjunction = False
            continue
        if w in pronouns_s: 
            substr = w+' '
            art=''
        else:
            art = get_article()
            if art is 'a ' and substr[0] in 'aeiou': art='an '
        substr= string.capwords(art+substr,'.')
        break

#print '--v--'
verbstr=''
while True:
    w=getword()
    if not_verb(w) or filter_possesive(w,True): continue
    elif is_adverb(w): verbstr+=w+' '
    elif is_gerund(w):
        verbstr+='is '+w+' '
        break
    elif is_verb(w):
        verbstr= verbstr+w+' '
        break
    elif is_modifier(w) or is_conjunction(w): continue
    else:
        if not is_plural(w):
            w=w+'ed' if w[-1]!='e' else w+'d'
        verbstr= verbstr+w+' '
        break

#print '--o--'
obstr=''
conjunction = False
while True:
    w=getword()
    if is_modifier(w):
        if modifiers<MAX_MODIFIERS:
            obstr+=w+' '
            modifiers+=1
        else: continue
    elif is_adverb(w) or not_noun(w) or w in pronouns_s: continue
    else:
        if is_conjunction(w): 
            conjunction = w
            continue
        obstr = obstr+w
        if conjunction:
            obstr+=' '+conjunction+' '
            conjunction = False
            continue
        if is_plural(w):
            art = pl_articles[random.randrange(len(pl_articles))] 
        else:
            art = articles[random.randrange(len(articles)-1)] 
            if art is 'a ' and obstr[0] in 'aeiou': art='an '
        if w in pronouns_o:
            obstr=w
        else:
            obstr= art+obstr
        break

#print '--p--'
while use_prep:
    w=getword()
    if (is_modifier(w) or is_preposition(w) or 
         is_gerund(w) or not_noun(w) or is_conjunction(w)):
        continue
    obstr+=' '+use_prep+' '+w
    use_prep=None

print substr+verbstr+obstr+'.'

3
उदाहरण वाक्य मुझे बहुत मुश्किल से हँसा रहे हैं, मैं रो रहा हूँ! xD
mikhailcazi

cat FILE | COMMAND? UUOC ;)
nyuszika7h

धन्यवाद @ nyuszika7h, मैंने आज कुछ सीखा है। एक आदत को तोड़ना जो पुराना हो सकता है, हालांकि ...
14

1
This smoke toasted some nonresidents.। ओह।
दर्शन

25

दे घुमा के

मतलाब जवाब से प्रेरित है। आपने मान लिया aptitudeहै।

r=$[ RANDOM % 7 ]
a=''
for i in `seq $r`; do a=$a'v'; done
if [ $r -ne 0 ]; then a='-'$a; fi
aptitude $a moo

संभव आउटपुट ( इस विकिपीडिया लेख से स्क्रीनशॉट )

यहाँ छवि विवरण दर्ज करें


7
मुझे नहीं लगता . /----\ -------/ \ / \ / | -----------------/ --------\ ----------------------------------------------कि एक वैध वाक्य है।
svick

1
@vick you winएक वाक्य हो सकता है (ऑब्जेक्ट "तर्क" निहित है)। और यहां तक ​​कि अगर यह नहीं है, तो सवाल उन मामलों से मना नहीं करता है जहां आउटपुट मान्य नहीं है।
ace_HongKongIndependence

23

अजगर:

import random
l = ['Buffalo']
while random.randint(0,5) > 0:
    l.append('buffalo')
print ' '.join(l) + '.'

नमूने:

  • भैंस की भैंस।
  • भैंस भैंस भैंस भैंस भैंस भैंस।

दुर्भाग्य से, यह कुछ हद तक विराम चिह्नों और पूंजीकरण से निपटता है, लेकिन फिर उन आवश्यकताओं के रूप में सूचीबद्ध नहीं किया गया था।

इसके अलावा, यहां एक संदर्भ है।


3
भैंस के शाब्दिक अर्थों में स्थान न जोड़ें; इसके बजाय उपयोग करें ' '.join(l)। कि ट्रेलिंग स्थान से छुटकारा मिल जाएगा। फिर आप केवल एक अवधि जोड़ सकते हैं।
ब्लैकलाइट उदय

@ ब्लेकलाइटिंग अपडेट किया गया। सलाह के लिये धन्यवाद।
8bittree

आपका स्वागत है। और भैंस के लिए +1। :)
ब्लैकलाइट उदय


1
Itertools के साथ व्यक्त किया ,print " ".join(takewhile(lambda _: randint(0, 5), repeat("buffalo"))).capitalize() + "."
nmclean

16

जंग + टोकी पोना

किसी भी भाषा को स्वीकार किया जाता है, इसलिए मैंने रस्ट में एक कार्यक्रम लिखा जो टोकी पोना में कुछ वाक्य उत्पन्न करता है ।

टोकी पोना एक न्यूनतम प्राकृतिक भाषा बनाने का एक प्रयास है, और इसमें एक सुपर सरल और नियमित व्याकरण है। यह इस प्रतियोगिता के लिए एक बहुत ही उपयोगी संपत्ति है!

use std::rand;

#[deriving(Rand)]
struct Phrase { a: Option<~GNominal>, b: ~Sujet, c: ~Predicat }

#[deriving(Rand)]
enum Sujet { A(~GNominal), B(~SCompose) }

#[deriving(Rand)]
enum Predicat { C(~GVerbal), D(~PCompose) }

#[deriving(Rand)]
struct SCompose { a: ~Sujet, b: ~Sujet }

#[deriving(Rand)]
struct PCompose { a: ~Predicat, b: ~Predicat }

#[deriving(Rand)]
struct GNominal { a: ~nom::Nom, b: Multi<~adjectif::Adjectif> }

#[deriving(Rand)]
struct GVerbal { a: ~verbe::Verbe, b: Multi<~adjectif::Adjectif>, c: Multi<~ODirect> }

#[deriving(Rand)]
struct ODirect { a: ~GNominal}

#[deriving(Rand)]
enum Multi<T> { Zero, One(T), Two((T,T)) }

mod nom {
    #[deriving(Rand)]
    #[deriving(ToStr)]
    pub enum Nom {akesi,ala,ale,anpa,ante,ijo,ike,ilo,insa,jaki,jan,jo,kala,kalama,kama,kasi,ken,kili,kiwen,ko,kon,kule,kulupu,lape,lawa,len,lete,linja,lipu,luka,lupa,ma,mama,mani,meli,mi,mije,moku,moli,monsi,mun,musi,mute,nanpa,nasin,nena,nimi,noka,oko,olin,ona,pakala,pali,palisa,pana,pilin,pimeja,pini,pipi,poka,poki,pona,seli,selo,sewi,sijelo,sike,sina,sinpin,sitelen,sona,soweli,suli,suno,supa,suwi,tan,tawa,telo,tenpo,toki,tomo,tu,unpa,uta,utala,walo,wan,waso,wawa,weka,wile}
}

mod verbe {
    #[deriving(Rand)]
    #[deriving(ToStr)]
    pub enum Verbe {ante,awen,ijo,ike,jaki,jan,jo,kalama,kama,ken,kepeken,kule,kute,lape,lawa,lete,lili,lon,lukin,moku,moli,musi,mute,nasa,olin,open,pakala,pali,pana,pilin,pimeja,pini,pona,seli,sin,sitelen,sona,suli,suwi,tawa,telo,toki,tu,unpa,utala,wan,wawa,weka,wile,}
}

mod adjectif {
    #[deriving(Rand)]
    #[deriving(ToStr)]
    pub enum Adjectif {ala,ale,anpa,ante,awen,ike,insa,jaki,jan,jelo,kama,kin,kiwen,kon,kule,kute,kulupu,lape,laso,lawa,lete,lili,linja,loje,luka,lukin,mama,meli,mi,mije,moli,monsi,mun,musi,mute,nasa,ni,olin,ona,pali,pimeja,pini,poka,pona,sama,seli,sewi,sike,sin,sina,suli,suwi,taso,tawa,toki,tomo,unpa,uta,walo,wan,wawa,weka,wile,}
}

impl ToStr for Phrase {
    fn to_str(&self) -> ~str {
        self.a.as_ref().map_or(~"", |g| format!("{:s} la ", g.to_str()))
        + format!("{:s} li {:s}", self.b.to_str(), self.c.to_str())
    }
}

impl ToStr for Sujet {
    fn to_str(&self) -> ~str {
        match *self {
            A(ref v) => v.to_str(),
            B(ref v) => v.to_str(),
        }
    }
}

impl ToStr for Predicat {
    fn to_str(&self) -> ~str {
        match *self {
            C(ref v) => v.to_str(),
            D(ref v) => v.to_str(),
        }
    }
}

impl ToStr for SCompose {
    fn to_str(&self) -> ~str {
        format!("{:s} en {:s}", self.a.to_str(), self.b.to_str())
    }
}

impl ToStr for PCompose {
    fn to_str(&self) -> ~str {
        format!("{:s} li {:s}", self.a.to_str(), self.b.to_str())
    }
}

impl ToStr for GNominal {
    fn to_str(&self) -> ~str {
        format!("{:s} {:s}", self.a.to_str(), self.b.to_str())
    }
}

impl ToStr for GVerbal {
    fn to_str(&self) -> ~str {
        format!("{:s} {:s} {:s}", self.a.to_str(), self.b.to_str(), self.c.to_str())
    }
}

impl ToStr for ODirect {
    fn to_str(&self) -> ~str {
        format!("e {:s}", self.a.to_str())
    }
}

impl<T: ToStr> ToStr for Multi<~T> {
    fn to_str(&self) -> ~str {
        match *self {
            Zero => ~"",
            One(ref v) => v.to_str(),
            Two((ref v,ref w)) => format!("{:s} {:s}", v.to_str(), w.to_str()),
        }
    }
}

fn main() {
    let phrase = rand::random::<Phrase>();
    println!("{:s}\n{:?}", phrase.to_str(), phrase);
}

मैं टोकी पोना नहीं बोलता, लेकिन मुझे विकीपीडिया पर बीएनएफ के नियमों के एक सेट के रूप में टोकी पोना का वाक्य विन्यास मिला । मैंने प्रत्येक बीएनएफ नियम के लिए एक संरचना या एनम बनाया, और मैंने उन्हें एनोटेट किया deriving(Rand), जो मुझे Phraseमुफ्त में एक यादृच्छिक संरचना उत्पन्न करने का एक तरीका देता है ! फिर, मैंने ToStrइनमें से प्रत्येक संरचना को एक स्ट्रिंग में बदलने के लिए लागू किया।

मैं जानबूझकर फ्रेंच में नाम छोड़ देता हूं, क्योंकि मुझे मिला बीएनएफ नियम फ्रेंच में है, और यह भी क्योंकि यह मेरे प्रस्तुत करने की बहुभाषी प्रकृति को पुष्ट करता है!

नमूना आउटपुट

कुछ आउटपुट और उनके अनुवाद, जो मैंने बीएनएफ नियमों और एक टोकी पोना शब्दकोश पर आधारित थे । मुझे यकीन है कि ये अनुवाद अधिकतर गलत हैं, लेकिन टोकी पोना वास्तव में एक वाक्य की व्याख्या के लिए बहुत जगह छोड़ता है।

नासिन मील तवा ला जान ली जाकी

मेरी यात्रा के दौरान, किसी ने प्रदूषित किया

मोनसी ली जाकी ली जान इक मुसी

बट गंदा है और एक मजाकिया बुरा व्यक्ति है

सिना ली तवा एले जेलो ई किली तवा ई इंसा

आपने फल और केंद्र को पीले ब्रह्मांड में स्थानांतरित कर दिया

मुद्दे

  • मैं जाँच नहीं करता कि एक क्रिया सकर्मक है या नहीं, इस प्रकार कुछ वाक्य व्याकरणिक रूप से गलत हैं।
  • कुछ संरचनाएं पुनरावर्ती हैं, और जब एक नियम दोहराया जा सकता है तो मैं यादृच्छिक रूप से आउटपुट 0, 1 या 2 तत्वों का चयन कर सकता हूं। यह लंबे समय से उत्पन्न वाक्यों के कारण हो सकता है, जिसमें हजारों शब्द होंगे ...
  • मैं वास्तव में आउटपुट की वैधता को सत्यापित नहीं कर सकता, मैं पूरी तरह से बीएनएफ सिंटैक्स, शब्दकोश, और मेरे अपने जंगली अनुमानों पर भरोसा करता हूं :)

1
sina li tawa ale jelo e kili tawa e insa == "आपने फल और केंद्र को पीले ब्रह्मांड में स्थानांतरित कर दिया" एक मशीन के लिए बहुत अच्छा है, आमतौर पर केवल उन्नत tp उपयोगकर्ता परिवर्तनकारी निर्माणों का उपयोग कर सकते हैं।
मैथ्मार्टिन

1
monsi li jaki li jan ike musi == बट (गधा? जर्क में?) गंदा है और मजाकिया स्वभाव का व्यक्ति है।
मैथ्मार्टिन

1
अरे आपकी टिप्पणी के लिए धन्यवाद, @ मट्टीमार्टिन! मुझे निश्चित रूप से एक टोकी पोना स्पीकर से मेरे सबमिशन को देखने की उम्मीद नहीं थी, लेकिन मुझे यह जानकर खुशी हुई कि ये सेंटीबल्स पूरी तरह से अस्पष्ट नहीं हैं :)
barjak

सुझाव: यह एक कोड गोल्फ नहीं है।
nyuszika7h

1
@ nyuszika7h मुझे यकीन नहीं है कि आपकी टिप्पणी का उद्देश्य क्या है। वास्तव में, यह एक कोड गोल्फ नहीं है, क्योंकि यह एक लोकप्रियता प्रतियोगिता है।
बराज

14

अजगर

import this


The Zen of Python, by Tim Peters

Beautiful is better than ugly.
Explicit is better than implicit.
Simple is better than complex.
Complex is better than complicated.
Flat is better than nested.
Sparse is better than dense.
Readability counts.
Special cases aren't special enough to break the rules.
Although practicality beats purity.
Errors should never pass silently.
Unless explicitly silenced.
In the face of ambiguity, refuse the temptation to guess.
There should be one-- and preferably only one --obvious way to do it.
Although that way may not be obvious at first unless you're Dutch.
Now is better than never.
Although never is often better than *right* now.
If the implementation is hard to explain, it's a bad idea.
If the implementation is easy to explain, it may be a good idea.
Namespaces are one honking great idea -- let's do more of those!

7
क्या आप तर्क दे सकते हैं कि import antigravityआउटपुट की ओर जाता है I LEARNED IT LAST NIGHT! EVERYTHING IS SO SIMPLE!? : D
ace_HongKongInd डिपेंडेंस

निस्संदेह, हाँ।
रेने लिडर

14

Prolog

सभी संभावित वाक्यों को उत्पन्न करने के लिए प्रोलॉग की बैकट्रैकिंग और अंग्रेजी व्याकरण का एक सामान्य व्याकरण का उपयोग करें ।

इस संस्करण में काफी सीमित शब्दावली और वाक्य संरचना है, लेकिन इसका विस्तार करना बहुत आसान होना चाहिए।

कोड:

% Define the vocabulary
verb(V) :- V = 'eats' | V = 'fights' | V = 'finds'.
subj_pronoun(P) :- P = 'he' | P = 'she' | P = 'it'.
obj_pronoun(P) :- P = 'him' | P = 'her' | P = 'it'.
name(N) :- N = 'alice' | N = 'bob'.
noun(N) :- N = 'cat' | N = 'door' | N = 'pen'.
article(H) :- H = 'the' | H = 'a'.

% Grammar
subject_phrase_short(H) :- subj_pronoun(H)
                         | name(H).
% Subordinate clause. Don't use verb_phrase here to avoid recursive clauses.
sub_clause([Which, Verb|T], Rest) :- Which = 'which', verb(Verb),
                                     object_noun_phrase_short(T, Rest).
subject_phrase([H|T], Rest) :- subject_phrase_short(H), Rest = T.
object_noun_phrase_short([A, N | T], Rest) :- article(A), noun(N), Rest = T
                                            | obj_pronoun(A), Rest = [N|T].
object_phrase(L, Rest) :- object_noun_phrase_short(L, Rest)
                        | object_noun_phrase_short(L, Rest1), sub_clause(Rest1, Rest).
verb_phrase([H|T], Rest) :- verb(H), object_phrase(T, Rest).
sentence(S) :- subject_phrase(S, Rest), verb_phrase(Rest, []).

यह क्वेरी चलाएँ:

sentence(L).

इस भाषा में सभी संभव वाक्य उत्पन्न करने के लिए।

कुछ नमूना आउटपुट:

L = [he, eats, the, cat] ;
L = [she, finds, a, door] ;
L = [alice, fights, the, door] ;
L = [he, fights, the, cat, which, eats, the, pen] ;
L = [alice, eats, him, which, finds, the, cat] ;

(संपादित करें: ऑब्जेक्ट अधीनस्थ खंड अनुमति दें)।


1
कोई उदाहरण वाक्य आउटपुट?
TheDoctor

हाँ, मैंने उत्तर में कुछ नमूने रखे हैं। यह कुल 2520 आउटपुट उत्पन्न करता है, हालांकि मैं उन सभी को पोस्ट नहीं कर सकता ...
chrisd

11

अजगर

जैसा कि आप जानते हैं, आप कुछ importएस के साथ अजगर में कुछ भी कर सकते हैं । यह सरल कार्य इस 2 पंक्तियों पायथन स्क्रिप्ट के साथ पूरा किया जा सकता है।

import random

print ("I like the number "+str(random.uniform(0,1)))

इस लिपि से उत्पन्न वाक्यों की संख्या बहुत बड़ी है: 10^12विभिन्न वाक्य। यदि एक सेंटीस पढ़ने में आपको ~ 0.5 सेकंड लगते हैं, तो उन सभी को पढ़ने में 15000 से अधिक साल लगेंगे!

कुछ नमूना वाक्य:

  • I like the number 0.444371877853
  • I like the number 0.358614422548

फिर भी सभी उत्पन्न वाक्यों में एक विषय, एक क्रिया और एक वस्तु होती है।

अपडेट करें:

मुझे कुछ परिष्कृत शब्दों के बारे में कुछ आलोचनात्मक शब्द मिले जो इस जटिल उपकरण का उत्पादन कर सकते हैं। यहां थोड़ा लंबा संस्करण है जो अधिकांश शब्दकारों के साथ अनुबंध में होना चाहिए।

import random

print ('I like the number'+''.join([' '+{'0':'zero','.':'point','1':'one','2':'two','3':'three','4':'four','5':'five','6':'six','7':'seven','8':'eight','9':'nine'}[digit] for digit in str(random.uniform(0,1))])+'.')

यहाँ कुछ नमूना वाक्य हैं:

  • I like the number zero point six three five nine zero eight one five eight four two four.
  • I like the number zero point four nine zero eight four four three two zero six two seven.

मैं अपने कुछ शब्दों को अपने शब्दकोश में ढूंढने में असफल रहा
डॉ। बेलिसरियस

5
मैंने आपके सॉफ़्टवेयर को आपके खराब शब्दकोश को बेहतर ढंग से फिट करने के लिए समायोजित किया है।
एंटोनियो रागैगिन

2
ठीक। 15000 वर्षों में मैं यह प्रमाणित करने के लिए पोस्ट करूँगा कि मैंने उन सभी को पाया है
डॉ। बेलिसरियस

10

गणित के आंतरिक शब्दकोश के साथ खेलना:

res = {};
SeedRandom[42 + 1];
Do[
  (While[
    If[(c = Flatten@WordData[RandomChoice[WordData[All]], "Examples"][[All, 2]]) != {},
     StringPosition[(c1 = RandomChoice@c), "'" | "-" | "\\" | "`"] != {}, True, True]];
   sp = ToLowerCase /@ StringSplit[c1, (WhitespaceCharacter .. | ",")];
   toChange = RandomSample[Range@#, RandomInteger[IntegerPart[{#/2, #}]]] &@Length@sp;
   If[StringPosition[ToString@WordData[sp[[#]], "Definitions"],  "WordData"] == {}, 
    sp[[#]] = RandomChoice@ WordData[All, RandomChoice@WordData[sp[[#]], "PartsOfSpeech"]]]
             & /@ toChange;
   AppendTo[res, StringJoin@Riffle[sp, " "]];)
  ,
  {10}];
res

आप भाग्यशाली हैं, कहते हैं, समय का 70%। यह इस तरह की चीजें उत्पन्न करता है:

एक amygdaloid विद्युत परिपथ
उधर Parkia था unrestrictive हालांकि प्रचंड
उसकी longanimous समाज
शिक्षा अस्पष्ट जबाब डॉक्टर कीबुत्स में
जूलियस सीजर के खिलाफ थोड़ा संगीत थियेटर
एक ताई नाटहेच
niggardliness विपरीत तेरा विनोदी केंद्र में नीचे घास काटना
आवश्यक बाह्य डिटर्जेंट
बिना जादू का जादूगर
मेरा latria विपरीत इन रग वक्षपेशी ट्रॉफी पत्नी ट्रेंड-सेटिंग निवेशक भूरा
क्या आग के आदमी-पोर्टेबल क्षेत्र
आकर्षक रूप से जहां मेरे जवाब में
एक और पेंच-ढीला मलबे का तूफान, सुगंधित असाल अरल सागर जटिल वफ़ल के
लिए प्रोफाइंड हैप्पी मंगोलोइड प्रकार धातु

लेकिन कभी - कभी:

मेरी गोद लेने की कम से कम लुट्ज़ेन की लड़ाई क्लीवर
नौ हेज़र सबडक्शन जीनस सेयूरस के दिलों की धड़कन के दौरान हिजिरा को अपने दर्शकों के दिलों में नगद आकर्षित करेगा

ओह ठीक है, अंग्रेजी का उपयोग मेरा से बेहतर है।


8

VBA / एक्सेल

[संपादित करें 2]

क्रियाओं को संयुग्मित करने का तरीका सिखाया है, नीचे दिए गए उदाहरण सरल भूत काल हैं:

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

प्रासंगिक कोड इस प्रकार है, बोरिंग सहायक पार्सिंग और लूपिंग कार्यों के एक समूह को छोड़कर। गायब होने वाले मुख्य भाग विभिन्न शब्द सूचियाँ (भाषण के कुछ भाग) हैं जो बहुवचन, काल, संयुग्मन आदि करते हैं।

सभी मूल शब्द बेतरतीब ढंग से उठाए गए हैं, लेकिन मैं उन्हें एक विशेष वाक्य पैटर्न में व्यवस्थित करने के लिए मजबूर करता हूं:

Debug.Print getWords("ad adj adj nns vpa1s pl ad adj adj nns")

... जो मैं ऊपर उत्पादन उत्पन्न करने के लिए इस्तेमाल किया है। यह सामान्य रूप का अनुसरण करता है, "तेज लाल लोमड़ी आलसी भूरे कुत्ते पर कूद गई।"

Function getWords(strStruc As String) As String
    Dim i As Long
    Dim s As Long
    Dim strIn As String
    Dim strOut As String

    getWords = ""
    s = numElements(strStruc)
    For i = 1 To s
        strIn = parsePattern(strStruc, i)
        Select Case strIn
            Case ",", ";", ":", """" 'punctuation
                strOut = strIn
                getWords = Trim(getWords)
            Case "ai", "ad" 'indefinite article, definite article
                strOut = getArticle(strIn)
            Case "adj" 'adjective
                strOut = getWord("adj", 1)
            Case "nns" 'noun nominative singular
                strOut = getWord("n", 1)
            Case "nnp" 'noun nominative plural
                strOut = getWord("n", 2)
            Case "nps" 'noun posessive singular
                strOut = getWord("n", 3)
            Case "npp" 'noun posessive plural
                strOut = getWord("n", 4)
            Case "vpr1s" 'Present 1st Person Singular
                strOut = getWord("v", 1)
            Case "vpr2s" 'Present 2nd Person Singular
                strOut = getWord("v", 2)
            Case "vpr3s" 'Present 3rd Person Singular
                strOut = getWord("v", 3)
            Case "vi" 'Infinitive
                strOut = getWord("v", 4)
            Case "vpp" 'Present Participle
                strOut = getWord("v", 5)
            Case "vi" 'Imperative/Subjunctive
                strOut = getWord("v", 6)
            Case "vpa1s" 'Past Tense First Person
                strOut = getWord("v", 7)
            Case "vpa2s" 'Past Tense Second Person
                strOut = getWord("v", 8)
            Case "vpa3s" 'Past Tense Third Person
                strOut = getWord("v", 9)
            Case "vppr1s" 'Present Progressive First Person Singular
                strOut = getWord("v", 10)
            Case "vppr2s" 'Present Progressive Second Person Singular
                strOut = getWord("v", 11)
            Case "vppr3s" 'Present Progressive Third Person Singular
                strOut = getWord("v", 12)
            Case "vppe1s" 'Present Perfect First Person Singular
                strOut = getWord("v", 13)
            Case "vppe2s" 'Present Perfect Second Person Singular
                strOut = getWord("v", 14)
            Case "vpp3s" 'Present Perfect Third Person Singular
                strOut = getWord("v", 15)
            Case "vi1s" 'Imperfect First Person Singular
                strOut = getWord("v", 16)
            Case "vi2s" 'Imperfect Second Person Singular
                strOut = getWord("v", 17)
            Case "v13s" 'Imperfect Third Person Singular
                strOut = getWord("v", 18)
            Case "vsf" 'Simple Future
                strOut = getWord("v", 19)
            Case "vfp" 'Future Progressive
                strOut = getWord("v", 20)
            Case "vc" 'Conditional
                strOut = getWord("v", 21)
            Case "vcp" 'Conditional Perfect
                strOut = getWord("v", 22)
            Case "vci" 'Conditional Imperfect
                strOut = getWord("v", 23)
            Case "pl" 'location prepositions
                strOut = getWord("pl", 1)
        End Select
        getWords = getWords & strOut & " "
    Next i
End Function

[मूल पोस्ट शुरू करें]

अभी भी एक कार्य प्रगति पर है, काल और संज्ञा / क्रिया बहुवचन के लिए तर्क जोड़ने की आवश्यकता है, अर्थात:

आपकी औसत यात्रा हमारे लिए आवश्यक खुराक है और न ही मेरे टमाटर से परे तापमान में वृद्धि।

... जो पार्स करने योग्य है, लेकिन इसका कोई मतलब नहीं है।

प्रोग्रामिंग उनके गंदे मछुआरे को हमारे पोर्क कास्ट के बजाय किसी वाक्य के लिए सक्षम बनाता है।

सही। वास्तव में एक वाक्य नहीं है, लेकिन कुछ जावास्क्रिप्ट त्रुटि संदेशों से बेहतर है।

उनकी अपील हर जीवित सवाल को उठाती है कि मेरी महिला ने अपनी अंग्रेजी की रूपरेखा बनाई।

सहज दिनचर्या लगभग शीर्ष पर है '...

अनु का पालन करने के लिए कोड। क्या इस प्रतियोगिता की कोई समय सीमा है?

[1 संपादित करें]

कोड जो ऊपर उत्पन्न हुआ।

Function getWord(sht As Worksheet) As String
    Dim i As Long
    Dim freq As Long
    Dim c As Long
    Dim f As Double
    Dim fSum As Double

    c = 4
    fSum = WorksheetFunction.Count(sht.Columns(c))
    f = Rnd() * fSum
    i = 2
    Do
        If i >= f Then Exit Do
        i = i + 1
    Loop
    getWord = sht.Cells(i, 1).Value
End Function
Function PCase(str As String) As String
    PCase = UCase(Left(str, 1)) & Right(str, Len(str) - 1)
End Function
Sub doMakeSentences01()
    Dim shtIn As Worksheet
    Dim shtOut As Worksheet
    Dim strSheet As String
    Dim rIn As Long
    Dim rOut As Long
    Dim cFreq As Long
    Dim c As Long
    Dim strPattern As String
    Dim w As Long
    Dim strOut As String
    Dim strIn As String
    Dim strWord As String

    cFreq = 4
    Set shtOut = Sheets("Output")
    rOut = shtOut.Range("A65536").End(xlUp).Row + 1

    strPattern = "anvajncanvian"
    For rOut = rOut To rOut + 1000
        strOut = ""
        For w = 1 To Len(strPattern)
            Set shtIn = Sheets(Mid(strPattern, w, 1))
            strWord = getWord(shtIn)
            If w = 1 Then strWord = PCase(strWord)
            strOut = strOut & strWord & " "
        Next w
        strOut = Trim(strOut) & "."
        shtOut.Cells(rOut, 1).Value = strOut
    Next rOut
End Sub

5
आपका कोड कहां है?
ace_HongKongIndependence

कोड के लिए मेरा संपादन देखें।
ब्रैंडन आर। गेट्स

6

पर्ल ५

ठीक है, कार्यक्रम की हिम्मत बस यही है:

use v5.14;
my %pad = (
    ...
);
sub pad { shift =~ s(\{(.+?)\}){pad($pad{$1}[rand(@{$pad{$1}})])}rogue }
say ucfirst pad '{START}';

यह मूल रूप से एक "मैडलिब" इंजन है। वास्तव में दिलचस्प वाक्य उत्पन्न करने के लिए, आपको %padकुछ डेटा के साथ आबाद करने की आवश्यकता है । यहाँ एक उदाहरण है %pad...

my %pad = (
  START => ['{complex}.'],
  complex => [
    '{simple}',
    '{simple}, and {simple}',
    '{simple}, and {complex}',
    '{simple}, but {simple}',
    '{simple}, yet {simple}',
    'even though everybody knows {simple}, {simple}',
    'not only {simple}, but also {simple}',
  ],
  simple => [
    '{thing} {verb}s {thing}',
    '{thing} {verb}s {adverb}',
    '{thing} is {adjective}',
    '{things} {verb} {thing}',
    '{things} {verb} {adverb}',
    '{things} are {adjective}',
    '{thing} {past_verb} {thing}',
    '{things} {past_verb} {thing}',
  ],
  thing => [
    'the {adjective} gorilla',
    'the {adjective} mailbox',
    'Archbishop Desmond Tutu',
    'the beef salad sandwich',
    'the {adjective} stegosaur',
    'the summit of Mt Everest',
    'Chuck Norris',
    'the cast of television\'s "Glee"',
    'a {adjective} chocolate cake',
  ],
  things => [
    '{adjective} shoes',
    'spider webs',
    'millions of {adjective} eels',
    '{adjective} children',
    '{adjective} monkeys',
    '{things} and {things}',
    'the British crown jewels',
  ],
  verb => [
    'love',
    'hate',
    'eat',
    'drink',
    'follow',
    'worship',
    'respect',
    'reject',
    'welcome',
    'jump',
    'resemble',
    'grow',
    'encourage',
    'capture',
    'fascinate',
  ],
  past_verb => [  # too irregular to derive from {verb}
    'loved',
    'ate',
    'followed',
    'worshipped',
    'welcomed',
    'jumped',
    'made love to',
    'melted',
  ],
  adverb => [
    'greedily',
    'punctually',
    'noisily',
    'gladly',
    'regularly',
  ],
  adjective => [
    'enormous',
    'tiny',
    'haunted',
    'ghostly',
    'sparkling',
    'highly-decorated',
    'foul-smelling',
    '{adjective} (yet {adjective})',
    'expensive',
    'yellow',
    'green',
    'lilac',
    'tall',
    'short',
  ],
);

यहां मैंने उस ज्ञान के कुछ नमूने लिए हैं जो मैंने उससे खोजे हैं %pad। इन वाक्यों को लंबाई, विराम चिह्न, व्याकरण, आदि के लिए संपादित नहीं किया गया है, हालांकि मैंने कुछ निर्बाध लोगों को लिया है और उस क्रम को फिर से व्यवस्थित किया है जिसमें वाक्य दिखाई देते हैं - वे अब उस क्रम में नहीं हैं जो वे उत्पन्न हुए थे, लेकिन इसके बजाय वे प्रयास कर रहे थे उन्हें एक कहानी बताने के लिए उपयोग करें: एक कहानी जो मुझे आशा है कि आपको छूने और सोचने वाले दोनों मिल जाएगी।

  • मकड़ी के जाले कम होते हैं।
  • मकड़ी के जाले नियमित रूप से मोहित करते हैं।
  • लघु बंदर स्पार्कलिंग हैं, लेकिन मकड़ी के जाले लालच से पीते हैं।
  • स्पार्कलिंग (अभी तक दुर्गंधपूर्ण) बंदरों ने छोटे (अभी तक स्पार्कलिंग) गोरिल्ला का अनुसरण किया।
  • माउंट एवरेस्ट के शिखर पर अत्यधिक सजाए गए स्टीगोसॉर का स्वागत किया।
  • न केवल माउंट एवरेस्ट का शिखर महंगा है, बल्कि टेलीविजन के "उल्लास" के कलाकारों ने शानदार गोरिल्ला का अनुसरण किया।
  • टेलीविजन के "उल्लास" के कलाकार बकाइन मेलबॉक्स से मिलते जुलते हैं।
  • महंगा मेलबॉक्स लंबा है, और महंगा स्टीगोसॉर चक नॉरिस को कूदता है, फिर भी हरे रंग के जूते बीफ सलाद सैंडविच को कूदते हैं।
  • बीफ़ सलाद सैंडविच चक नॉरिस को पसंद करता था।
  • लाखों स्पार्कलिंग ईल हरे (अभी तक भूतिया) हैं।

अब अगर आप पैड को प्रोग्रामिक रूप से पॉप्युलेट कर सकते हैं
प्योरफ्रेट

पैड को प्रोग्रामिक रूप से पॉपुलेट करना ज्यादा चुनौती नहीं है। बस विकिपीडिया या कुछ और परिमार्जन करें। हालांकि इस तरह के मजेदार वाक्य नहीं मिलेंगे।
tobyink

यह बहुत ज्यादा चुनौती नहीं है, लेकिन मुझे लगता है कि यह इसका एक मजेदार हिस्सा है।
शुद्ध

5

म एस वर्ड

मुझे यकीन नहीं है कि यह स्वीकार्य है, लेकिन चूंकि html है, मुझे लगता है कि यह भी स्वीकार्य होना चाहिए।

 =rand(1,1)

नमूना वाक्य:

सम्मिलित करें टैब पर, दीर्घाओं में वे आइटम शामिल हैं जो आपके दस्तावेज़ के समग्र रूप के साथ समन्वय करने के लिए डिज़ाइन किए गए हैं।

आप इन दीर्घाओं का उपयोग टेबल, हेडर, फुटर, सूचियाँ, कवर पृष्ठ और अन्य दस्तावेज़ निर्माण ब्लॉकों को सम्मिलित करने के लिए कर सकते हैं।

आप किसी भी वाक्य और पैराग्राफ को निर्दिष्ट कर सकते हैं।


4

JSoup और simpleNLG का उपयोग करते हुए प्रगति पर एक काम

import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;

import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;

import simplenlg.framework.NLGFactory;
import simplenlg.lexicon.Lexicon;
import simplenlg.phrasespec.SPhraseSpec;
import simplenlg.realiser.english.Realiser;

/**
 * Scapes words from Wiktionary then assembles them into sentences
 * 
 * @author pureferret
 *
 */
public class SentenceBuilder {
    static ArrayList<String> ListOfWordTypes= new ArrayList<>(Arrays.asList("Noun","Verb","Adjective","Adverb","Proper noun","Conjunction"));
    private static String RandomWiktWord ="http://toolserver.org/~hippietrail/randompage.fcgi?langname=English";  
    /**
     * @param args
     */
    public static void main(String[] args) {
        Lexicon lexicon = Lexicon.getDefaultLexicon();
        NLGFactory nlgFactory = new NLGFactory(lexicon);
        Realiser realiser = new Realiser(lexicon);

        ArrayList<String> nounList = new ArrayList<String>();
        ArrayList<String> verbList = new ArrayList<String>();
        ArrayList<String> adjeList = new ArrayList<String>();
        ArrayList<String> adveList = new ArrayList<String>();
        ArrayList<String> pnouList = new ArrayList<String>();
        ArrayList<String> conjList = new ArrayList<String>();


        String word= null;
        String wordType = null;

        try {
            newDoc:
            while( nounList.size()<1 ||
                    verbList.size()<1 ||
//                  adjeList.size()<2 ||
//                  adveList.size()<2 ||
                    pnouList.size()<1){
                Document doc = Jsoup.connect(RandomWiktWord).get();
                Element bodyElem = doc.body();
                word = bodyElem.select("h1>span[dir=auto]").get(0).ownText();
                int wtIdx = 0;
                while(wtIdx<bodyElem.select("div#mw-content-text span.mw-headline").size()){
                    wordType = bodyElem.select("div#mw-content-text span.mw-headline").get(wtIdx).id()
                            .replace("_", " ");
                    wtIdx++;
                    switch (wordType) {
                    case "Proper noun":
                        pnouList.add(word);
                        continue newDoc;
                    case "Noun":
                        nounList.add(word);
                        continue newDoc;
                    case "Verb":
                        verbList.add(word);
                        continue newDoc;
                    case "Adjective":
                        adjeList.add(word);
                        continue newDoc;
                    case "Adverb":
                        adveList.add(word);
                        continue newDoc;
                    case "Conjunction":
                        conjList .add(word);
                        continue newDoc;
                    default:
                        break;
                    }
                }
            }
                SPhraseSpec p = nlgFactory.createClause();
                p.setSubject(pnouList.get(0));
                p.setVerb(verbList.get(0));
                p.setObject(nounList.get(0));

                String output2 = realiser.realiseSentence(p); // Realiser created earlier.
                System.out.println(output2);

        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            System.err.println(word + " is a " + wordType);
        } catch (IndexOutOfBoundsException e) {
            e.printStackTrace();
            System.err.println(word + " is a " + wordType);
        }
    }

}

मुद्दे:

  • वाक्य बहुत सरल हैं
  • कभी-कभी 404s (अच्छी हैंडलिंग के बिना!)
  • केवल एक बार में एक वाक्य उत्पन्न करता है
  • स्विच केस का उपयोग करता है!

नमूना आउटपुट:

पॉपोलोका धावक बीन्स को चुभता है।
मकर राशि का ट्रॉपिक, चोली को मुस्कराता है।
बीजिंग ने तकिया बक्से को पर्यायवाची बना दिया।
चुचियों को प्रभावित करने वाले अतिक्रमण।


3

पीएचपी

<?php
  $trends = file_get_contents('http://www.google.com/trends/hottrends/widget?pn=p1&tn=30');
  preg_match_all("/widget-title-in-list'>(.+?)</", $trends, $m);

  $q = urlencode($m[1][array_rand($m[1])]);
  $page = file_get_contents("http://www.google.com/search?q=$q&btnI=1");
  preg_match_all('/[A-Z]([\w,]+ ){2,}[\w, ]+?[.!]/', strip_tags($page), $m);

  echo $m[0][array_rand($m[0])];

यह 30 सबसे अधिक ट्रेंडिंग Google खोजों को प्राप्त करता है, "I Feel Lucky" खोज करता है, और फिर उस पृष्ठ से कम से कम 3 शब्दों के साथ एक यादृच्छिक वाक्य प्रदर्शित करता है।

उदाहरण:

"उन्हें इस आयोजन में एक पदक पसंदीदा माना जाता था।"

"केट ने एक साल पहले हाई स्कूल से स्नातक किया।"

"15 अप्रैल 2014, जीवित लोगों की जीवनियों पर नीति के अनुपालन को बढ़ावा देने के लिए।"

"ब्रायन की ओर से, हम, उनका परिवार, प्यार, प्रार्थना और समर्थन के लिए सभी को धन्यवाद देना चाहते हैं।"

"यह लेख अमेरिकी बास्केटबॉल खिलाड़ी के बारे में है।"

"क्षमा करें, आपके ब्राउज़र में जावास्क्रिप्ट अक्षम है या कोई समर्थित खिलाड़ी नहीं है।"


3

पायथन 2.7

python2.7 -c "import urllib2, pprint; pprint.pprint([str(x[:x.find('<')]) for x in unicode(urllib2.urlopen('http://codegolf.stackexchange.com/questions/21571/generate-an-understandable-sentence').read(), 'utf8').split('<p>') if x.find('<') >= 1][1].split('.')[0])"

उत्पादन:

एक ऐसा वाक्य तैयार करें जिसे पढ़ा और समझा जा सके


स्टैक एक्सचेंज के साझाकरण यूआरआई (जैसे के /q/21571बजाय /questions/21571/generate-an-understandable-sentence) का उपयोग करें।
ब्लैकलाइट उदय

2
चूंकि यह कोड गोल्फ नहीं है, इसलिए पठनीयता के लिए लाइन ब्रेक अच्छा होगा।
nyuszika7h

2

शेल स्क्रिप्टिंग

यह स्क्रिप्ट हमेशा पहले प्रश्न के शीर्षक को प्रदर्शित करेगी जो इस साइट के शीर्ष पर है। मेरी धारणा प्रश्न शीर्षक हमेशा मानव पठनीय होगा। और यह गतिशील रूप से बदल जाएगा। इसलिए जब भी कोई नया प्रश्न आता है और जब स्क्रिप्ट निष्पादित होती है, तो यह नवीनतम प्रश्न शीर्षक देगा।

curl "codegolf.stackexchange.com" -s |  w3m -dump -T text/html > foo.txt
awk 'f;/more tags/{f=1}' foo.txt > foo1.txt
sed '8q;d' foo1.txt

परीक्षण 1 आउटपुट

Find words containing every vowel

परीक्षण 2 उत्पादन

Hello World 0.0!

संपादित करें

किसी भी फाइल का उपयोग नहीं कर रहा है। फ़ाइलों के बिना, मैं नीचे दी गई स्क्रिप्ट का उपयोग कर सकता हूं।

value1=$(curl "codegolf.stackexchange.com" -s |  w3m -dump -T text/html)
echo "$value1" | grep -A 8 "more tags" | tail -1

उत्पादन

Generate an understandable sentence

1
न ही उन्हें सीधे एक फ़ाइल से पढ़ा जा रहा है ...
rafaelcastrocouto

मैंने फ़ाइल का उपयोग न करने के लिए बदलाव किए हैं। अब, यह केवल चर का उपयोग करता है। इसके बारे में क्या खयाल है?
रमेश

2
वोट हटा दिया!
राफेलकास्ट्रोकोटो

2

जावास्क्रिप्ट (ES6)

var t='';for(f of [_=>foo,_=>null.a,_=>0..toString(0)])try{f()}catch(e){t+=e.message+'\n';}t

कंसोल में इसे चलाने से उत्पादन होता है

foo is not defined
null has no properties
radix must be an integer at least 2 and no greater than 36

इससे भी छोटा:t='';for(f of [_=>foo,_=>null.a,_=>0..toString(0)])try{f()}catch(e){t+=e.message+'\n'}t
टूथब्रश

2

फिर भी एक और पायथन लिपि

User3058846 के जवाब में बुरा नहीं है, लेकिन यह हर वाक्य, हर बार प्रदर्शित करता है। यहाँ, मैं एक स्क्रिप्ट प्रस्तावित करता हूँ जो पायथन के ज़ेन से एक यादृच्छिक वाक्य का उत्पादन करती है :

from random import choice
import subprocess
proc = subprocess.Popen(('python', '-c', 'import this'), stdout=subprocess.PIPE,)
# Get output of proc, split by newline
sentences = [x for x in proc.communicate()[0].splitlines() if x != '']
print(choice(sentences))

एक पंक्ति में, प्रशंसकों के लिए:

from random import choice;import subprocess;print(choice([x for x in subprocess.Popen("python -c 'import this'",shell=True,stdout=subprocess.PIPE).communicate()[0].split('\n') if x]))

(बूहोह, गंदा।)

उदाहरण:

>>> a()  # <--- a is just the oneline above
Explicit is better than implicit.
>>> a() 
Although never is often better than *right* now.
>>> a() 
Errors should never pass silently.
>>> a() 
Special cases aren't special enough to break the rules.


पायथन में एक और मजेदार तरीका

@TheDoctor के विचार के लिए धन्यवाद :-) आयात आउटपुट को शांत करें और फिर मॉड्यूल में छद्म-एन्क्रिप्टेड तानाशाह के साथ खेलें।

import sys, random 
_stdout, sys.stdout = sys.stdout, open('/tmp/trash', 'w')  # silent the stdout just for the import
import this
sys.stdout = _stdout
lst = []
for x in this.s:
    if x in this.d:
        lst.append(this.d[x])
    else:
        lst.append(x)

# Then, example from the interpreter
>>> random.choice(''.join(lst).split('\n'))
'Beautiful is better than ugly.'
>>> random.choice(''.join(lst).split('\n'))
'Although never is often better than *right* now.'
>>>

यह आमतौर पर उपयोग करने के लिए बुरा अभ्यास है shell=True। यद्यपि यह इस मामले में असुरक्षित नहीं है, क्योंकि आप उपयोगकर्ता इनपुट नहीं ले रहे हैं, मैं इसका विकल्प चुनूंगा subprocess.Popen(('python', '-c', 'import this'))
nyuszika7h

क्या आप जानते हैं कि क्या आप कविता को चुप कर सकते हैं import this, मॉड्यूल में एक चर thisहै जिसमें सभी पाठ शामिल हैं, लेकिन एन्क्रिप्टेड। इसे डिक्रिप्ट करने के लिए एक शब्दकोश भी है।
TheDoctor

1
@ TheDoctor मेरा अद्यतन जवाब देखें: D
मैक्सिमे

1

अजगर ३

व्याकरणिक उत्पादन उत्पन्न करने की गारंटी! (आमतौर पर।)

import re
from urllib.request import urlopen
from random import random, choice as pick

letters = "abcdefghijklmnopqrstuvwxyz"
wordregex = re.compile(r'a href="/wiki/([a-z_]+)"')
subjects = {1:("I","we"), 2:("you",), 3:("they",)}
objects = {1:("me","us"), 2:("you",), 3:("him","her","it","them")}
patterns = ["{0} {1} {2}.",
            "Why do {0} {1} {2}?",
            "It's because {0} {1} {2}, of course.",
            "Did {0} {1} {2}?",
            "{0} will not {1} {2}!",
            ]

wiktionaryurl = "http://en.wiktionary.org/w/index.php?" + \
              "title=Category:English_{0}&pagefrom={1}"

def getWord(category):
    subset = pick(letters) + pick(letters)
    url = wiktionaryurl.format(category, subset)
    try:
        response = urlopen(url)
    except:
        print("An error occurred while connecting to the Internet!")
        return "fail"
    page = str(response.read())
    word = pick(wordregex.findall(page))
    word = word.replace("_", " ")
    return word

for i in range(10):
    verb = getWord("transitive_verbs")
    subjPerson = pick([1,2,3])
    subj = pick(subjects[subjPerson])
    if random() > 0.4:
        # Use a plural noun for the object
        obj = getWord("plurals")
    else:
        # Use a pronoun for the object
        objPerson = pick([1,2,3])
        while subjPerson == objPerson and subjPerson in (1,2):
            objPerson = pick([1,2,3])
        obj = pick(objects[objPerson])
    sentence = pick(patterns).format(subj, verb, obj)
    sentence = sentence[0].upper() + sentence[1:]
    print(sentence)

इसे पूरी तरह से व्याकरणिक बनाने के लिए, अंडरस्कोर को हटा दें wordregex। यह बहु-शब्द प्रविष्टियों को ख़राब कर देगा, जो "हम आपको झटकते हैं" जैसे बुरे वाक्यों को जन्म देते हैं।

नमूना रन:

We appropriate journals.
I will not masticate you!
Did you lower me?
Why do I sag estoppels?
They will not proofread you!
It's because you unbeguile mucosae, of course.
Why do I flack zakuski?
You will not visit junkpiles!
Did they goat us?
Why do we prefix nolids?

अब तक का पसंदीदा उत्पादन:

They you her.

यह देखो अप: http://en.wiktionary.org/wiki/you#Verb


0

अजगर

नतीजा:

$ python mksentence.py
infringement lecture attainment
Produce more? (Y/N)y
impeachment recoup ornament
Produce more? (Y/N)y
maladjustment edit discouragement
Produce more? (Y/N)y
embellishment guest punishment
Produce more? (Y/N)y
settlement section escapement
Produce more? (Y/N)y
segment withhold recruitment
Produce more? (Y/N)

मैंने यहाँ से शब्द सूची का उपयोग किया है प्रत्येक स्वर वाले शब्द खोजें

कुछ और नियम जोड़े जा सकते हैं। उदाहरण के लिए, यदि "नेस" के साथ समाप्त होने वाला शब्द और शब्द भी प्रत्यय के बिना सेट में मौजूद है, तो यह एक संज्ञा है।

सोर्स कोड:

#!/usr/bin/env python
# vim: set fileencoding=utf-8 ts=4 sw=4 tw=72 :

from __future__ import (unicode_literals, absolute_import,
                        division, print_function)

import random                     

if __name__ == "__main__":        
    filename = 'corncob_lowercase.txt'
    noun = set()
    verb = set()
    whole_words_set = {word.rstrip() for word in open(filename)}

    for word in whole_words_set:
        if word.endswith('ment'):
            noun.add(word)
        elif word.endswith('ing'):
            if word[:-3] in whole_words_set:
                verb.add(word[:-3])
            elif word[:-3]+"e" in whole_words_set:
                verb.add(word[:-3]+"e")
    noun_list = list(noun)
    verb_list = list(verb)
    while True:                   
        sentence = "%s %s %s" % (random.choice(noun_list),
                                 random.choice(verb_list),
                                 random.choice(noun_list))                                                                                           
        print(sentence)
        if input("Produce more? (Y/N)").lower() == "n":
            break

3
क्या मैं वास्तव में पायथन और अंग्रेजी में चूसता हूं, या आप 2 संज्ञा और एक क्रिया के बजाय 3 संज्ञा का उत्पादन कर रहे हैं?
ace_HongKongIndependence

@ ऑप्स, मैंने आखिरी मिनट में कोड तय करने का फैसला किया :-(
यिंग

0

दे घुमा के

एक प्रोग्राम चलाने की कोशिश करना जो मौजूद है, लेकिन स्थापित नहीं है यह देता है (लिनक्स टकसाल 13 में)।

$ say
The program 'say' is currently not installed.  To run 'say' please ask your administrator to install the package 'gnustep-gui-runtime'

विभिन्न विकृतियों में, यह आपको एक अलग वाक्य देता है।
TheDoctor

इसलिए मैंने LM13 में कहा
user80551

0

अजगर ३

मैक्सिम के जवाब से प्रेरित होकर द ज़ेन ऑफ़ पाइथन में एक और लिया गया ।

import codecs
import os
import sys
import random

stdout = sys.stdout
sys.stdout = open(os.devnull, 'r+')

import this

sys.stdout.close()
sys.stdout = stdout

zen = codecs.decode(this.s, 'rot-13').splitlines()

print(random.choice(zen))

0
var vocab={
    noun:{
        tp:{
            singular:["Mike","Chan","Karl","Mithun","Debasish","Kamal","Group","Crowd","He","She"],
            plural:["They"],
        },
        fp:{
            singular:["I"],
            plural:["We"]
        },
        sp:{
            singular:["You"],
            plural:["You"]
        }

    },
    verbIndicator:{
        tp:{
            present:{
                singular:["is"],
                plural:["are"]
            },
            past:{
                singular:["was"],
                plural:["were"]
            }
        },
        fp:{
            present:{
                singular:["am"],
                plural:["are"]
            },
            past:{
                singular:["was"],
                plural:["were"]
            }
        },
        sp:{
            present:{
                singular:["are"],
                plural:["are"]
            },
            past:{
                singular:["were"],
                plural:["were"]
            }
        }
    },
    verb:{
        continuous:{
            consumer:["having"],
            performer:["doing","playing","watching"]
        },
        simple:{
            consumer:["had"],
            performer:["did","played","watched"]
        }
    },
    dependentAction:{
        consumer:["food","fun","badtime"],
        performer:["movie","cricket","song","dance"]
    },
    independentAction:["Cooking","Playing","singing"],
    adjective:["good","bad","excellent","awesome"],
    object:["boy","Person","girl","Human being","Man","Mental"]
}

var referenceBook={
    figure:["fp","sp","tp"],
    time:["present","past"],
    singularity:["singular","plural"],
    verState:{
        present:["continuous"],
        past:["continuous","simple"]
    },
    objectRole:["consumer","performer"]
};

function getTerm(term) {
    var cur = referenceBook[term] || [];
    var randomIndex = Math.ceil((Math.random() * 93967)) % cur.length;
    return cur[randomIndex]

}
function getToken(key) {
    var path = key.split("-");
    var token = vocab;
    path.forEach(function(s) {
        token = token[s];
   });

    return token[Math.ceil((Math.random() * 1000)) % token.length];

}

function generateSentence(rules) {
    rules.forEach(function(str) {
        var m = str.match(/{[^}]*}/g)

        var variable = {};
        if (m) {
            m.forEach(function(s) {
                s = s.replace(/(^{)|(}$)/g, "");
                variable[s] = getTerm(s);
            });

            for (var each in variable) {
                str = str.replace(new RegExp("{" + each + "}", 'g'), variable[each]);

            }
        }
        var cur = str.split("|");
        var sentence = "";
        cur.forEach(function(s) {
            sentence += " " + getToken(s);

        })
        console.log(sentence);

    })


};
/*

In the rules array, I specify rules for the sentence to be genrated

*/

var rules = [
    "noun-{figure}-{singularity}|verbIndicator-{figure}-{time}-{singularity}|verb-continuous-{objectRole}|dependentAction-{objectRole}", 
    "noun-sp-singular|adjective|object"
];

generateSentence(rules);

4
कृपया बताएं कि यह कौन सी भाषा है।
रोडोल्फो डायस

1
@RodolfoDias मुझे पूरा यकीन है कि यह जावास्क्रिप्ट है ... हालांकि निश्चित नहीं है।
TheDoctor
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.