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

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

?? agrep.chronicle

?? harvest是一個下載html網頁得機器人
?? CHRONICLE
字號:
/* Copyright (c) 1994 Sun Wu, Udi Manber, Burra Gopal.  All Rights Reserved. */Started in Feb 1991.This chronicle briefly describes the progress of agrep.Feb/91: The approximate pattern matching algorithm called 'bitap'	(bit-parallel approximate pattern matching) is designed.	The algorithm is a generalization of Baeza-Yates' "shift-or"	algorithm for exact matching.Mar/91: Many extensions of the algorithm 'bitap' are found, especially	for approximate regular expression pattern matching.  Preliminary	implementation of the algorithm showed a strong promise for 	a general-purpose fast approximate pattern-matching tool.Apr/91: Approximate regular expression pattern matching was implemented.	The result is even better than expected. 	The design of the software tool is pinned down.	(For example, record oriented, multi-pattern, AND/OR logic queries.)	A partition technique for approximate pattern matching is used.	May/91: The prototype of "agrep" is completed.	A lot of debugging/optimization in this month.Jun/91: The first version of agrep is released.	agrep 1.0 was announced and made available by anonymous ftp 	from cs.arizona.edu.Jul/91: A sub-linear expected-time algorithm, called "amonkey" for 	approximate pattern matching (for simple pattern) is designed.	The algorithm has the same time complexity as that of	Chang&Lawler but is much much faster in practice.	The algorithm is based on a variation of Boyer-Moore technique,	which we call "block-shifting." 	A sub-linear expected-time algorithm, called "mgrep" for 	matching a set of patterns is designed based on the "block-shifting" 	technique with a hashing technique.Aug/91: "amonkey" is implemented and incorporated into agrep.	It is very fast for long patterns like DNA patterns.	(But roughly the same for matching English words as the bitap	algorithm using the partition technique.)	Prototype of "mgrep" is implemented.Sep/91: "mgrep" is incorporated into agrep to support the -f option.	An algorithm for approximate pattern matching that combines the 	'partition' technique with the sub-linear expected-time algorithm 	for multi-patterns is designed.	Implementation shows it to be the fastest for ASCII text (and pattern).	Boyer-moore technique for exact matching is incorporated.Nov/91: The final paper of "agrep" that is to appear in USENIX	conference (Jan 1992)  is finished.Jan/92: Some new options are added, such as find best matches (-B), 	and file outputs (-G).	The man pages are revised.	agrep version 2.0 is released.	Fixed the following bugs and change the version to be 2.01.	1. -G option doesn't work correctly.	2. multiple definition of some global variables.	3. -# with -w forced the first character of the pattern to be matchedMar/92: Fixed the following bugs and change the version to be 2.02.	1. agrep sometimes misses some matches for pipeline input.	2. the word delimiter was not defined consistantly.------------------------------------------------------------------------------bgopal: The following changes were made to the original agrep during 1993-94:1. Modifications to make main() take multiple options from the same '-' group:	- the only modifications were in main.c.2. Now, to make agrep take input from a buffer so that it can be used as a   procedure from another program. Places where changes have to be done:	- asearch.c/fill_buf(), bitap.c/fill_buf()	- main.c/read() statements	- mgrep.c/read() statements	- sgrep.c/read() statements	- probably don't have to change scanf in main.c where a y/n is asked.	- probably don't have to change readdir in recursive.c.I have used fill_buf everywhere for reading things from a file. I have toverify whether this is actually used to take input in which it has to searchfor patterns or to read things REALLY from a file (-f option, file_out, etc.).If former, then I can simply modify fill_buf to read from an fd or froman input string. How to specify that string / area of memory is a separateissue to be resolved during the weekend.I have resolved it. I've also made a library interface for agrep. So 2 is done.3. Make errno = exit code whenever you return -1 instead of exiting.4. See if there is a way to avoid copying of memory bytes in agrep   by using pointer manipulation instead of fill_buf: a part of making agrep   a callable routine. Important to make it really fast, that's why do this.   Solution:   ---------   I think I've solved the problem: but there is a restriction for within the   memory pattern matching: THE SEARCHBUFFER HAS TO BEGIN WITH A NEWLINE --   otherwise we cannot avoid the copying. This fact can be checked in the   library interface.   There are some more problems whose solution I'm not sure of: ask Udi.   The problem is:	a. In asearch(), asearch0() and asearch1(), some data is copied after	   the data read in the buffer. Is that crucial? The same thing can be	   seen in bitap(). This is done when num_read < BlockSize -- why?	b. In sgrep(), the whole buffer is filled with pat[m-1] so that bm()	   does not enter an infinite-loop. Is that crucial if there is an	   equivalent of a single iteration of the while-fill_buf-loop.   I have not modified prepf() to read the multi-pattern from memory, not a   file.  I have to modify it later (including agrep.c). Function fill_buf now   simply reads from the fd given: it does not bother about pointer   manipulation.  Note: wherever there is a while(i<end) loop,   buffer[0] = buffer[end-1] = '\n'; assignment is made, and wherever   monkey(..start,end..) is called, the assignment   buffer[0] = buffer[end] = '\0'; is made. The semantics are consistent   with what end happens to be.   NOTE:   -----   The amount of "space" expected is = length of the pattern. Now, is there a   way to avoid buserr/segv by using a syscall to find out if buffer+pattern   is in valid memory? If so, we can return error to user, instead of   terminating! Painful since we have to trap SIGSEGV and ruin an already   trapped SIGSEGV, and we don't know if the fault was due to us or them.5. Is there a way to modify agrep so that it can search through tcompress-ed   files? One way would be to handle them separately in a function called   tgrep(), say.  But we would then have to call the functions bitap(),   mgrep() and sgrep() from WITHIN tgrep() anyway. The other way would be   to modify the pattern in the beginning and let the normal processing of   agrep continue.   The next thing would be to uncompress the matched line for printout purposes.   This is complicated in the sense that -- we might have to look for a literal   char#10 within verbatim, OR the code for '\n' among the special characters.   Also, we have to search not only for words in the dictionary, but words in   verbatim too! Moreover, I have to be careful about the exact translation of   a verbatim/non-verbatim word.   - I'm working on this now: I know the translation algo (its just like     uncompress) but the interface to agrep (I have to rewrite the input     handling by myself since the way '\n's are searched for in normal files     is quite different.  The difficult thing is going backwards and looking     for the previous '\n' -- I don't have to literally search for '\n' --     I can remember the position of the previous one. Identifying '\n' in     sgrep(), mgrep() and other functions has to be changed.   - Moreover, I have to uncompress a file not from the beginning, but from the     position of a '\n' to the next '\n' or eof. So compress/uncompress must     also be callable routines.**** This including modifications to all routines in sgrep.c and newmgrep.c     were completed and debugged by Aug '94.6. What options can be added to agrep as a callable routine so that the output   can be put into a user-level buffer / returned as values which can be   examined, etc., so that the thing does not go onto the stdout! Moreover,   copying the matched lines might not be desirable -- the user might want   line numbers, or pointers to the beginning of the lines where the match   occurs and the offset of the match...  (* Callable routine => lots of   problems! *).**** These were completed and added into glimpse/glimpseindex in Spring 1994.7. One other problems with agrep as a callable routine: the variable names used   by agrep can clash with user defined variable names. Making agrep variables   static is not going to help since they are accessed throughout agrep code.   Making code reentrant is not the issue (it is almost impossible!).

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美国产麻豆| 国产麻豆视频精品| 亚洲精品水蜜桃| 亚洲欧美一区二区三区孕妇| 日本不卡一二三区黄网| 久久亚洲一区二区三区四区| 精品国产一区二区三区忘忧草| 欧美日韩亚洲另类| 在线观看视频一区二区欧美日韩| 国产一区二区三区免费看| 狠狠色狠狠色综合日日91app| 日韩国产一二三区| 麻豆精品一区二区av白丝在线| 亚洲成va人在线观看| 男人操女人的视频在线观看欧美| 日韩av一区二区在线影视| 日韩成人伦理电影在线观看| 久久精品国产一区二区三 | 91首页免费视频| 波多野洁衣一区| 国产精品白丝jk黑袜喷水| 国产高清久久久| 在线观看一区二区视频| 在线观看日韩国产| 精品国一区二区三区| 中文字幕在线免费不卡| 首页亚洲欧美制服丝腿| 国产精品18久久久久久久久| 不卡一区中文字幕| 欧美大片在线观看一区| 1000精品久久久久久久久| 久久国产麻豆精品| 色呦呦一区二区三区| 中文字幕成人在线观看| 久久aⅴ国产欧美74aaa| 在线观看日韩电影| 亚洲国产精品高清| 国产在线一区二区综合免费视频| 欧美一a一片一级一片| 日本一区二区成人| 国产电影精品久久禁18| 欧美一区二区不卡视频| 亚洲成人综合网站| 91麻豆福利精品推荐| 国产精品美女一区二区在线观看| 亚洲国产色一区| 欧美色手机在线观看| 午夜精品久久久久久久| 欧美日韩成人一区二区| 亚洲午夜电影在线观看| 欧美日韩国产大片| 三级一区在线视频先锋| 337p亚洲精品色噜噜| 亚洲高清中文字幕| 日韩欧美色综合网站| 粉嫩嫩av羞羞动漫久久久 | 精品成人一区二区| 不卡的看片网站| 亚洲一区二区影院| 欧美精品一区二区三区高清aⅴ| 国产激情一区二区三区| 久久久久国产精品厨房| 99精品国产热久久91蜜凸| 亚州成人在线电影| 日韩欧美精品三级| 国产精品中文字幕日韩精品| 亚洲色图视频网| 欧美猛男男办公室激情| 久久机这里只有精品| 亚洲大型综合色站| 国产精品成人午夜| 精品久久久久久久久久久院品网| av在线播放不卡| 国产一区二区三区免费在线观看| 亚洲欧美日韩电影| 日韩视频一区二区三区| 91在线无精精品入口| 国产在线不卡视频| 九九国产精品视频| 午夜久久久影院| 亚洲精品第一国产综合野| 日韩美女啊v在线免费观看| 中文字幕亚洲在| 亚洲蜜桃精久久久久久久| 亚洲自拍偷拍欧美| 五月综合激情婷婷六月色窝| 日韩av中文字幕一区二区| 蜜乳av一区二区| 国产美女一区二区| 色视频欧美一区二区三区| 欧美日韩色一区| 欧美成人国产一区二区| 国产精品免费看片| 日韩高清一区在线| 国产福利一区二区三区在线视频| 成人网男人的天堂| 777久久久精品| 国产欧美日本一区视频| 亚洲一区二区三区中文字幕在线| 婷婷成人激情在线网| 国产精品18久久久久久久网站| 99这里都是精品| 日韩欧美二区三区| 亚洲高清免费在线| 97久久久精品综合88久久| 欧美一区二区在线不卡| 亚洲综合免费观看高清完整版在线 | 精品美女在线播放| 亚洲主播在线播放| 成人avav在线| 国产精品久久久久久户外露出 | 911精品产国品一二三产区| 国产精品久久免费看| 久久99精品国产麻豆婷婷| 欧美高清www午色夜在线视频| 亚洲日韩欧美一区二区在线| 久久国产视频网| 6080午夜不卡| 日本欧美在线看| 欧美喷水一区二区| 午夜成人免费视频| 欧美肥胖老妇做爰| 舔着乳尖日韩一区| 日韩一区和二区| 精品一区二区日韩| 国产亚洲人成网站| 国产高清在线观看免费不卡| 日韩精品一区二区三区在线播放 | 国产精品免费久久久久| 91污片在线观看| 一区二区三区不卡视频在线观看| 色婷婷亚洲综合| 青娱乐精品视频| 国产精品久久国产精麻豆99网站| 福利一区在线观看| 亚洲欧美另类在线| 日韩欧美国产三级| jlzzjlzz欧美大全| 婷婷夜色潮精品综合在线| 精品久久人人做人人爽| 不卡一区二区中文字幕| 天堂一区二区在线免费观看| 久久综合色8888| 欧美三级电影在线看| 国产剧情av麻豆香蕉精品| 亚洲视频一区二区在线| 69成人精品免费视频| caoporen国产精品视频| 免费一级欧美片在线观看| 国产精品久久久久影院老司| 欧美日韩午夜精品| 成人深夜在线观看| 青青草伊人久久| 亚洲综合视频在线| 日本一区二区三区视频视频| 欧美日韩成人高清| 色噜噜偷拍精品综合在线| 美女视频免费一区| 性欧美疯狂xxxxbbbb| 国产精品久久久久久久岛一牛影视 | 精品久久一区二区| 日韩一区二区三区av| 精品裸体舞一区二区三区| 懂色av一区二区三区蜜臀| 美女视频黄免费的久久 | 欧美日本乱大交xxxxx| 成人综合婷婷国产精品久久免费| 蜜臂av日日欢夜夜爽一区| 日日欢夜夜爽一区| 日本欧美在线看| 久久精品二区亚洲w码| 免播放器亚洲一区| 日韩 欧美一区二区三区| 午夜伦理一区二区| 青草av.久久免费一区| 免费一级片91| 国产一区二区福利| 国产99久久久国产精品免费看| 国产在线精品免费| 成人av网址在线| 欧美日本免费一区二区三区| 日韩欧美在线1卡| 国产色婷婷亚洲99精品小说| 中文av一区二区| 亚洲不卡一区二区三区| 六月丁香婷婷色狠狠久久| 日韩不卡在线观看日韩不卡视频| 亚洲国产精品久久人人爱蜜臀| 日韩黄色小视频| 粉嫩av亚洲一区二区图片| 91国产福利在线| 久久久久88色偷偷免费| 亚洲成人av免费| 成人理论电影网| 欧美精品久久99| 亚洲精品成人天堂一二三| 国产一区二区福利| 555www色欧美视频| 亚洲色图在线视频| 国产福利一区二区三区视频 |