-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
reduce startup time by storing the parikh map
- Loading branch information
Showing
8 changed files
with
307 additions
and
14 deletions.
There are no files selected for viewing
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
200 changes: 200 additions & 0 deletions
200
src/commonMain/kotlin/ai/hypergraph/kaliningraph/repair/Grammars.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,200 @@ | ||
package ai.hypergraph.kaliningraph.repair | ||
|
||
import ai.hypergraph.kaliningraph.parsing.freeze | ||
import ai.hypergraph.kaliningraph.parsing.noEpsilonOrNonterminalStubs | ||
import ai.hypergraph.kaliningraph.parsing.parseCFG | ||
|
||
val s2pCFGStr = """ | ||
START -> Stmts_Or_Newlines | ||
Stmts_Or_Newlines -> Stmt_Or_Newline | Stmt_Or_Newline Stmts_Or_Newlines | ||
Stmt_Or_Newline -> Stmt | Newline | ||
Newline -> NEWLINE | ||
Async_Funcdef -> Async_Keyword Funcdef | ||
Funcdef -> Def_Keyword Simple_Name Parameters Colon Suite | Def_Keyword Simple_Name Parameters Arrow Test Colon Suite | ||
Parameters -> Open_Paren Close_Paren | Open_Paren Typedargslist Close_Paren | ||
Typedargslist -> Many_Tfpdef | Many_Tfpdef Comma | Many_Tfpdef Comma Star_Double_Star_Typed | Many_Tfpdef Comma Double_Star_Tfpdef | Star_Double_Star_Typed | Double_Star_Tfpdef | ||
Star_Double_Star_Typed -> Star_Tfpdef | Star_Tfpdef Comma | Star_Tfpdef Comma Double_Star_Tfpdef | ||
Star_Tfpdef_Comma -> Comma Tfpdef_Default | Comma Tfpdef_Default Star_Tfpdef_Comma | ||
Star_Tfpdef -> Star_Op | Star_Op Star_Tfpdef_Comma | Star_Op Tfpdef | Star_Op Tfpdef Star_Tfpdef_Comma | ||
Double_Star_Tfpdef -> Double_Star_Op Tfpdef | Double_Star_Op Tfpdef Comma | ||
Many_Tfpdef -> Tfpdef_Default | Tfpdef_Default Comma Many_Tfpdef | ||
Tfpdef_Default -> Tfpdef | Tfpdef Assign_Op Test | ||
Varargslist -> Many_Vfpdef | Many_Vfpdef Comma | Many_Vfpdef Comma Star_Double_Star | Many_Vfpdef Comma Double_Star_Vfpdef | Star_Double_Star | Double_Star_Vfpdef | ||
Star_Double_Star -> Star_Vfpdef | Star_Vfpdef Comma | Star_Vfpdef Comma Double_Star_Vfpdef | ||
Star_Vfpdef_Comma -> Comma Vfpdef_Default | Comma Vfpdef_Default Star_Vfpdef_Comma | ||
Star_Vfpdef -> Star_Op | Star_Op Star_Vfpdef_Comma | Star_Op Vfpdef | Star_Op Vfpdef Star_Vfpdef_Comma | ||
Double_Star_Vfpdef -> Double_Star_Op Vfpdef | Double_Star_Op Vfpdef Comma | ||
Many_Vfpdef -> Vfpdef_Default | Vfpdef_Default Comma Many_Vfpdef | ||
Vfpdef_Default -> Vfpdef | Vfpdef Assign_Op Test | ||
Tfpdef -> Vfpdef | Vfpdef Colon Test | ||
Vfpdef -> NAME | ||
Assign_Op -> = | ||
Star_Op -> * | ||
Double_Star_Op -> ** | ||
Arrow -> arrow | ||
Stmt -> Simple_Stmt | Compound_Stmt | ||
Simple_Stmt -> Small_Stmts Newline | Small_Stmts Semicolon Newline | ||
Small_Stmts -> Small_Stmt | Small_Stmt Semicolon Small_Stmts | ||
Small_Stmt -> Expr_Stmt | Del_Stmt | Pass_Stmt | Flow_Stmt | Import_Stmt | Global_Stmt | Nonlocal_Stmt | Assert_Stmt | ||
Expr_Stmt -> Testlist_Star_Expr Annotated_Assign | Testlist_Star_Expr Aug_Assign Yield_Expr | Testlist_Star_Expr Aug_Assign Testlist_Endcomma | Testlist_Star_Exprs_Assign | ||
Annotated_Assign -> Colon Test | Colon Test Assign_Op Test | ||
Test_Or_Star_Expr -> Test | Star_Expr | ||
Test_Or_Star_Exprs -> Test_Or_Star_Expr | Test_Or_Star_Expr Comma Test_Or_Star_Exprs | ||
Testlist_Star_Expr -> Test_Or_Star_Exprs | Test_Or_Star_Exprs Comma | ||
Yield_Testlist_Star_Assign_Exprs -> Assign_Op Yield_Expr | Assign_Op Testlist_Star_Expr | Assign_Op Yield_Expr Yield_Testlist_Star_Assign_Exprs | Assign_Op Testlist_Star_Expr Yield_Testlist_Star_Assign_Exprs | ||
Testlist_Star_Exprs_Assign -> Testlist_Star_Expr | Testlist_Star_Expr Yield_Testlist_Star_Assign_Exprs | ||
Del_Stmt -> Del_Keyword Exprlist | ||
Flow_Stmt -> Break_Stmt | Continue_Stmt | Return_Stmt | Raise_Stmt | Yield_Stmt | ||
Return_Stmt -> Return_Keyword | Return_Keyword Testlist_Endcomma | ||
Yield_Stmt -> Yield_Expr | ||
Raise_Stmt -> Raise_Keyword | Raise_Keyword Test | Raise_Keyword Test From_Keyword Test | ||
Import_Stmt -> Import_name | Import_From | ||
Import_name -> Import_Keyword Dotted_As_Names | ||
Dots_Plus -> Dot_Or_Dots | Dot_Or_Dots Dots_Plus | ||
Start_Dotted_Name -> Dotted_Name | Dots_Plus Dotted_Name | ||
Import_From_Froms -> From_Keyword Start_Dotted_Name | From_Keyword Dots_Plus | ||
Import_From_Imports -> Import_Keyword Star_Op | Import_Keyword Open_Paren Import_As_Names_Endcomma Close_Paren | Import_Keyword Import_As_Names_Endcomma | ||
Import_From -> Import_From_Froms Import_From_Imports | ||
Import_As_Name -> Simple_Name | Simple_Name As_Keyword Simple_Name | ||
Dotted_As_Name -> Dotted_Name | Dotted_Name As_Keyword Simple_Name | ||
Import_As_Names -> Import_As_Name | Import_As_Name Comma Import_As_Names_Endcomma | ||
Import_As_Names_Endcomma -> Import_As_Names | Import_As_Name Comma | ||
Dotted_As_Names -> Dotted_As_Name | Dotted_As_Name Comma Dotted_As_Names | ||
Dotted_Name -> Simple_Name | Simple_Name Dot Dotted_Name | ||
Many_Names -> Simple_Name | Simple_Name Comma Many_Names | ||
Global_Stmt -> Global_Keyword Many_Names | ||
Nonlocal_Stmt -> Nonlocal_Keyword Many_Names | ||
Assert_Stmt -> Assert_Keyword Test | Assert_Keyword Test Comma Test | ||
Aug_Assign -> += | -= | *= | @= | /= | %= | &= | |= | ^= | <<= | >>= | **= | //= | ||
Del_Keyword -> del | ||
Pass_Stmt -> pass | ||
Break_Stmt -> break | ||
Continue_Stmt -> continue | ||
Return_Keyword -> return | ||
Yield_Keyword -> yield | ||
Raise_Keyword -> raise | ||
From_Keyword -> from | ||
Import_Keyword -> import | ||
Dot_Or_Dots -> . | ... | ||
As_Keyword -> as | ||
Global_Keyword -> global | ||
Nonlocal_Keyword -> nonlocal | ||
Assert_Keyword -> assert | ||
Def_Keyword -> def | ||
Class_Keyword -> class | ||
Compound_Stmt -> If_Stmt | While_Stmt | For_Stmt | Try_Stmt | With_Stmt | Funcdef | Classdef | Async_Stmt | ||
Async_Stmt -> Async_Keyword Funcdef | Async_Keyword With_Stmt | Async_Keyword For_Stmt | ||
Elif_Stmt -> Elif_Keyword Test Colon Suite | Elif_Keyword Test Colon Suite Elif_Stmt | ||
Else_Stmt -> Else_Keyword Colon Suite | ||
If_Stmt -> If_Keyword Test Colon Suite | If_Keyword Test Colon Suite Else_Stmt | If_Keyword Test Colon Suite Elif_Stmt | If_Keyword Test Colon Suite Elif_Stmt Else_Stmt | ||
While_Stmt -> While_Keyword Test Colon Suite | While_Keyword Test Colon Suite Else_Stmt | ||
For_Stmt -> For_Keyword Exprlist In_Keyword Testlist_Endcomma Colon Suite | For_Keyword Exprlist In_Keyword Testlist_Endcomma Colon Suite Else_Stmt | ||
Finally_Stmt -> Finally_Keyword Colon Suite | ||
Except_Stmt -> Except_Clause Colon Suite | Except_Clause Colon Suite Except_Stmt | ||
Try_Stmt -> Try_Keyword Colon Suite Finally_Stmt | Try_Keyword Colon Suite Except_Stmt | Try_Keyword Colon Suite Except_Stmt Else_Stmt | Try_Keyword Colon Suite Except_Stmt Finally_Stmt | Try_Keyword Colon Suite Except_Stmt Else_Stmt Finally_Stmt | ||
With_Stmt -> With_Keyword With_Items Colon Suite | ||
With_Items -> With_Item | With_Item Comma With_Items | ||
With_Item -> Test | Test As_Keyword Expr | ||
Except_Clause -> Except_Keyword | Except_Keyword Test | Except_Keyword Test As_Keyword Simple_Name | ||
Suite -> Simple_Stmt | Newline Indent Stmts_Or_Newlines Dedent | ||
Async_Keyword -> async | ||
Await_Keyword -> await | ||
If_Keyword -> if | ||
Elif_Keyword -> elif | ||
Else_Keyword -> else | ||
While_Keyword -> while | ||
For_Keyword -> for | ||
In_Keyword -> in | ||
Finally_Keyword -> finally | ||
Except_Keyword -> except | ||
Try_Keyword -> try | ||
With_Keyword -> with | ||
Lambda_Keyword -> lambda | ||
Indent -> INDENT | ||
Dedent -> DEDENT | ||
Colon -> : | ||
Semicolon -> ; | ||
Comma -> , | ||
Dot -> . | ||
Open_Paren -> ( | ||
Close_Paren -> ) | ||
Open_Sq_Bracket -> [ | ||
Close_Sq_Bracket -> ] | ||
Open_Curl_Bracket -> { | ||
Close_Curl_Bracket -> } | ||
Test -> Or_Test | Or_Test If_Keyword Or_Test Else_Keyword Test | Lambdef | ||
Test_Nocond -> Or_Test | Lambdef_Nocond | ||
Lambdef -> Lambda_Keyword Colon Test | Lambda_Keyword Varargslist Colon Test | ||
Lambdef_Nocond -> Lambda_Keyword Colon Test_Nocond | Lambda_Keyword Varargslist Colon Test_Nocond | ||
Or_Test -> And_Test | Or_Test Or_Bool_Op And_Test | ||
And_Test -> Not_Test | And_Test And_Bool_Op Not_Test | ||
Not_Test -> Not_Bool_Op Not_Test | Comparison | ||
Comparison -> Expr | Comparison Comp_Op Expr | ||
Star_Expr -> Star_Op Expr | ||
Expr -> Xor_Expr | Expr Or_Op Xor_Expr | ||
Xor_Expr -> And_Expr | Xor_Expr Xor_Op And_Expr | ||
And_Expr -> Shift_Expr | And_Expr And_Op Shift_Expr | ||
Shift_Expr -> Arith_Expr | Shift_Expr Shift_Op Arith_Expr | ||
Arith_Expr -> Term | Arith_Expr Arith_Op Term | ||
Term -> Factor | Term MulDiv_Op Factor | ||
Factor -> Unary_Op Factor | Power | ||
Power -> Atom_Expr | Atom_Expr Double_Star_Op Factor | ||
Many_Trailers -> Trailer | Trailer Many_Trailers | ||
Atom_Expr -> Atom | Atom Many_Trailers | Await_Keyword Atom | Await_Keyword Atom Many_Trailers | ||
Atom -> Open_Paren Close_Paren | Open_Sq_Bracket Close_Sq_Bracket | Open_Curl_Bracket Close_Curl_Bracket | Open_Paren Yield_Expr Close_Paren | Open_Paren Testlist_Comp Close_Paren | Open_Sq_Bracket Testlist_Comp Close_Sq_Bracket | Open_Curl_Bracket Dict_Or_Set_Maker Close_Curl_Bracket | Literals | ||
Testlist_Comp -> Test_Or_Star_Expr Comp_For | Testlist_Star_Expr | ||
Trailer -> Open_Paren Close_Paren | Open_Paren Arglist Close_Paren | Open_Sq_Bracket Subscriptlist Close_Sq_Bracket | Dot Simple_Name | ||
Subscripts -> Subscript | Subscript Comma Subscripts | ||
Subscriptlist -> Subscripts | Subscripts Comma | ||
Subscript -> Test | Colon | Test Colon | Colon Test | Colon Sliceop | Test Colon Test | Colon Test Sliceop | Test Colon Sliceop | Test Colon Test Sliceop | ||
Sliceop -> Colon | Colon Test | ||
Generic_Expr -> Expr | Star_Expr | ||
Generic_Exprs -> Generic_Expr | Generic_Expr Comma Generic_Exprs | ||
Exprlist -> Generic_Exprs | Generic_Exprs Comma | ||
Testlist -> Test | Test Comma Testlist_Endcomma | ||
Testlist_Endcomma -> Testlist | Test Comma | ||
KeyVal_Or_Unpack -> Test Colon Test | Double_Star_Op Expr | ||
Many_KeyVals_Or_Unpacks -> KeyVal_Or_Unpack | KeyVal_Or_Unpack Comma Many_KeyVals_Or_Unpacks | ||
KeyVal_Or_Unpack_Setter -> KeyVal_Or_Unpack Comp_For | Many_KeyVals_Or_Unpacks | Many_KeyVals_Or_Unpacks Comma | ||
Test_Or_Star_Expr_Setter -> Test_Or_Star_Expr Comp_For | Testlist_Star_Expr | ||
Dict_Or_Set_Maker -> KeyVal_Or_Unpack_Setter | Test_Or_Star_Expr_Setter | ||
Or_Bool_Op -> or | ||
And_Bool_Op -> and | ||
Not_Bool_Op -> not | ||
Comp_Op -> < | > | == | >= | <= | <> | != | in | not_in | is | is_not | ||
Or_Op -> OR | ||
Xor_Op -> ^ | ||
And_Op -> & | ||
Shift_Op -> << | >> | ||
Arith_Op -> + | - | ||
MulDiv_Op -> * | @ | / | % | // | ||
Unary_Op -> + | - | ~ | ||
Literals -> NAME | NUMBER | STRING | ... | None | True | False | ||
Simple_Name -> NAME | ||
Classdef -> Class_Keyword Simple_Name Colon Suite | Class_Keyword Simple_Name Open_Paren Close_Paren Colon Suite | Class_Keyword Simple_Name Open_Paren Arglist Close_Paren Colon Suite | ||
Arglist -> Arguments | Arguments Comma | ||
Arguments -> Argument | Argument Comma Arguments | ||
Argument -> Test | Test Comp_For | Test Assign_Op Test | Double_Star_Op Test | Star_Op Test | ||
Comp_Iter -> Comp_For | Comp_If | ||
Comp_For -> For_Keyword Exprlist In_Keyword Or_Test | For_Keyword Exprlist In_Keyword Or_Test Comp_Iter | Async_Keyword For_Keyword Exprlist In_Keyword Or_Test | Async_Keyword For_Keyword Exprlist In_Keyword Or_Test Comp_Iter | ||
Comp_If -> If_Keyword Test_Nocond | If_Keyword Test_Nocond Comp_Iter | ||
Yield_Expr -> Yield_Keyword | Yield_Keyword Yield_Arg | ||
Yield_Arg -> From_Keyword Test | Testlist_Endcomma | ||
""" | ||
|
||
val vanillaS2PCFG by lazy { s2pCFGStr.parseCFG().noEpsilonOrNonterminalStubs.freeze() } |
38 changes: 38 additions & 0 deletions
38
src/jvmMain/kotlin/ai/hypergraph/kaliningraph/repair/Cache.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
package ai.hypergraph.kaliningraph.repair | ||
|
||
import ai.hypergraph.kaliningraph.parsing.langCache | ||
import java.io.ByteArrayInputStream | ||
import java.io.InputStreamReader | ||
import java.nio.charset.StandardCharsets | ||
import java.util.zip.ZipInputStream | ||
|
||
fun decompressZipToString(zipBytes: ByteArray): String { | ||
ByteArrayInputStream(zipBytes).use { byteArrayInputStream -> | ||
ZipInputStream(byteArrayInputStream).use { zipInputStream -> | ||
val entry = zipInputStream.nextEntry | ||
if (entry != null) { | ||
return InputStreamReader(zipInputStream, StandardCharsets.UTF_8).use { reader -> | ||
reader.readText() | ||
} | ||
} else { | ||
throw IllegalArgumentException("The zip file is empty.") | ||
} | ||
} | ||
} | ||
} | ||
|
||
object LangCache { | ||
// Loads the Python Parikh map into memory | ||
fun prepopPythonLangCache() { | ||
if (1566012639 in langCache) return | ||
val filename = "1566012639.cache.zip" | ||
val zippedText = object {}.javaClass.classLoader.getResource(filename)!!.readBytes() | ||
// Now decompress and load into memory | ||
val str = decompressZipToString(zippedText) | ||
|
||
val upperBound = str.lines().last().substringBefore(" ") | ||
println("Prepopulated Parikh Map ($upperBound) for vanillaS2PCFG from $filename") | ||
|
||
langCache[1566012639] = str | ||
} | ||
} |
Binary file not shown.
Oops, something went wrong.