ChainForge/chainforge/oaievals/json_patch_object.cforge

1 line
286 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-json_patch_object", "type": "prompt", "data": {"prompt": "{prompt}", "n": 1, "llms": [{"key": "aa3c0f03-22bd-416e-af4d-4bf5c4278c99", "settings": {"system_msg": "Return a JSON Patch array with no additional commentary.\nReturn the minimal set of JSON Patch operations required; do not return ineffective or redundant operations.\nJSON Patch operations should be JSON objects with the keys \"op\", \"path\", and \"value\".\n\"op\" can be one of \"add\", \"remove\", or \"replace\".\n\"path\" is a JSON Pointer to the key in the base JSON to which the operation should be applied.\nIf the operation is \"add\" or \"replace\", \"value\" is the value to be added or replaced.\nIf the operation is \"remove\", \"value\" should be not included.\nReturn the JSON Patch array on a single line in the following format: [{{\"op\": \"replace\", \"path\": \"/95d90676-2b2e-4152-9b48-5238ca7019a9/38184eb5-03b9-4f3a-9546-c76d4bc141ef\", \"value\": 385}}]", "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": "Return a JSON Patch array with no additional commentary.\nReturn the minimal set of JSON Patch operations required; do not return ineffective or redundant operations.\nJSON Patch operations should be JSON objects with the keys \"op\", \"path\", and \"value\".\n\"op\" can be one of \"add\", \"remove\", or \"replace\".\n\"path\" is a JSON Pointer to the key in the base JSON to which the operation should be applied.\nIf the operation is \"add\" or \"replace\", \"value\" is the value to be added or replaced.\nIf the operation is \"remove\", \"value\" should be not included.\nReturn the JSON Patch array on a single line in the following format: [{{\"op\": \"replace\", \"path\": \"/95d90676-2b2e-4152-9b48-5238ca7019a9/38184eb5-03b9-4f3a-9546-c76d4bc141ef\", \"value\": 385}}]", "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-json_patch_object", "type": "evaluator", "data": {"code": "function evaluate(response) {\n\tlet ideal = response.meta['Ideal'];\n\treturn response.text.includes(ideal);\n}", "language": "javascript"}, "position": {"x": 820, "y": 150}, "positionAbsolute": {"x": 820, "y": 150}}, {"width": 228, "height": 196, "id": "vis-json_patch_object", "type": "vis", "data": {"input": "eval-json_patch_object"}, "position": {"x": 1200, "y": 250}, "positionAbsolute": {"x": 1200, "y": 250}}, {"width": 302, "height": 260, "id": "inspect-json_patch_object", "type": "inspect", "data": {"input": "prompt-json_patch_object"}, "position": {"x": 820, "y": 400}, "positionAbsolute": {"x": 820, "y": 400}}, {"width": 423, "height": 417, "id": "table-json_patch_object", "type": "table", "data": {"rows": [{"prompt": "Return the minimal JSON Patch array that when applied to the following JSON object: {\"a67a28\": {\"875da6\": {\"a55203\": 279, \"843ffd\": 952, \"71f64f\": 986, \"a927e7\": 112}, \"253e27\": {\"7956db\": 44, \"c3034c\": 425, \"7692b4\": 992, \"7efd84\": 708}, \"20007e\": {\"dd7d5f\": 182, \"e1b43c\": 347, \"683c71\": 572, \"7b1f33\": 151}, \"bae77d\": {\"f8d162\": 268, \"051ca7\": 323, \"88dd84\": 478, \"929ea9\": 892}}, \"d9a2fb\": {\"6532ff\": {\"256d60\": 905, \"73c237\": 106, \"2bdcf6\": 700, \"1ec4ff\": 332}, \"f8f517\": {\"ed3164\": 714, \"725e3f\": 381, \"c4a27e\": 521, \"a4175b\": 971}, \"053a01\": {\"e9d4b6\": 921, \"911b43\": 759, \"6164b1\": 923, \"dea694\": 43}, \"c77438\": {\"2ffbb6\": 430, \"e699a3\": 570, \"4156e0\": 432, \"6814f5\": 524}}, \"efc07d\": {\"8e48c5\": {\"c5de11\": 760, \"0c40d0\": 30, \"eeab6a\": 457, \"836bbf\": 419}, \"4609e4\": {\"12ac6b\": 883, \"9d3a85\": 19