ChainForge/chainforge/oaievals/infiniteloop-match.cforge

1 line
55 KiB
Plaintext
Raw Permalink Normal View History

TypeScript backend, HuggingFace models, JavaScript evaluators, Comment Nodes, and more (#81) * Beginning to convert Python backend to Typescript * Change all fetch() calls to fetch_from_backend switcher * wip converting query.py to query.ts * wip started utils.js conversion. Tested that OpenAI API call works * more progress on converting utils.py to Typescript * jest tests for query, utils, template.ts. Confirmed PromptPipeline works. * wip converting queryLLM in flask_app to TS * Tested queryLLM and StorageCache compressed saving/loading * wip execute() in backend.ts * Added execute() and tested w concrete func. Need to test eval() * Added craco for optional webpack config. Config'd for TypeScript with Node.js packages browserify'd * Execute JS code on iframe sandbox * Tested and working JS Evaluator execution. * wip swapping backends * Tested TypeScript backendgit status! :) woot * Added fetchEnvironAPIKeys to Flask server to fetch os.environ keys when running locally * Route Anthropic calls through Flask when running locally * Added info button to Eval nodes. Rebuilt react * Edits to info modal on Eval node * Remove/error out on Python eval nodes when not running locally. * Check browser compat and display error if not supported * Changed all example flows to use JS. Bug fix in query.ts * Refactored to LLMProvider to streamline model additions * Added HuggingFace models API * Added back Dalai call support, routing through Flask * Remove flask app calls and socketio server that are no longer used * Added Comment Nodes. Rebuilt react. * Fix PaLM temp=0 build, update package vers and rebuild react
2023-06-30 15:11:20 -04:00
{"flow": {"nodes": [{"width": 312, "height": 311, "id": "prompt-infiniteloop-match", "type": "prompt", "data": {"prompt": "{prompt}", "n": 1, "llms": [{"key": "aa3c0f03-22bd-416e-af4d-4bf5c4278c99", "settings": {"system_msg": "You have to determine if a given block of code will run in forever in an infinite loop, or if it will stop. Only answer with True if it will run forever, and only with False if it stops", "temperature": 1, "functions": [], "function_call": "", "top_p": 1, "stop": [], "presence_penalty": 0, "frequency_penalty": 0}, "name": "GPT3.5", "emoji": "\ud83d\ude42", "model": "gpt-3.5-turbo", "base_model": "gpt-3.5-turbo", "temp": 1, "formData": {"shortname": "GPT3.5", "model": "gpt-3.5-turbo", "system_msg": "You have to determine if a given block of code will run in forever in an infinite loop, or if it will stop. Only answer with True if it will run forever, and only with False if it stops", "temperature": 1, "functions": "", "function_call": "", "top_p": 1, "stop": "", "presence_penalty": 0, "frequency_penalty": 0}}]}, "position": {"x": 448, "y": 224}, "selected": false, "positionAbsolute": {"x": 448, "y": 224}, "dragging": false}, {"width": 333, "height": 182, "id": "eval-infiniteloop-match", "type": "evaluator", "data": {"code": "function evaluate(response) {\n\tlet ideal = response.meta['Ideal'];\n\treturn response.text.startsWith(ideal);\n}", "language": "javascript"}, "position": {"x": 820, "y": 150}, "positionAbsolute": {"x": 820, "y": 150}}, {"width": 228, "height": 196, "id": "vis-infiniteloop-match", "type": "vis", "data": {"input": "eval-infiniteloop-match"}, "position": {"x": 1200, "y": 250}, "positionAbsolute": {"x": 1200, "y": 250}}, {"width": 302, "height": 260, "id": "inspect-infiniteloop-match", "type": "inspect", "data": {"input": "prompt-infiniteloop-match"}, "position": {"x": 820, "y": 400}, "positionAbsolute": {"x": 820, "y": 400}}, {"width": 423, "height": 417, "id": "table-infiniteloop-match", "type": "table", "data": {"rows": [{"prompt": "#include <stdio.h> void main() { int i = 10; for( ; ;) { printf(\"%d\\n\",i); } }", "ideal": "False"}, {"prompt": "#include <stdio.h> void main() { int i = 10; while(i<100) { printf(\"%d\\t\",i); } }", "ideal": "True"}, {"prompt": "#include <stdio.h> void main() { int i = 10; do { printf(\"%d\\t\",i); i++; } while(i); }", "ideal": "True"}, {"prompt": "#include <stdio.h> void checkEven(int num) { if (num%2 == 0) goto even_no; else goto odd_no; even_no: printf(\"The number is even.\\t\"); goto even_no; odd_no: printf(\"The number is odd.\\t\"); goto odd_no; } void main() { int i = 10; checkEven(i); }", "ideal": "True"}, {"prompt": "int main() { float x = 3.0; while (x != 4.0) { printf(\"x = %f\\n\", x); x += 0.1; } return 0; }", "ideal": "True"}, {"prompt": "int ReadVariableLengthInt(byte[] data, ref int index) { int value = 0; while (index < data.Length) { int b = data[index]; if ((b & 0x80) == 0) { return (value << 7) | b; } value = (value << 7) | (b & 0x7F); index++; } return value; }", "ideal": "False"}, {"prompt": "int processMessagesFromServer(char *hostaddr, int port) { ... int servsock; int connected; struct sockaddr_in servaddr; // create socket to connect to server servsock = socket( AF_INET, SOCK_STREAM, 0); memset( &servaddr, 0, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_port = htons(port); servaddr.sin_addr.s_addr = inet_addr(hostaddr); do { // establish connection to server connected = connect(servsock, (struct sockaddr *)&servaddr, sizeof(servaddr)); // if connected then read and process messages from server if (connected > -1) { // read and process messages ... } // keep trying to establish connection to the server } while (connected < 0); // close socket and return success or failure ... }", "ideal": "True"}, {"prompt": "int processMessagesFromServer(char *hostaddr, int port) { ... // initialize number of attempts counter int count = 0; do { // establish connection to server connected = connect(ser