edsl 0.1.39.dev2__py3-none-any.whl → 0.1.39.dev3__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- edsl/Base.py +332 -385
- edsl/BaseDiff.py +260 -260
- edsl/TemplateLoader.py +24 -24
- edsl/__init__.py +49 -57
- edsl/__version__.py +1 -1
- edsl/agents/Agent.py +867 -1079
- edsl/agents/AgentList.py +413 -551
- edsl/agents/Invigilator.py +233 -285
- edsl/agents/InvigilatorBase.py +270 -254
- edsl/agents/PromptConstructor.py +354 -252
- edsl/agents/__init__.py +3 -2
- edsl/agents/descriptors.py +99 -99
- edsl/agents/prompt_helpers.py +129 -129
- edsl/auto/AutoStudy.py +117 -117
- edsl/auto/StageBase.py +230 -230
- edsl/auto/StageGenerateSurvey.py +178 -178
- edsl/auto/StageLabelQuestions.py +125 -125
- edsl/auto/StagePersona.py +61 -61
- edsl/auto/StagePersonaDimensionValueRanges.py +88 -88
- edsl/auto/StagePersonaDimensionValues.py +74 -74
- edsl/auto/StagePersonaDimensions.py +69 -69
- edsl/auto/StageQuestions.py +73 -73
- edsl/auto/SurveyCreatorPipeline.py +21 -21
- edsl/auto/utilities.py +224 -224
- edsl/base/Base.py +279 -279
- edsl/config.py +157 -177
- edsl/conversation/Conversation.py +290 -290
- edsl/conversation/car_buying.py +58 -59
- edsl/conversation/chips.py +95 -95
- edsl/conversation/mug_negotiation.py +81 -81
- edsl/conversation/next_speaker_utilities.py +93 -93
- edsl/coop/PriceFetcher.py +54 -54
- edsl/coop/__init__.py +2 -2
- edsl/coop/coop.py +1028 -1090
- edsl/coop/utils.py +131 -131
- edsl/data/Cache.py +555 -562
- edsl/data/CacheEntry.py +233 -230
- edsl/data/CacheHandler.py +149 -170
- edsl/data/RemoteCacheSync.py +78 -78
- edsl/data/SQLiteDict.py +292 -292
- edsl/data/__init__.py +4 -5
- edsl/data/orm.py +10 -10
- edsl/data_transfer_models.py +73 -74
- edsl/enums.py +175 -195
- edsl/exceptions/BaseException.py +21 -21
- edsl/exceptions/__init__.py +54 -54
- edsl/exceptions/agents.py +42 -54
- edsl/exceptions/cache.py +5 -5
- edsl/exceptions/configuration.py +16 -16
- edsl/exceptions/coop.py +10 -10
- edsl/exceptions/data.py +14 -14
- edsl/exceptions/general.py +34 -34
- edsl/exceptions/jobs.py +33 -33
- edsl/exceptions/language_models.py +63 -63
- edsl/exceptions/prompts.py +15 -15
- edsl/exceptions/questions.py +91 -109
- edsl/exceptions/results.py +29 -29
- edsl/exceptions/scenarios.py +22 -29
- edsl/exceptions/surveys.py +37 -37
- edsl/inference_services/AnthropicService.py +87 -84
- edsl/inference_services/AwsBedrock.py +120 -118
- edsl/inference_services/AzureAI.py +217 -215
- edsl/inference_services/DeepInfraService.py +18 -18
- edsl/inference_services/GoogleService.py +148 -139
- edsl/inference_services/GroqService.py +20 -20
- edsl/inference_services/InferenceServiceABC.py +147 -80
- edsl/inference_services/InferenceServicesCollection.py +97 -122
- edsl/inference_services/MistralAIService.py +123 -120
- edsl/inference_services/OllamaService.py +18 -18
- edsl/inference_services/OpenAIService.py +224 -221
- edsl/inference_services/PerplexityService.py +163 -160
- edsl/inference_services/TestService.py +89 -92
- edsl/inference_services/TogetherAIService.py +170 -170
- edsl/inference_services/models_available_cache.py +118 -118
- edsl/inference_services/rate_limits_cache.py +25 -25
- edsl/inference_services/registry.py +41 -41
- edsl/inference_services/write_available.py +10 -10
- edsl/jobs/Answers.py +56 -43
- edsl/jobs/Jobs.py +898 -757
- edsl/jobs/JobsChecks.py +147 -172
- edsl/jobs/JobsPrompts.py +268 -270
- edsl/jobs/JobsRemoteInferenceHandler.py +239 -287
- edsl/jobs/__init__.py +1 -1
- edsl/jobs/buckets/BucketCollection.py +63 -104
- edsl/jobs/buckets/ModelBuckets.py +65 -65
- edsl/jobs/buckets/TokenBucket.py +251 -283
- edsl/jobs/interviews/Interview.py +661 -358
- edsl/jobs/interviews/InterviewExceptionCollection.py +99 -99
- edsl/jobs/interviews/InterviewExceptionEntry.py +186 -186
- edsl/jobs/interviews/InterviewStatistic.py +63 -63
- edsl/jobs/interviews/InterviewStatisticsCollection.py +25 -25
- edsl/jobs/interviews/InterviewStatusDictionary.py +78 -78
- edsl/jobs/interviews/InterviewStatusLog.py +92 -92
- edsl/jobs/interviews/ReportErrors.py +66 -66
- edsl/jobs/interviews/interview_status_enum.py +9 -9
- edsl/jobs/runners/JobsRunnerAsyncio.py +466 -421
- edsl/jobs/runners/JobsRunnerStatus.py +330 -330
- edsl/jobs/tasks/QuestionTaskCreator.py +242 -244
- edsl/jobs/tasks/TaskCreators.py +64 -64
- edsl/jobs/tasks/TaskHistory.py +450 -449
- edsl/jobs/tasks/TaskStatusLog.py +23 -23
- edsl/jobs/tasks/task_status_enum.py +163 -161
- edsl/jobs/tokens/InterviewTokenUsage.py +27 -27
- edsl/jobs/tokens/TokenUsage.py +34 -34
- edsl/language_models/KeyLookup.py +30 -0
- edsl/language_models/LanguageModel.py +668 -571
- edsl/language_models/ModelList.py +155 -153
- edsl/language_models/RegisterLanguageModelsMeta.py +184 -184
- edsl/language_models/__init__.py +3 -2
- edsl/language_models/fake_openai_call.py +15 -15
- edsl/language_models/fake_openai_service.py +61 -61
- edsl/language_models/registry.py +190 -180
- edsl/language_models/repair.py +156 -156
- edsl/language_models/unused/ReplicateBase.py +83 -0
- edsl/language_models/utilities.py +64 -65
- edsl/notebooks/Notebook.py +258 -263
- edsl/notebooks/__init__.py +1 -1
- edsl/prompts/Prompt.py +362 -352
- edsl/prompts/__init__.py +2 -2
- edsl/questions/AnswerValidatorMixin.py +289 -334
- edsl/questions/QuestionBase.py +664 -509
- edsl/questions/QuestionBaseGenMixin.py +161 -165
- edsl/questions/QuestionBasePromptsMixin.py +217 -221
- edsl/questions/QuestionBudget.py +227 -227
- edsl/questions/QuestionCheckBox.py +359 -359
- edsl/questions/QuestionExtract.py +182 -182
- edsl/questions/QuestionFreeText.py +114 -113
- edsl/questions/QuestionFunctional.py +166 -166
- edsl/questions/QuestionList.py +231 -229
- edsl/questions/QuestionMultipleChoice.py +286 -330
- edsl/questions/QuestionNumerical.py +153 -151
- edsl/questions/QuestionRank.py +324 -314
- edsl/questions/Quick.py +41 -41
- edsl/questions/RegisterQuestionsMeta.py +71 -71
- edsl/questions/ResponseValidatorABC.py +174 -200
- edsl/questions/SimpleAskMixin.py +73 -74
- edsl/questions/__init__.py +26 -27
- edsl/questions/compose_questions.py +98 -98
- edsl/questions/decorators.py +21 -21
- edsl/questions/derived/QuestionLikertFive.py +76 -76
- edsl/questions/derived/QuestionLinearScale.py +87 -90
- edsl/questions/derived/QuestionTopK.py +93 -93
- edsl/questions/derived/QuestionYesNo.py +82 -82
- edsl/questions/descriptors.py +413 -427
- edsl/questions/prompt_templates/question_budget.jinja +13 -13
- edsl/questions/prompt_templates/question_checkbox.jinja +32 -32
- edsl/questions/prompt_templates/question_extract.jinja +11 -11
- edsl/questions/prompt_templates/question_free_text.jinja +3 -3
- edsl/questions/prompt_templates/question_linear_scale.jinja +11 -11
- edsl/questions/prompt_templates/question_list.jinja +17 -17
- edsl/questions/prompt_templates/question_multiple_choice.jinja +33 -33
- edsl/questions/prompt_templates/question_numerical.jinja +36 -36
- edsl/questions/question_registry.py +177 -177
- edsl/questions/settings.py +12 -12
- edsl/questions/templates/budget/answering_instructions.jinja +7 -7
- edsl/questions/templates/budget/question_presentation.jinja +7 -7
- edsl/questions/templates/checkbox/answering_instructions.jinja +10 -10
- edsl/questions/templates/checkbox/question_presentation.jinja +22 -22
- edsl/questions/templates/extract/answering_instructions.jinja +7 -7
- edsl/questions/templates/likert_five/answering_instructions.jinja +10 -10
- edsl/questions/templates/likert_five/question_presentation.jinja +11 -11
- edsl/questions/templates/linear_scale/answering_instructions.jinja +5 -5
- edsl/questions/templates/linear_scale/question_presentation.jinja +5 -5
- edsl/questions/templates/list/answering_instructions.jinja +3 -3
- edsl/questions/templates/list/question_presentation.jinja +5 -5
- edsl/questions/templates/multiple_choice/answering_instructions.jinja +9 -9
- edsl/questions/templates/multiple_choice/question_presentation.jinja +11 -11
- edsl/questions/templates/numerical/answering_instructions.jinja +6 -6
- edsl/questions/templates/numerical/question_presentation.jinja +6 -6
- edsl/questions/templates/rank/answering_instructions.jinja +11 -11
- edsl/questions/templates/rank/question_presentation.jinja +15 -15
- edsl/questions/templates/top_k/answering_instructions.jinja +8 -8
- edsl/questions/templates/top_k/question_presentation.jinja +22 -22
- edsl/questions/templates/yes_no/answering_instructions.jinja +6 -6
- edsl/questions/templates/yes_no/question_presentation.jinja +11 -11
- edsl/results/CSSParameterizer.py +108 -108
- edsl/results/Dataset.py +424 -587
- edsl/results/DatasetExportMixin.py +731 -653
- edsl/results/DatasetTree.py +275 -295
- edsl/results/Result.py +465 -451
- edsl/results/Results.py +1165 -1172
- edsl/results/ResultsDBMixin.py +238 -0
- edsl/results/ResultsExportMixin.py +43 -45
- edsl/results/ResultsFetchMixin.py +33 -33
- edsl/results/ResultsGGMixin.py +121 -121
- edsl/results/ResultsToolsMixin.py +98 -98
- edsl/results/Selector.py +135 -145
- edsl/results/TableDisplay.py +198 -125
- edsl/results/__init__.py +2 -2
- edsl/results/table_display.css +77 -77
- edsl/results/tree_explore.py +115 -115
- edsl/scenarios/FileStore.py +632 -511
- edsl/scenarios/Scenario.py +601 -498
- edsl/scenarios/ScenarioHtmlMixin.py +64 -65
- edsl/scenarios/ScenarioJoin.py +127 -131
- edsl/scenarios/ScenarioList.py +1287 -1430
- edsl/scenarios/ScenarioListExportMixin.py +52 -45
- edsl/scenarios/ScenarioListPdfMixin.py +261 -239
- edsl/scenarios/__init__.py +4 -3
- edsl/shared.py +1 -1
- edsl/study/ObjectEntry.py +173 -173
- edsl/study/ProofOfWork.py +113 -113
- edsl/study/SnapShot.py +80 -80
- edsl/study/Study.py +528 -521
- edsl/study/__init__.py +4 -4
- edsl/surveys/DAG.py +148 -148
- edsl/surveys/Memory.py +31 -31
- edsl/surveys/MemoryPlan.py +244 -244
- edsl/surveys/Rule.py +326 -327
- edsl/surveys/RuleCollection.py +387 -385
- edsl/surveys/Survey.py +1801 -1229
- edsl/surveys/SurveyCSS.py +261 -273
- edsl/surveys/SurveyExportMixin.py +259 -259
- edsl/surveys/{SurveyFlowVisualization.py → SurveyFlowVisualizationMixin.py} +179 -181
- edsl/surveys/SurveyQualtricsImport.py +284 -284
- edsl/surveys/__init__.py +3 -5
- edsl/surveys/base.py +53 -53
- edsl/surveys/descriptors.py +56 -60
- edsl/surveys/instructions/ChangeInstruction.py +49 -48
- edsl/surveys/instructions/Instruction.py +65 -56
- edsl/surveys/instructions/InstructionCollection.py +77 -82
- edsl/templates/error_reporting/base.html +23 -23
- edsl/templates/error_reporting/exceptions_by_model.html +34 -34
- edsl/templates/error_reporting/exceptions_by_question_name.html +16 -16
- edsl/templates/error_reporting/exceptions_by_type.html +16 -16
- edsl/templates/error_reporting/interview_details.html +115 -115
- edsl/templates/error_reporting/interviews.html +19 -19
- edsl/templates/error_reporting/overview.html +4 -4
- edsl/templates/error_reporting/performance_plot.html +1 -1
- edsl/templates/error_reporting/report.css +73 -73
- edsl/templates/error_reporting/report.html +117 -117
- edsl/templates/error_reporting/report.js +25 -25
- edsl/tools/__init__.py +1 -1
- edsl/tools/clusters.py +192 -192
- edsl/tools/embeddings.py +27 -27
- edsl/tools/embeddings_plotting.py +118 -118
- edsl/tools/plotting.py +112 -112
- edsl/tools/summarize.py +18 -18
- edsl/utilities/SystemInfo.py +28 -28
- edsl/utilities/__init__.py +22 -22
- edsl/utilities/ast_utilities.py +25 -25
- edsl/utilities/data/Registry.py +6 -6
- edsl/utilities/data/__init__.py +1 -1
- edsl/utilities/data/scooter_results.json +1 -1
- edsl/utilities/decorators.py +77 -77
- edsl/utilities/gcp_bucket/cloud_storage.py +96 -96
- edsl/utilities/interface.py +627 -627
- edsl/utilities/naming_utilities.py +263 -263
- edsl/utilities/repair_functions.py +28 -28
- edsl/utilities/restricted_python.py +70 -70
- edsl/utilities/utilities.py +424 -436
- {edsl-0.1.39.dev2.dist-info → edsl-0.1.39.dev3.dist-info}/LICENSE +21 -21
- {edsl-0.1.39.dev2.dist-info → edsl-0.1.39.dev3.dist-info}/METADATA +10 -12
- edsl-0.1.39.dev3.dist-info/RECORD +277 -0
- edsl/agents/QuestionInstructionPromptBuilder.py +0 -128
- edsl/agents/QuestionOptionProcessor.py +0 -172
- edsl/agents/QuestionTemplateReplacementsBuilder.py +0 -137
- edsl/coop/CoopFunctionsMixin.py +0 -15
- edsl/coop/ExpectedParrotKeyHandler.py +0 -125
- edsl/exceptions/inference_services.py +0 -5
- edsl/inference_services/AvailableModelCacheHandler.py +0 -184
- edsl/inference_services/AvailableModelFetcher.py +0 -209
- edsl/inference_services/ServiceAvailability.py +0 -135
- edsl/inference_services/data_structures.py +0 -62
- edsl/jobs/AnswerQuestionFunctionConstructor.py +0 -188
- edsl/jobs/FetchInvigilator.py +0 -40
- edsl/jobs/InterviewTaskManager.py +0 -98
- edsl/jobs/InterviewsConstructor.py +0 -48
- edsl/jobs/JobsComponentConstructor.py +0 -189
- edsl/jobs/JobsRemoteInferenceLogger.py +0 -239
- edsl/jobs/RequestTokenEstimator.py +0 -30
- edsl/jobs/buckets/TokenBucketAPI.py +0 -211
- edsl/jobs/buckets/TokenBucketClient.py +0 -191
- edsl/jobs/decorators.py +0 -35
- edsl/jobs/jobs_status_enums.py +0 -9
- edsl/jobs/loggers/HTMLTableJobLogger.py +0 -304
- edsl/language_models/ComputeCost.py +0 -63
- edsl/language_models/PriceManager.py +0 -127
- edsl/language_models/RawResponseHandler.py +0 -106
- edsl/language_models/ServiceDataSources.py +0 -0
- edsl/language_models/key_management/KeyLookup.py +0 -63
- edsl/language_models/key_management/KeyLookupBuilder.py +0 -273
- edsl/language_models/key_management/KeyLookupCollection.py +0 -38
- edsl/language_models/key_management/__init__.py +0 -0
- edsl/language_models/key_management/models.py +0 -131
- edsl/notebooks/NotebookToLaTeX.py +0 -142
- edsl/questions/ExceptionExplainer.py +0 -77
- edsl/questions/HTMLQuestion.py +0 -103
- edsl/questions/LoopProcessor.py +0 -149
- edsl/questions/QuestionMatrix.py +0 -265
- edsl/questions/ResponseValidatorFactory.py +0 -28
- edsl/questions/templates/matrix/__init__.py +0 -1
- edsl/questions/templates/matrix/answering_instructions.jinja +0 -5
- edsl/questions/templates/matrix/question_presentation.jinja +0 -20
- edsl/results/MarkdownToDocx.py +0 -122
- edsl/results/MarkdownToPDF.py +0 -111
- edsl/results/TextEditor.py +0 -50
- edsl/results/smart_objects.py +0 -96
- edsl/results/table_data_class.py +0 -12
- edsl/results/table_renderers.py +0 -118
- edsl/scenarios/ConstructDownloadLink.py +0 -109
- edsl/scenarios/DirectoryScanner.py +0 -96
- edsl/scenarios/DocumentChunker.py +0 -102
- edsl/scenarios/DocxScenario.py +0 -16
- edsl/scenarios/PdfExtractor.py +0 -40
- edsl/scenarios/ScenarioSelector.py +0 -156
- edsl/scenarios/file_methods.py +0 -85
- edsl/scenarios/handlers/__init__.py +0 -13
- edsl/scenarios/handlers/csv.py +0 -38
- edsl/scenarios/handlers/docx.py +0 -76
- edsl/scenarios/handlers/html.py +0 -37
- edsl/scenarios/handlers/json.py +0 -111
- edsl/scenarios/handlers/latex.py +0 -5
- edsl/scenarios/handlers/md.py +0 -51
- edsl/scenarios/handlers/pdf.py +0 -68
- edsl/scenarios/handlers/png.py +0 -39
- edsl/scenarios/handlers/pptx.py +0 -105
- edsl/scenarios/handlers/py.py +0 -294
- edsl/scenarios/handlers/sql.py +0 -313
- edsl/scenarios/handlers/sqlite.py +0 -149
- edsl/scenarios/handlers/txt.py +0 -33
- edsl/surveys/ConstructDAG.py +0 -92
- edsl/surveys/EditSurvey.py +0 -221
- edsl/surveys/InstructionHandler.py +0 -100
- edsl/surveys/MemoryManagement.py +0 -72
- edsl/surveys/RuleManager.py +0 -172
- edsl/surveys/Simulator.py +0 -75
- edsl/surveys/SurveyToApp.py +0 -141
- edsl/utilities/PrettyList.py +0 -56
- edsl/utilities/is_notebook.py +0 -18
- edsl/utilities/is_valid_variable_name.py +0 -11
- edsl/utilities/remove_edsl_version.py +0 -24
- edsl-0.1.39.dev2.dist-info/RECORD +0 -352
- {edsl-0.1.39.dev2.dist-info → edsl-0.1.39.dev3.dist-info}/WHEEL +0 -0
edsl/exceptions/questions.py
CHANGED
@@ -1,109 +1,91 @@
|
|
1
|
-
from typing import Any, SupportsIndex
|
2
|
-
import
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
class QuestionErrors(Exception):
|
7
|
-
"""
|
8
|
-
Base exception class for question-related errors.
|
9
|
-
"""
|
10
|
-
|
11
|
-
def __init__(self, message="An error occurred with the question"):
|
12
|
-
self.message = message
|
13
|
-
super().__init__(self.message)
|
14
|
-
|
15
|
-
|
16
|
-
class QuestionAnswerValidationError(QuestionErrors):
|
17
|
-
documentation = "https://docs.expectedparrot.com/en/latest/exceptions.html"
|
18
|
-
|
19
|
-
explanation = """This when the answer coming from the Language Model does not conform to the expectation for that question type.
|
20
|
-
For example, if the question is a multiple choice question, the answer should be drawn from the list of options provided.
|
21
|
-
"""
|
22
|
-
|
23
|
-
def __init__(
|
24
|
-
self
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
):
|
30
|
-
self
|
31
|
-
self.
|
32
|
-
self.
|
33
|
-
self.
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
"
|
58
|
-
"
|
59
|
-
"
|
60
|
-
"/
|
61
|
-
|
62
|
-
),
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
class QuestionAttributeMissing(QuestionErrors):
|
93
|
-
pass
|
94
|
-
|
95
|
-
|
96
|
-
class QuestionSerializationError(QuestionErrors):
|
97
|
-
pass
|
98
|
-
|
99
|
-
|
100
|
-
class QuestionScenarioRenderError(QuestionErrors):
|
101
|
-
pass
|
102
|
-
|
103
|
-
|
104
|
-
class QuestionMissingTypeError(QuestionErrors):
|
105
|
-
pass
|
106
|
-
|
107
|
-
|
108
|
-
class QuestionBadTypeError(QuestionErrors):
|
109
|
-
pass
|
1
|
+
from typing import Any, SupportsIndex
|
2
|
+
from jinja2 import Template
|
3
|
+
import json
|
4
|
+
|
5
|
+
|
6
|
+
class QuestionErrors(Exception):
|
7
|
+
"""
|
8
|
+
Base exception class for question-related errors.
|
9
|
+
"""
|
10
|
+
|
11
|
+
def __init__(self, message="An error occurred with the question"):
|
12
|
+
self.message = message
|
13
|
+
super().__init__(self.message)
|
14
|
+
|
15
|
+
|
16
|
+
class QuestionAnswerValidationError(QuestionErrors):
|
17
|
+
documentation = "https://docs.expectedparrot.com/en/latest/exceptions.html"
|
18
|
+
|
19
|
+
explanation = """This when the answer coming from the Language Model does not conform to the expectation for that question type.
|
20
|
+
For example, if the question is a multiple choice question, the answer should be drawn from the list of options provided.
|
21
|
+
"""
|
22
|
+
|
23
|
+
def __init__(self, message="Invalid answer.", data=None, model=None):
|
24
|
+
self.message = message
|
25
|
+
self.data = data
|
26
|
+
self.model = model
|
27
|
+
super().__init__(self.message)
|
28
|
+
|
29
|
+
def __str__(self):
|
30
|
+
return f"""{repr(self)}
|
31
|
+
Data being validated: {self.data}
|
32
|
+
Pydnantic Model: {self.model}.
|
33
|
+
Reported error: {self.message}."""
|
34
|
+
|
35
|
+
def to_html_dict(self):
|
36
|
+
return {
|
37
|
+
"error_type": ("Name of the exception", "p", "/p", self.__class__.__name__),
|
38
|
+
"explaination": ("Explanation", "p", "/p", self.explanation),
|
39
|
+
"edsl answer": (
|
40
|
+
"What model returned",
|
41
|
+
"pre",
|
42
|
+
"/pre",
|
43
|
+
json.dumps(self.data, indent=2),
|
44
|
+
),
|
45
|
+
"validating_model": (
|
46
|
+
"Pydantic model for answers",
|
47
|
+
"pre",
|
48
|
+
"/pre",
|
49
|
+
json.dumps(self.model.model_json_schema(), indent=2),
|
50
|
+
),
|
51
|
+
"error_message": (
|
52
|
+
"Error message Pydantic returned",
|
53
|
+
"p",
|
54
|
+
"/p",
|
55
|
+
self.message,
|
56
|
+
),
|
57
|
+
"documentation_url": (
|
58
|
+
"URL to EDSL docs",
|
59
|
+
f"a href='{self.documentation}'",
|
60
|
+
"/a",
|
61
|
+
self.documentation,
|
62
|
+
),
|
63
|
+
}
|
64
|
+
|
65
|
+
|
66
|
+
class QuestionCreationValidationError(QuestionErrors):
|
67
|
+
pass
|
68
|
+
|
69
|
+
|
70
|
+
class QuestionResponseValidationError(QuestionErrors):
|
71
|
+
pass
|
72
|
+
|
73
|
+
|
74
|
+
class QuestionAttributeMissing(QuestionErrors):
|
75
|
+
pass
|
76
|
+
|
77
|
+
|
78
|
+
class QuestionSerializationError(QuestionErrors):
|
79
|
+
pass
|
80
|
+
|
81
|
+
|
82
|
+
class QuestionScenarioRenderError(QuestionErrors):
|
83
|
+
pass
|
84
|
+
|
85
|
+
|
86
|
+
class QuestionMissingTypeError(QuestionErrors):
|
87
|
+
pass
|
88
|
+
|
89
|
+
|
90
|
+
class QuestionBadTypeError(QuestionErrors):
|
91
|
+
pass
|
edsl/exceptions/results.py
CHANGED
@@ -1,29 +1,29 @@
|
|
1
|
-
from edsl.exceptions.BaseException import BaseException
|
2
|
-
|
3
|
-
|
4
|
-
class ResultsError(BaseException):
|
5
|
-
relevant_docs = "https://docs.expectedparrot.com/en/latest/results.html"
|
6
|
-
|
7
|
-
|
8
|
-
class ResultsDeserializationError(ResultsError):
|
9
|
-
pass
|
10
|
-
|
11
|
-
|
12
|
-
class ResultsBadMutationstringError(ResultsError):
|
13
|
-
pass
|
14
|
-
|
15
|
-
|
16
|
-
class ResultsColumnNotFoundError(ResultsError):
|
17
|
-
pass
|
18
|
-
|
19
|
-
|
20
|
-
class ResultsInvalidNameError(ResultsError):
|
21
|
-
pass
|
22
|
-
|
23
|
-
|
24
|
-
class ResultsMutateError(ResultsError):
|
25
|
-
pass
|
26
|
-
|
27
|
-
|
28
|
-
class ResultsFilterError(ResultsError):
|
29
|
-
pass
|
1
|
+
from edsl.exceptions.BaseException import BaseException
|
2
|
+
|
3
|
+
|
4
|
+
class ResultsError(BaseException):
|
5
|
+
relevant_docs = "https://docs.expectedparrot.com/en/latest/results.html"
|
6
|
+
|
7
|
+
|
8
|
+
class ResultsDeserializationError(ResultsError):
|
9
|
+
pass
|
10
|
+
|
11
|
+
|
12
|
+
class ResultsBadMutationstringError(ResultsError):
|
13
|
+
pass
|
14
|
+
|
15
|
+
|
16
|
+
class ResultsColumnNotFoundError(ResultsError):
|
17
|
+
pass
|
18
|
+
|
19
|
+
|
20
|
+
class ResultsInvalidNameError(ResultsError):
|
21
|
+
pass
|
22
|
+
|
23
|
+
|
24
|
+
class ResultsMutateError(ResultsError):
|
25
|
+
pass
|
26
|
+
|
27
|
+
|
28
|
+
class ResultsFilterError(ResultsError):
|
29
|
+
pass
|
edsl/exceptions/scenarios.py
CHANGED
@@ -1,29 +1,22 @@
|
|
1
|
-
import re
|
2
|
-
import textwrap
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
def __init__(self, message):
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
def make_urls_clickable(text):
|
24
|
-
url_pattern = r"https?://[^\s]+"
|
25
|
-
urls = re.findall(url_pattern, text)
|
26
|
-
for url in urls:
|
27
|
-
clickable_url = f"\033]8;;{url}\007{url}\033]8;;\007"
|
28
|
-
text = text.replace(url, clickable_url)
|
29
|
-
return text
|
1
|
+
import re
|
2
|
+
import textwrap
|
3
|
+
|
4
|
+
|
5
|
+
class ScenarioError(Exception):
|
6
|
+
documentation = "https://docs.expectedparrot.com/en/latest/scenarios.html#module-edsl.scenarios.Scenario"
|
7
|
+
|
8
|
+
def __init__(self, message: str):
|
9
|
+
self.message = message + "\n" + "Documentation: " + self.documentation
|
10
|
+
super().__init__(self.message)
|
11
|
+
|
12
|
+
def __str__(self):
|
13
|
+
return self.make_urls_clickable(self.message)
|
14
|
+
|
15
|
+
@staticmethod
|
16
|
+
def make_urls_clickable(text):
|
17
|
+
url_pattern = r"https?://[^\s]+"
|
18
|
+
urls = re.findall(url_pattern, text)
|
19
|
+
for url in urls:
|
20
|
+
clickable_url = f"\033]8;;{url}\007{url}\033]8;;\007"
|
21
|
+
text = text.replace(url, clickable_url)
|
22
|
+
return text
|
edsl/exceptions/surveys.py
CHANGED
@@ -1,37 +1,37 @@
|
|
1
|
-
from edsl.exceptions.BaseException import BaseException
|
2
|
-
|
3
|
-
|
4
|
-
class SurveyError(BaseException):
|
5
|
-
relevant_doc = "https://docs.expectedparrot.com/en/latest/surveys.html"
|
6
|
-
|
7
|
-
|
8
|
-
class SurveyCreationError(SurveyError):
|
9
|
-
pass
|
10
|
-
|
11
|
-
|
12
|
-
class SurveyHasNoRulesError(SurveyError):
|
13
|
-
pass
|
14
|
-
|
15
|
-
|
16
|
-
class SurveyRuleSendsYouBackwardsError(SurveyError):
|
17
|
-
pass
|
18
|
-
|
19
|
-
|
20
|
-
class SurveyRuleSkipLogicSyntaxError(SurveyError):
|
21
|
-
pass
|
22
|
-
|
23
|
-
|
24
|
-
class SurveyRuleReferenceInRuleToUnknownQuestionError(SurveyError):
|
25
|
-
pass
|
26
|
-
|
27
|
-
|
28
|
-
class SurveyRuleRefersToFutureStateError(SurveyError):
|
29
|
-
pass
|
30
|
-
|
31
|
-
|
32
|
-
class SurveyRuleCollectionHasNoRulesAtNodeError(SurveyError):
|
33
|
-
pass
|
34
|
-
|
35
|
-
|
36
|
-
class SurveyRuleCannotEvaluateError(SurveyError):
|
37
|
-
pass
|
1
|
+
from edsl.exceptions.BaseException import BaseException
|
2
|
+
|
3
|
+
|
4
|
+
class SurveyError(BaseException):
|
5
|
+
relevant_doc = "https://docs.expectedparrot.com/en/latest/surveys.html"
|
6
|
+
|
7
|
+
|
8
|
+
class SurveyCreationError(SurveyError):
|
9
|
+
pass
|
10
|
+
|
11
|
+
|
12
|
+
class SurveyHasNoRulesError(SurveyError):
|
13
|
+
pass
|
14
|
+
|
15
|
+
|
16
|
+
class SurveyRuleSendsYouBackwardsError(SurveyError):
|
17
|
+
pass
|
18
|
+
|
19
|
+
|
20
|
+
class SurveyRuleSkipLogicSyntaxError(SurveyError):
|
21
|
+
pass
|
22
|
+
|
23
|
+
|
24
|
+
class SurveyRuleReferenceInRuleToUnknownQuestionError(SurveyError):
|
25
|
+
pass
|
26
|
+
|
27
|
+
|
28
|
+
class SurveyRuleRefersToFutureStateError(SurveyError):
|
29
|
+
pass
|
30
|
+
|
31
|
+
|
32
|
+
class SurveyRuleCollectionHasNoRulesAtNodeError(SurveyError):
|
33
|
+
pass
|
34
|
+
|
35
|
+
|
36
|
+
class SurveyRuleCannotEvaluateError(SurveyError):
|
37
|
+
pass
|
@@ -1,84 +1,87 @@
|
|
1
|
-
import os
|
2
|
-
from typing import Any, Optional, List
|
3
|
-
import re
|
4
|
-
from anthropic import AsyncAnthropic
|
5
|
-
from edsl.inference_services.InferenceServiceABC import InferenceServiceABC
|
6
|
-
from edsl.language_models.LanguageModel import LanguageModel
|
7
|
-
|
8
|
-
|
9
|
-
class AnthropicService(InferenceServiceABC):
|
10
|
-
"""Anthropic service class."""
|
11
|
-
|
12
|
-
_inference_service_ = "anthropic"
|
13
|
-
_env_key_name_ = "ANTHROPIC_API_KEY"
|
14
|
-
key_sequence = ["content", 0, "text"] # ["content"][0]["text"]
|
15
|
-
usage_sequence = ["usage"]
|
16
|
-
input_token_name = "input_tokens"
|
17
|
-
output_token_name = "output_tokens"
|
18
|
-
model_exclude_list = []
|
19
|
-
|
20
|
-
@classmethod
|
21
|
-
def available(cls):
|
22
|
-
# TODO - replace with an API call
|
23
|
-
return [
|
24
|
-
"claude-3-5-sonnet-20240620",
|
25
|
-
"claude-3-opus-20240229",
|
26
|
-
"claude-3-sonnet-20240229",
|
27
|
-
"claude-3-haiku-20240307",
|
28
|
-
]
|
29
|
-
|
30
|
-
@classmethod
|
31
|
-
def create_model(
|
32
|
-
cls, model_name: str = "claude-3-opus-20240229", model_class_name=None
|
33
|
-
) -> LanguageModel:
|
34
|
-
if model_class_name is None:
|
35
|
-
model_class_name = cls.to_class_name(model_name)
|
36
|
-
|
37
|
-
class LLM(LanguageModel):
|
38
|
-
"""
|
39
|
-
Child class of LanguageModel for interacting with OpenAI models
|
40
|
-
"""
|
41
|
-
|
42
|
-
key_sequence = cls.key_sequence
|
43
|
-
usage_sequence = cls.usage_sequence
|
44
|
-
input_token_name = cls.input_token_name
|
45
|
-
output_token_name = cls.output_token_name
|
46
|
-
|
47
|
-
_inference_service_ = cls._inference_service_
|
48
|
-
_model_ = model_name
|
49
|
-
_parameters_ = {
|
50
|
-
"temperature": 0.5,
|
51
|
-
"max_tokens": 1000,
|
52
|
-
"top_p": 1,
|
53
|
-
"frequency_penalty": 0,
|
54
|
-
"presence_penalty": 0,
|
55
|
-
"logprobs": False,
|
56
|
-
"top_logprobs": 3,
|
57
|
-
}
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
1
|
+
import os
|
2
|
+
from typing import Any, Optional, List
|
3
|
+
import re
|
4
|
+
from anthropic import AsyncAnthropic
|
5
|
+
from edsl.inference_services.InferenceServiceABC import InferenceServiceABC
|
6
|
+
from edsl.language_models.LanguageModel import LanguageModel
|
7
|
+
|
8
|
+
|
9
|
+
class AnthropicService(InferenceServiceABC):
|
10
|
+
"""Anthropic service class."""
|
11
|
+
|
12
|
+
_inference_service_ = "anthropic"
|
13
|
+
_env_key_name_ = "ANTHROPIC_API_KEY"
|
14
|
+
key_sequence = ["content", 0, "text"] # ["content"][0]["text"]
|
15
|
+
usage_sequence = ["usage"]
|
16
|
+
input_token_name = "input_tokens"
|
17
|
+
output_token_name = "output_tokens"
|
18
|
+
model_exclude_list = []
|
19
|
+
|
20
|
+
@classmethod
|
21
|
+
def available(cls):
|
22
|
+
# TODO - replace with an API call
|
23
|
+
return [
|
24
|
+
"claude-3-5-sonnet-20240620",
|
25
|
+
"claude-3-opus-20240229",
|
26
|
+
"claude-3-sonnet-20240229",
|
27
|
+
"claude-3-haiku-20240307",
|
28
|
+
]
|
29
|
+
|
30
|
+
@classmethod
|
31
|
+
def create_model(
|
32
|
+
cls, model_name: str = "claude-3-opus-20240229", model_class_name=None
|
33
|
+
) -> LanguageModel:
|
34
|
+
if model_class_name is None:
|
35
|
+
model_class_name = cls.to_class_name(model_name)
|
36
|
+
|
37
|
+
class LLM(LanguageModel):
|
38
|
+
"""
|
39
|
+
Child class of LanguageModel for interacting with OpenAI models
|
40
|
+
"""
|
41
|
+
|
42
|
+
key_sequence = cls.key_sequence
|
43
|
+
usage_sequence = cls.usage_sequence
|
44
|
+
input_token_name = cls.input_token_name
|
45
|
+
output_token_name = cls.output_token_name
|
46
|
+
|
47
|
+
_inference_service_ = cls._inference_service_
|
48
|
+
_model_ = model_name
|
49
|
+
_parameters_ = {
|
50
|
+
"temperature": 0.5,
|
51
|
+
"max_tokens": 1000,
|
52
|
+
"top_p": 1,
|
53
|
+
"frequency_penalty": 0,
|
54
|
+
"presence_penalty": 0,
|
55
|
+
"logprobs": False,
|
56
|
+
"top_logprobs": 3,
|
57
|
+
}
|
58
|
+
|
59
|
+
_tpm = cls.get_tpm(cls)
|
60
|
+
_rpm = cls.get_rpm(cls)
|
61
|
+
|
62
|
+
async def async_execute_model_call(
|
63
|
+
self,
|
64
|
+
user_prompt: str,
|
65
|
+
system_prompt: str = "",
|
66
|
+
files_list: Optional[List["Files"]] = None,
|
67
|
+
) -> dict[str, Any]:
|
68
|
+
"""Calls the OpenAI API and returns the API response."""
|
69
|
+
|
70
|
+
api_key = os.environ.get("ANTHROPIC_API_KEY")
|
71
|
+
client = AsyncAnthropic(api_key=api_key)
|
72
|
+
|
73
|
+
response = await client.messages.create(
|
74
|
+
model=model_name,
|
75
|
+
max_tokens=self.max_tokens,
|
76
|
+
temperature=self.temperature,
|
77
|
+
system=system_prompt,
|
78
|
+
messages=[
|
79
|
+
# {"role": "system", "content": system_prompt},
|
80
|
+
{"role": "user", "content": user_prompt},
|
81
|
+
],
|
82
|
+
)
|
83
|
+
return response.model_dump()
|
84
|
+
|
85
|
+
LLM.__name__ = model_class_name
|
86
|
+
|
87
|
+
return LLM
|