FOSD оригами - FOSD origami

Ерекшелікке бағытталған бағдарламалау немесе Бағдарламалық жасақтаманың ерекшелігі (FOSD) үшін жалпы парадигма болып табылады бағдарламалық синтез бағдарламалық өнім желілерінде. Өтінемін Ерекшелікке бағытталған бағдарламалау доменнің FOSD моделі 0-ary функцияларының кортежі (мәндер деп аталады) және функциялар деп аталатын 1-ary (unary) функциясының жиынтығы болып табылатындығын түсіндіретін бет. Бұл парақта күрделі бағдарламалардың ықшам сипаттамалары үшін маңызды FOSD модельдерінің көпөлшемді жалпыламалары талқыланады.

Оригами

Метамодельдерді іргелі жалпылау болып табылады оригами.Маңызды идея - бағдарлама дизайны бір ғана өрнекпен ұсынылмауы керек; бірнеше өрнектерді қолдануға болады.[1][2][3] Бұл GenVoca-ның бірнеше ортогоналды модельдерін қолдануды қамтиды.

Мысал: T құрал моделі болсын, оның P (талдау), H (жинау), D (доклет) және J (Java-ға аудару) ерекшеліктері бар. P - мән, ал қалғандары - унар-функциялар. Java диалект тілінде жазылған файлды талдап, оны таза Java-ға аударатын T1 құралы модельденеді: T1 = J • P. Ал javadoc тәрізді T2 құралы файлды Java диалектісінде талдайды, түсініктемелер жинайды және жиналған пікірлерді HTML парағына аударады: T2 = D • H • P. Сонымен, T1 және T2 құралдары T өнімнің қатарына жатады.
L тілдік моделі Java диалектілерінің отбасын (өнім желісін) сипаттайды. Оған мүмкіндіктер кіреді: B (Java 1.4), G (генериктер), S (мемлекеттік машиналар). B - мән, ал қалғандары - унарлы функциялар. Сонымен, генерикасы бар Java L1 диалектісі (яғни, Java 1.5): L1 = G • B. Мемлекеттік машиналар үшін тілдік қолдауға ие Java L2 диалектісі: L2 = S • B. Сонымен L1 және L2 диалектілері L-дің өнімі қатарына жатады.
Java диалектіне арналған javadoc тәрізді құралды (E) мемлекеттік машиналармен сипаттау үшін екі өрнек қажет: E (T моделін қолдану) және оның Java диалектісі (L моделін қолдану) үшін құралдың функционалдығын анықтайтын:
  E = D • H • P - құрал теңдеуі E = S • B - тілдік теңдеу
L және T модельдері - GenVoca-ның ортогоналды модельдері: бірі E құралының ерекшеліктеріне негізделген құрылымын, ал екіншісі оның кіру тілінің ерекшеліктеріне негізделген құрылымын білдіреді. T және L модельдерінің шын мәнінде екенін ескеріңіз реферат келесі мағынада: Т-дің кез-келген ерекшелігінің орындалуы шынымен де құралдың диалектісіне байланысты (L арқылы өрнектелген), ал (симметриялы) L-дің кез-келген ерекшелігінің орындалуы шынымен де құралдың функционалдылығына байланысты (T-мен көрсетілген). Демек, Е-ді жүзеге асырудың жалғыз жолы - бұл T және L теңдеулерін білу.

U = [U. Болсын1, U2, ..., Un] GenVoca моделі болуы керек n, және W = [W1, ... Wм] m ерекшеліктерінің GenVoca моделі болуы керек. U және W екі ортогоналды модельдер арасындағы қатынас U деп аталатын UW матрицасы болып табыладыОригами матрицасы, мұндағы әр қайсысы U функциясымен, ал әрбір баған W. функциясымен сәйкес келеді. UW жазбасыиж жүзеге асыратын функция болып табыладытіркесім U ерекшеліктерімен және В.j.

Ескерту: UW тензор өнімі U және W (яғни UW = U × W).
    
Мысал. T = [P, H, D, J] және L = [B, G, S] модельдерін еске түсіріңіз. Origami матрицасы TL:
    
