亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? yacaspatternpredicatebase.java

?? 計算機代數系統
?? JAVA
字號:
package net.sf.yacas;/// \file /// Pattern matching code.////// General idea: have a class that can match function parameters/// to a pattern, check for predicates on the arguments, and return/// whether there was a match.////// First the pattern is mapped onto the arguments. Then local variables/// are set. Then the predicates are called. If they all return true,/// Then the pattern matches, and the locals can stay (the body is expected/// to use these variables).import java.util.*;/// Class that matches function arguments to a pattern./// This class (specifically, the Matches() member function) can match/// function parameters to a pattern, check for predicates on the/// arguments, and return whether there was a match.class YacasPatternPredicateBase {  /// Constructor.  /// \param aEnvironment the underlying Lisp environment  /// \param aPattern Lisp expression containing the pattern  /// \param aPostPredicate Lisp expression containing the  /// postpredicate  ///  /// The function MakePatternMatcher() is called for every argument  /// in \a aPattern, and the resulting pattern matchers are  /// collected in #iParamMatchers. Additionally, \a aPostPredicate  /// is copied, and the copy is added to #iPredicates.  public YacasPatternPredicateBase(LispEnvironment  aEnvironment,                            LispPtr  aPattern,                            LispPtr  aPostPredicate) throws Exception  {    LispIterator iter = new LispIterator(aPattern);        while (iter.GetObject() != null)    {        YacasParamMatcherBase matcher = MakeParamMatcher(aEnvironment,iter.GetObject());        LispError.LISPASSERT(matcher!=null);        iParamMatchers.add(matcher);        iter.GoNext();    }    LispPtr  post = new LispPtr();    post.Set(aPostPredicate.Get());    iPredicates.add(post);  }  /// Try to match the pattern against \a aArguments.  /// First, every argument in \a aArguments is matched against the  /// corresponding YacasParamMatcherBase in #iParamMatches. If any  /// match fails, Matches() returns false. Otherwise, a temporary  /// LispLocalFrame is constructed, then SetPatternVariables() and  /// CheckPredicates() are called, and then the LispLocalFrame is  /// immediately deleted. If CheckPredicates() returns false, this  /// function also returns false. Otherwise, SetPatternVariables()  /// is called again, but now in the current LispLocalFrame, and  /// this function returns true.   public boolean Matches(LispEnvironment  aEnvironment, LispPtr  aArguments) throws Exception  {    int i;    LispPtr[]  arguments = null;    if (iVariables.size() > 0)    {        arguments = new LispPtr[iVariables.size()];        for (i=0;i<iVariables.size();i++)        {          arguments[i] = new LispPtr();        }          }    LispIterator iter = new LispIterator(aArguments);    for (i=0;i<iParamMatchers.size();i++)    {        if (iter.GetObject() == null)            return false;        LispPtr  ptr = iter.Ptr();        if (ptr==null)            return false;        if (!((YacasParamMatcherBase)iParamMatchers.get(i)).ArgumentMatches(aEnvironment,ptr,arguments))        {            return false;        }        iter.GoNext();    }    if (iter.GetObject() != null)        return false;    {        // set the local variables.        aEnvironment.PushLocalFrame(false);        try        {          SetPatternVariables(aEnvironment,arguments);          // do the predicates          if (!CheckPredicates(aEnvironment))              return false;        }        catch (Exception e)        {          throw e;        }        finally        {          aEnvironment.PopLocalFrame();        }    }    // set the local variables for sure now    SetPatternVariables(aEnvironment,arguments);        return true;  }  /// Try to match the pattern against \a aArguments.  /// This function does the same as Matches(LispEnvironment ,LispPtr ),   /// but differs in the type of the arguments.  boolean Matches(LispEnvironment  aEnvironment, LispPtr[]  aArguments) throws Exception  {    int i;    LispPtr[]  arguments = null;    if (iVariables.size() > 0)        arguments = new LispPtr[iVariables.size()];    for (i=0;i<iVariables.size();i++)    {      arguments[i] = new LispPtr();    }    for (i=0;i<iParamMatchers.size();i++)    {        if (!((YacasParamMatcherBase)iParamMatchers.get(i)).ArgumentMatches(aEnvironment,aArguments[i],arguments))        {            return false;        }    }    {        // set the local variables.        aEnvironment.PushLocalFrame(false);        try        {          SetPatternVariables(aEnvironment,arguments);          // do the predicates          if (!CheckPredicates(aEnvironment))              return false;        }        catch (Exception e)        {          throw e;        }        finally        {          aEnvironment.PopLocalFrame();        }    }    // set the local variables for sure now    SetPatternVariables(aEnvironment,arguments);    return true;  }  /// Construct a pattern matcher out of a Lisp expression.  /// The result of this function depends on the value of \a aPattern:    /// - If \a aPattern is a number, the corresponding MatchNumber is  ///   constructed and returned.  /// - If \a aPattern is an atom, the corresponding MatchAtom is  ///   constructed and returned.  /// - If \a aPattern is a list of the form <tt>( _ var )<tt>,  ///   where \c var is an atom, LookUp() is called on \c var. Then  ///   the correspoding MatchVariable is constructed and returned.  /// - If \a aPattern is a list of the form <tt>( _ var expr )<tt>,  ///   where \c var is an atom, LookUp() is called on \c var. Then,  ///   \a expr is appended to #iPredicates. Finally, the  ///   correspoding MatchVariable is constructed and returned.   /// - If \a aPattern is a list of another form, this function  ///   calls itself on any of the entries in this list. The  ///   resulting YacasParamMatcherBase objects are collected in a  ///   MatchSubList, which is returned.  /// - Otherwise, this function returns #null.  protected YacasParamMatcherBase MakeParamMatcher(LispEnvironment  aEnvironment, LispObject aPattern) throws Exception  {    if (aPattern == null)        return null;    if (aPattern.Number(aEnvironment.Precision()) != null)    {        return new MatchNumber(aPattern.Number(aEnvironment.Precision()));    }    // Deal with atoms    if (aPattern.String() != null)    {        return new MatchAtom(aPattern.String());    }    // Else it must be a sublist    if (aPattern.SubList() != null)    {        // See if it is a variable template:        LispPtr  sublist = aPattern.SubList();        LispError.LISPASSERT(sublist != null);        int num = LispStandard.InternalListLength(sublist);        // variable matcher here...        if (num>1)        {            LispObject head = sublist.Get();            if (head.String() == aEnvironment.HashTable().LookUp("_"))            {                LispObject second = head.Next().Get();                if (second.String() != null)                {                    int index = LookUp(second.String());                    // Make a predicate for the type, if needed                    if (num>2)                    {                        LispPtr third = new LispPtr();                        LispObject predicate = second.Next().Get();                        if (predicate.SubList() != null)                        {                            LispStandard.InternalFlatCopy(third, predicate.SubList());                        }                        else                        {                            third.Set(second.Next().Get().Copy(false));                        }                        String str = second.String();                        LispObject last = third.Get();                        while (last.Next().Get() != null)                            last = last.Next().Get();                                                last.Next().Set(LispAtom.New(aEnvironment,str));                        LispPtr pred = new LispPtr();                        pred.Set(LispSubList.New(third.Get()));                        iPredicates.add(pred);                    }                    return new MatchVariable(index);                }            }        }                YacasParamMatcherBase[] matchers = new YacasParamMatcherBase[num];        int i;        LispIterator iter = new LispIterator(sublist);        for (i=0;i<num;i++)        {            matchers[i] = MakeParamMatcher(aEnvironment,iter.GetObject());            LispError.LISPASSERT(matchers[i] != null);            iter.GoNext();        }        return new MatchSubList(matchers, num);    }        return null;  }  /// Look up a variable name in #iVariables  /// \returns index in #iVariables array where \a aVariable  /// appears.  ///  /// If \a aVariable is not in #iVariables, it is added.  protected int LookUp(String aVariable)  {    int i;    for (i=0;i<iVariables.size();i++)    {        if (iVariables.get(i) == aVariable)        {            return i;        }    }    iVariables.add(aVariable);    return iVariables.size()-1;  }  /// Set local variables corresponding to the pattern variables.  /// This function goes through the #iVariables array. A local  /// variable is made for every entry in the array, and the  /// corresponding argument is assigned to it.  protected void SetPatternVariables(LispEnvironment  aEnvironment, LispPtr[]  arguments) throws Exception  {    int i;    for (i=0;i<iVariables.size();i++)    {        // set the variable to the new value        aEnvironment.NewLocal((String)iVariables.get(i),arguments[i].Get());    }  }  /// Check whether all predicates are true.  /// This function goes through all predicates in #iPredicates, and  /// evaluates them. It returns #false if at least one  /// of these results IsFalse(). An error is raised if any result  /// neither IsTrue() nor IsFalse().  protected boolean CheckPredicates(LispEnvironment  aEnvironment) throws Exception  {    int i;    for (i=0;i<iPredicates.size();i++)    {        LispPtr pred = new LispPtr();        aEnvironment.iEvaluator.Eval(aEnvironment, pred, ((LispPtr)iPredicates.get(i)));        if (LispStandard.IsFalse(aEnvironment, pred))        {            return false;        }        LispError.Check(LispStandard.IsTrue(aEnvironment, pred), LispError.KLispErrNonBooleanPredicateInPattern);    }    //hier    return true;  }  /// List of parameter matches, one for every parameter.  protected ArrayList iParamMatchers = new ArrayList(); //CDeletingArrayGrower<YacasParamMatcherBase*> iParamMatchers;  /// List of variables appearing in the pattern.  protected ArrayList iVariables = new ArrayList(); //CArrayGrower<String>   /// List of predicates which need to be true for a match.  protected ArrayList iPredicates = new ArrayList(); //CDeletingArrayGrower<LispPtr[] >}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩国产精品91| 欧美亚洲国产bt| 一区二区三区精品在线| 久久久久青草大香线综合精品| 日韩一级黄色大片| 欧美丰满少妇xxxxx高潮对白| 欧美日韩黄色影视| 欧美老肥妇做.爰bbww视频| 久久精品亚洲一区二区三区浴池| 国产精品色一区二区三区| 国产日韩高清在线| 中文字幕亚洲电影| 亚洲激情第一区| 日韩精品1区2区3区| 蜜桃精品在线观看| 国模大尺度一区二区三区| 国产成a人无v码亚洲福利| 99在线视频精品| 一本久久a久久精品亚洲| 色婷婷久久久久swag精品| 欧美精品一区二区三区一线天视频| 欧美国产乱子伦| 亚洲男人的天堂av| 日韩激情在线观看| 欧美亚洲一区二区在线观看| 国产亚洲福利社区一区| 国内精品写真在线观看| 欧美一激情一区二区三区| 午夜久久福利影院| 国产成人免费视频网站 | 2020国产成人综合网| 国产精品区一区二区三区| 国产一区在线观看麻豆| 色欲综合视频天天天| 日韩久久一区二区| 麻豆成人91精品二区三区| 欧美三级韩国三级日本一级| 亚洲国产精品v| 国产不卡免费视频| 中文字幕欧美日韩一区| 成人丝袜18视频在线观看| 欧美日韩亚洲综合一区| 婷婷久久综合九色国产成人| 欧美一区二区三区在线视频| 亚洲免费观看在线观看| 日本高清不卡aⅴ免费网站| 欧美精品一区二区三区视频| 国产精品亚洲一区二区三区在线| 欧美日韩国产高清一区二区三区| 无码av中文一区二区三区桃花岛| 日韩三级精品电影久久久| 久久99国内精品| 777奇米四色成人影色区| 日本一区二区三区在线不卡| av电影一区二区| 亚洲一区二区三区四区的 | 色综合天天综合网天天看片| 久久久久国产精品免费免费搜索| av不卡在线播放| 亚洲国产aⅴ天堂久久| 91久久精品一区二区三区| 亚洲精品乱码久久久久久| 4438x亚洲最大成人网| 国产一区二区美女| 亚洲男人的天堂在线观看| 日韩一区国产二区欧美三区| 丁香天五香天堂综合| 亚洲自拍偷拍九九九| 精品欧美一区二区三区精品久久| 香蕉成人啪国产精品视频综合网| 欧美午夜在线一二页| 九九**精品视频免费播放| 一区二区中文字幕在线| 欧美男男青年gay1069videost| 国产馆精品极品| 亚洲国产色一区| 国产人妖乱国产精品人妖| 欧美日韩国产乱码电影| 国产传媒欧美日韩成人| 亚洲高清中文字幕| 中文字幕第一区综合| 欧美肥妇bbw| 欧美一区二区福利在线| 国产福利91精品一区| 天堂久久久久va久久久久| 国产视频一区二区在线观看| 91精品欧美久久久久久动漫| av亚洲精华国产精华| 精品一区二区三区视频在线观看| 亚洲国产精品一区二区尤物区| 亚洲精品一区二区三区在线观看 | 精品久久久久久久久久久久包黑料 | 夜夜精品视频一区二区| 久久综合给合久久狠狠狠97色69| 欧美日韩精品欧美日韩精品一| 成人动漫一区二区三区| 国产精品灌醉下药二区| 日本韩国欧美一区| 国产福利精品导航| 蜜臀av一区二区在线观看| 亚洲国产精品一区二区www在线| 亚洲国产成人午夜在线一区| 久久色在线视频| 欧美成人三级在线| 欧美在线三级电影| 奇米影视7777精品一区二区| 欧美国产精品久久| 亚洲精品在线电影| 日韩欧美国产一区在线观看| 成人国产精品视频| 国产成人综合精品三级| 久久99久久久欧美国产| 亚洲视频免费在线观看| 国产精品无人区| 国产欧美一区二区精品性色超碰| 精品国产不卡一区二区三区| 精品国产一区二区国模嫣然| 欧美va亚洲va在线观看蝴蝶网| 日韩欧美中文字幕一区| 91精选在线观看| 欧美一级欧美一级在线播放| 欧美一区二区三区思思人 | 色综合网色综合| 色国产精品一区在线观看| 91亚洲精品乱码久久久久久蜜桃 | 日韩三级在线免费观看| 欧美一区二区三区播放老司机| 3d动漫精品啪啪一区二区竹菊| 欧美另类z0zxhd电影| 在线不卡一区二区| 日韩欧美一区二区免费| 久久亚洲一级片| 国产精品入口麻豆原神| 亚洲精品乱码久久久久久| 爽好久久久欧美精品| 91日韩精品一区| 日本福利一区二区| 884aa四虎影成人精品一区| 精品va天堂亚洲国产| 欧美韩国日本不卡| 亚洲欧美视频在线观看视频| 亚洲高清视频的网址| 久久精品久久精品| 国产91精品露脸国语对白| 色悠悠久久综合| 欧美电影在哪看比较好| 久久久亚洲精华液精华液精华液| 最新国产精品久久精品| 亚洲午夜视频在线观看| 久久福利资源站| 成人精品视频一区二区三区 | 精品成人在线观看| 日本一区二区免费在线| 亚洲五码中文字幕| 国产精品综合一区二区三区| 91免费视频大全| 欧美电影免费提供在线观看| 一区二区在线看| 国产综合一区二区| 色天使色偷偷av一区二区| 日韩欧美国产1| 综合久久国产九一剧情麻豆| 免费观看久久久4p| 99久久国产综合精品色伊| 成人国产精品免费观看视频| 91麻豆精品国产自产在线 | 日韩精品一区二区三区视频| 亚洲乱码国产乱码精品精小说 | 久久久午夜精品| 亚洲第一二三四区| 丰满白嫩尤物一区二区| 欧美一区二区三区免费在线看| 亚洲欧美另类久久久精品| 狠狠久久亚洲欧美| 欧美亚洲日本国产| 国产精品国产三级国产aⅴ中文 | 精品裸体舞一区二区三区| 亚洲免费观看视频| 风间由美一区二区av101| 日韩欧美在线观看一区二区三区| 亚洲激情自拍视频| 成人性生交大合| www欧美成人18+| 日韩不卡一二三区| 在线观看av一区| 亚洲日本电影在线| 成人在线视频一区二区| 亚洲精品一区二区三区影院 | 欧美成人a视频| 午夜激情一区二区| 欧美在线啊v一区| 一区二区三区四区不卡在线 | 美女在线视频一区| 欧美婷婷六月丁香综合色| 亚洲精品欧美激情| 成人午夜看片网址| 国产精品午夜电影| 成人中文字幕在线| 欧美国产欧美亚州国产日韩mv天天看完整| 国产在线视频一区二区|