• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-341  評(píng)論-2670  文章-0  trackbacks-0
                這幾天一直在忙學(xué)校的比賽,到了今天終于有空了。

                Lazy Script的語(yǔ)法實(shí)在是很復(fù)雜,因此不得不在進(jìn)行第一步的名字檢查之后把原本的語(yǔ)言轉(zhuǎn)換為內(nèi)部使用的一種元語(yǔ)言。這種元語(yǔ)言設(shè)計(jì)的原則是盡量簡(jiǎn)單。譬如[y|y<-xs , y<x]這樣的語(yǔ)法和do-end語(yǔ)句就需要被轉(zhuǎn)換掉。進(jìn)行了轉(zhuǎn)換以后,就需要對(duì)元語(yǔ)言進(jìn)行一個(gè)類型方程組的建立。這一步暫時(shí)還沒有建模好,而且實(shí)際工作需不需要真的構(gòu)造出一組方程組還不知道。目前還比較沒有頭緒的就是如何對(duì)模板函數(shù)的類型方程建模。

                舉個(gè)例子,譬如我們對(duì)上一篇文章中提到的代碼進(jìn)行類型方程組的構(gòu)造:
            1 makelist num list = if (num<=0)
            2     list
            3     (makelist (num-1) ([num]++list));

                我們找到的已定義名稱有:
                ·(<=) :: Int -> Int -> Bool | Float -> Float -> Bool
                ·if :: Bool -> T -> T -> T
                ·(++) :: [T] -> [T] -> [T]
                ·(-) :: Int -> Int -> Int | Float -> Float -> Float
                ·0 :: Int
                ·1 :: Int

                為上面的程序建立方程組,我們可以得到:
                T(makelist) T(num) T(list) =
                (Bool -> T0 -> T0 -> T0)
                    ((<=)::(Int -> Int -> Bool | Float -> Float -> Bool) T(num) Int)
                    T(list)
                    (T(makelist)
                        ((-)::(Int -> Int -> Int | Float -> Float -> Float) T(num) Int)
                        ((++)::([T1] -> [T1] -> [T1]) [T(num)] T(list))
                    )

                對(duì)上面的函數(shù)調(diào)用類型進(jìn)行進(jìn)一步的推導(dǎo),我們可以得到:
                Bool = (<=)::(Int -> Int -> Bool | Float -> Float -> Bool) T(num) Int
                T0 = T(list)
                T0 = T(makelist)  ((Int -> Int -> Int | Float -> Float -> Float) T(num) Int) ((++)::([T1] -> [T1] -> [T1]) [T(num)] T(list))
                T(makelist) T(num) T(list) = T0

                緊接著繼續(xù)推導(dǎo),我們有:
                (<=)::(Int -> Int -> Bool | Float -> Float -> Bool) T(num) = Int
                (-)::((Int -> Int -> Int | Float -> Float -> Float) T(num) = Int
                [T1] = [T(num)]
                [T1] = T(list)

                根據(jù)上面的式子我們可以得到:
                T(num)=Int
                T1=Int
                T(list)=[Int]
                (++)::[Int] -> [Int] -> [Int]
                (<=)::Int -> Int -> Bool
                (-):: Int -> Int -> Int
                T0 = [Int]
                if :: Bool -> [Int] -> [Int]
                makelist :: [Int] -> [Int] -> [Int]

                至于如何為上面的整個(gè)過(guò)程建模,還得在這幾天內(nèi)想出辦法來(lái)。現(xiàn)在唯一知道的就是,構(gòu)造一個(gè)類型方程組需要確定解的名字,然后求解。解還有若干種,譬如確定解,模板解等等。具體細(xì)節(jié)還需要繼續(xù)斟酌。
            posted on 2008-04-27 10:16 陳梓瀚(vczh) 閱讀(2133) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Vczh Lazy Script
            日韩乱码人妻无码中文字幕久久| 国产99久久九九精品无码| 天堂无码久久综合东京热| 亚洲国产精品成人AV无码久久综合影院 | 久久精品国产亚洲Aⅴ蜜臀色欲| 久久无码国产| 亚洲精品无码久久千人斩| 一级做a爰片久久毛片人呢| 无码精品久久一区二区三区| 日本久久久久亚洲中字幕| 久久精品视频91| 久久不射电影网| 亚洲色大成网站www久久九| 热久久这里只有精品| 亚洲AV成人无码久久精品老人| 久久er热视频在这里精品| 99久久精品国产一区二区 | 久久av免费天堂小草播放| 亚洲香蕉网久久综合影视| 久久精品免费网站网| 国产精品久久网| 亚洲人成伊人成综合网久久久| 久久婷婷五月综合色99啪ak| 国产精品无码久久久久| 亚洲国产精品成人久久| 国产精品亚洲综合久久| 蜜桃麻豆www久久国产精品| 伊人久久综在合线亚洲2019 | 国产精品美女久久福利网站| 久久精品国产清自在天天线| 国产亚洲精久久久久久无码AV| 97久久精品午夜一区二区| 精品国产乱码久久久久久郑州公司| 亚洲乱码日产精品a级毛片久久| 国产精品成人久久久久三级午夜电影| 久久91亚洲人成电影网站| 777午夜精品久久av蜜臀| 久久青青色综合| 亚洲精品乱码久久久久久蜜桃图片| 人妻无码αv中文字幕久久琪琪布| 久久免费观看视频|