мұндағы PB - Java үшін талдаушыны іске асыратын мән, PG - генераторларды талдауға арналған Java талдаушысын кеңейтетін унитарлы функция, ал PS - күй машинасының сипаттамаларын талдауға арналған Java талдаушысын кеңейтетін унитарлы функция. HB - Java кодына түсініктемелер жинау машинасын іске асыратын унитарлы функция. HG - жалпы код бойынша түсініктемелер жинау машинасын жүзеге асыратын униарлы функция, ал HS - мемлекеттік машинаның техникалық сипаттамалары бойынша түсініктемелер жинау машинасын іске асыратын униарлы функция және т.б.

Бағдарламаны синтездеу үшін бірнеше теңдеулердің қалай қолданылатынын көру үшін U және W модельдерін қайта қарастырыңыз. F бағдарламасы екі теңдеумен сипатталады, бір модельге. Біз F үшін теңдеуді екі түрлі жолмен жаза аламыз: сипаттамаларға атаулары немесе олардың индекстері бойынша сілтеме жасау, мысалы:

    —F-тің U өрнегі - F өрнегі

UW моделі U және W модельдерінің қалай іске асырылатынын анықтайды. F бағдарламасын синтездеу қажет емес бағандар мен жолдардан UW проекциялауды және жинақтауды (а.а.) қамтиды. тензорлық жиырылу ):

    

Оригами матрицаларының негізгі қасиеті деп аталады ортогоналдылық, өлшемдердің жиырылу реті маңызды емес. Жоғарыда келтірілген теңдеуде алдымен U өлшемі (i индексі) немесе W өлшемі (j индексі) бойынша қорытынды жасау маңызды емес. Әрине, ортогоналдылық - бұл тексерілуі керек қасиет. Оригами матрицаларының (немесе тензорлар / n-өлшемді массивтердің) ортогоналды екендігін тексеру үшін тиімді (сызықтық) алгоритмдер жасалды.[4] Ортогоналдылықтың маңыздылығы - көзқарастардың бірізділігі. Белгілі бір өлшем бойынша жинақтау (келісімшарт) бағдарламаның «көрінісін» ұсынады. Әр түрлі көзқарастар сәйкес келуі керек: егер біреу бағдарламаның кодын бір көріністе жөндейтін болса (немесе бағдарлама туралы қасиеттерді бір көріністе дәлелдейтін болса), сол түзетулердің немесе қасиеттердің дұрыстығына барлық көріністер сәйкес келуі керек.

Жалпы алғанда, өнім сызығының көбейтіндісі n өрнегімен ұсынылуы мүмкін, n-ден ортогоналды және реферат GenVoca модельдері G1 ... Г.n. Origamimatrix (немесе куб немесе тензор) n өлшемді A жиымы:

     

Осы өнім сызығының H көбейтіндісі А-дан қажет емес жолдарды, бағандарды және т.б. жою және n-кубты скалярға біріктіру (жиыру) арқылы құрылады:

    
Мысал. E бағдарламасын және T = [P, H, D, J] моделін еске түсіріңіз. E = D • H • P = T2• Т1• Т0. Сол сияқты, L = [B, G, S] моделіндегі E-нің көрінісі E = S • B = L2• Л.0. TL берілген Origami моделін синтездеу келесі өрнекті бағалайды: .

Қолданбалар

Origami көмегімен жасалған бірнеше өнімге арналған қосымшалар бар. Олардың қатарына:

Жеткізілетін басқа қосымшалар.

Сондай-ақ қараңыз

Әдебиеттер тізімі

  1. ^ «Өнім шығаратын линиялар - отбасылар» (PDF).
  2. ^ «Нақтылау және алаңдаушылықты көп өлшемді бөлу» (PDF).
  3. ^ «Модульизацияның жетілдірілген технологияларындағы мүмкіндіктерге қолдауды бағалау» (PDF).
  4. ^ «Көпөлшемді бағдарламалық құрылымдарды жобалау және талдау» (PDF).