langfun 0.1.2.dev202509020804__py3-none-any.whl → 0.1.2.dev202509040804__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.

Potentially problematic release.


This version of langfun might be problematic. Click here for more details.

@@ -61,6 +61,7 @@ from langfun.core.llms.google_genai import Gemini15Flash8B_001
61
61
  from langfun.core.llms.google_genai import Gemini2ProExp_20250205
62
62
  from langfun.core.llms.google_genai import Gemini2FlashThinkingExp_20250121
63
63
  from langfun.core.llms.google_genai import GeminiExp_20241206
64
+ from langfun.core.llms.google_genai import Gemini25FlashImagePreview
64
65
 
65
66
  from langfun.core.llms.vertexai import VertexAIGemini
66
67
  from langfun.core.llms.vertexai import VertexAIGemini2Flash
@@ -86,6 +87,7 @@ from langfun.core.llms.vertexai import VertexAIGemini25FlashPreview_20250520
86
87
  from langfun.core.llms.vertexai import VertexAIGemini25ProPreview_20250605
87
88
  from langfun.core.llms.vertexai import VertexAIGemini25Pro
88
89
  from langfun.core.llms.vertexai import VertexAIGemini25Flash
90
+ from langfun.core.llms.vertexai import VertexAIGemini25FlashImagePreview
89
91
 
90
92
  # For backward compatibility.
91
93
  GeminiPro1_5 = Gemini15Pro
@@ -195,7 +195,7 @@ SUPPORTED_MODELS = [
195
195
  rate_limits=lf.ModelInfo.RateLimits(
196
196
  max_requests_per_minute=2000,
197
197
  max_tokens_per_minute=4_000_000,
198
- )
198
+ ),
199
199
  ),
200
200
  # Gemini 2.5 Pro 0605
201
201
  GeminiModelInfo(
@@ -218,7 +218,7 @@ SUPPORTED_MODELS = [
218
218
  rate_limits=lf.ModelInfo.RateLimits(
219
219
  max_requests_per_minute=2000,
220
220
  max_tokens_per_minute=4_000_000,
221
- )
221
+ ),
222
222
  ),
223
223
  # Gemini 2.5 Flash Preview 0520
224
224
  GeminiModelInfo(
@@ -264,7 +264,7 @@ SUPPORTED_MODELS = [
264
264
  rate_limits=lf.ModelInfo.RateLimits(
265
265
  max_requests_per_minute=2000,
266
266
  max_tokens_per_minute=4_000_000,
267
- )
267
+ ),
268
268
  ),
269
269
  # Gemini 2.5 Flash Preview
270
270
  GeminiModelInfo(
@@ -614,6 +614,21 @@ SUPPORTED_MODELS = [
614
614
  #
615
615
  # Experimental models.
616
616
  #
617
+ GeminiModelInfo(
618
+ model_id='gemini-2.5-flash-image-preview',
619
+ in_service=True,
620
+ experimental=True,
621
+ provider=pg.oneof(['Google GenAI', 'VertexAI']),
622
+ model_type='instruction-tuned',
623
+ description='Gemini 2.5 Flash Image Preview model.',
624
+ release_date=datetime.datetime(2025, 8, 17),
625
+ input_modalities=GeminiModelInfo.INPUT_IMAGE_TYPES
626
+ + GeminiModelInfo.INPUT_DOC_TYPES,
627
+ context_length=lf.ModelInfo.ContextLength(
628
+ max_input_tokens=32_768,
629
+ max_output_tokens=32_768,
630
+ ),
631
+ ),
617
632
  GeminiModelInfo(
618
633
  model_id='gemini-2.0-pro-exp-02-05',
619
634
  in_service=True,
@@ -690,6 +705,12 @@ class Gemini(rest.REST):
690
705
  'The name of the model to use.',
691
706
  ]
692
707
 
708
+ response_modalities: pg.typing.Annotated[
709
+ list[str] | None,
710
+ 'Response modalities. It is needed for models whose response modalities '
711
+ + 'are more than plain text.',
712
+ ] = None
713
+
693
714
  @functools.cached_property
694
715
  def model_info(self) -> GeminiModelInfo:
695
716
  return _SUPPORTED_MODELS_BY_ID[self.model]
@@ -768,6 +789,11 @@ class Gemini(rest.REST):
768
789
  'thinkingBudget': options.max_thinking_tokens,
769
790
  }
770
791
 
792
+ if self.response_modalities:
793
+ config['responseModalities'] = self.response_modalities
794
+ if 'IMAGE' in self.response_modalities:
795
+ config.pop('responseLogprobs', None)
796
+ config.pop('logprobs', None)
771
797
  return config
772
798
 
773
799
  def result(self, json: dict[str, Any]) -> lf.LMSamplingResult:
@@ -92,6 +92,11 @@ class GenAI(gemini.Gemini):
92
92
  #
93
93
 
94
94
 
95
+ class Gemini25FlashImagePreview(GenAI):
96
+ """Gemini 2.5 Flash Image Preview model."""
97
+ model = 'gemini-2.5-flash-image-preview'
98
+
99
+
95
100
  class Gemini25Pro(GenAI):
96
101
  """Gemini 2.5 Pro GA model."""
97
102
 
@@ -284,6 +284,14 @@ class VertexAIGemini15Flash8B_001(VertexAIGemini): # pylint: disable=invalid-na
284
284
  #
285
285
 
286
286
 
287
+ class VertexAIGemini25FlashImagePreview(VertexAIGemini): # pylint: disable=invalid-name
288
+ """Gemini 2.5 Flash Image Preview model."""
289
+
290
+ model = 'gemini-2.5-flash-image-preview'
291
+ location = 'global'
292
+ response_modalities = ['TEXT', 'IMAGE']
293
+
294
+
287
295
  class VertexAIGemini2ProExp_20250205(VertexAIGemini): # pylint: disable=invalid-name
288
296
  """Gemini Flash 2.0 Pro model launched on 02/05/2025."""
289
297
  model = 'gemini-2.0-pro-exp-02-05'
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: langfun
3
- Version: 0.1.2.dev202509020804
3
+ Version: 0.1.2.dev202509040804
4
4
  Summary: Langfun: Language as Functions.
5
5
  Home-page: https://github.com/google/langfun
6
6
  Author: Langfun Authors
@@ -90,7 +90,7 @@ langfun/core/eval/v2/reporting.py,sha256=yUIPCAMnp7InIzpv1DDWrcLO-75iiOUTpscj7sm
90
90
  langfun/core/eval/v2/reporting_test.py,sha256=CMK-vwho8cNRJwlbkCqm_v5fykE7Y3V6SaIOCY0CDyA,5671
91
91
  langfun/core/eval/v2/runners.py,sha256=bEniZDNu44AQgvqpwLsvBU4V_7WltAe-NPhYgIsLj1E,16848
92
92
  langfun/core/eval/v2/runners_test.py,sha256=spjkmqlls_vyERdZMdjv6dhIN9ZfxsDDvIQAWTj2kMk,11954
93
- langfun/core/llms/__init__.py,sha256=CtxUdXohQ8AQk1DqBT6MBy2zdAoPSggNo00SYrj9-AY,9521
93
+ langfun/core/llms/__init__.py,sha256=VrVwI9gwPp4KEZdWbg-uQESg41L4VXPXMyWiGDkZNQo,9663
94
94
  langfun/core/llms/anthropic.py,sha256=YcQ2VG8iOfXtry_tTpAukmiwXa2hK_9LkpkmXk41Nm0,26226
95
95
  langfun/core/llms/anthropic_test.py,sha256=qA9vByp_cwwXNlXzcwHpPWFnO9lfFo8NKfDi5nBNqgI,9052
96
96
  langfun/core/llms/azure_openai.py,sha256=-KkSLaR54MlsIqz_XIwv0TnsBnvNTAxnjA2Q2O2u5KM,2733
@@ -101,9 +101,9 @@ langfun/core/llms/deepseek.py,sha256=jvTxdXPr-vH6HNakn_Ootx1heDg8Fen2FUkUW36bpCs
101
101
  langfun/core/llms/deepseek_test.py,sha256=DvROWPlDuow5E1lfoSkhyGt_ELA19JoQoDsTnRgDtTg,1847
102
102
  langfun/core/llms/fake.py,sha256=xmgCkk9y0I4x0IT32SZ9_OT27aLadXH8PRiYNo5VTd4,3265
103
103
  langfun/core/llms/fake_test.py,sha256=2h13qkwEz_JR0mtUDPxdAhQo7MueXaFSwsD2DIRDW9g,7653
104
- langfun/core/llms/gemini.py,sha256=umrEJGnZb_U4CCbFHicaoVsBuEdZGg7QGNkr-mSJidw,29061
104
+ langfun/core/llms/gemini.py,sha256=r4WVWMWHVtyR7tf4NdJ_eAL8Uq6OyQU_2-yBbzrx5mQ,30065
105
105
  langfun/core/llms/gemini_test.py,sha256=y1s0W65SrdepbZxzgIeoTB2MI7sXnfBDf1NsGn57LbM,7617
106
- langfun/core/llms/google_genai.py,sha256=3VbNMQORUBSTzFAMY_6c4Nd9tesP9lGoKMrlP9m-80c,5787
106
+ langfun/core/llms/google_genai.py,sha256=ogyoOUK4s1OcSFKun0YK5xBRDVyxmvz9WsYNKAwuB0g,5918
107
107
  langfun/core/llms/google_genai_test.py,sha256=NKNtpebArQ9ZR7Qsnhd2prFIpMjleojy6o6VMXkJ1zY,1502
108
108
  langfun/core/llms/groq.py,sha256=S9V10kFo3cgX89qPgt_umq-SpRnxEDLTt_hJmpERfbo,12066
109
109
  langfun/core/llms/groq_test.py,sha256=P4EgexCqsh4K2x11w0UL_vz-YYNaPdQU0WsDAdnTRQ8,2045
@@ -115,7 +115,7 @@ langfun/core/llms/openai_compatible_test.py,sha256=KwOMA7tsmOxFBjezltkBDSU77AvOQ
115
115
  langfun/core/llms/openai_test.py,sha256=gwuO6aoa296iM2welWV9ua4KF8gEVGsEPakgbtkWkFQ,2687
116
116
  langfun/core/llms/rest.py,sha256=mY9n0sMAtf0RsvTBgbYHDxGzGD9WLIkocALEHXAL5r4,4583
117
117
  langfun/core/llms/rest_test.py,sha256=_zM7nV8DEVyoXNiQOnuwJ917mWjki0614H88rNmDboE,5020
118
- langfun/core/llms/vertexai.py,sha256=4oE3coQtkNB43ATvwQAaVX7YqWXdnHZoKVM8lde8EpU,20000
118
+ langfun/core/llms/vertexai.py,sha256=M0GySUbTukyfc6Pwo7i6AX4uapYyshY49VfPsTU8xac,20245
119
119
  langfun/core/llms/vertexai_test.py,sha256=_e-acnNBAf9C3WO6i1b2J_mhRzdDdYQTorD9hIVZKOg,5034
120
120
  langfun/core/llms/cache/__init__.py,sha256=QAo3InUMDM_YpteNnVCSejI4zOsnjSMWKJKzkb3VY64,993
121
121
  langfun/core/llms/cache/base.py,sha256=rt3zwmyw0y9jsSGW-ZbV1vAfLxQ7_3AVk0l2EySlse4,3918
@@ -165,8 +165,8 @@ langfun/core/templates/demonstration.py,sha256=vCrgYubdZM5Umqcgp8NUVGXgr4P_c-fik
165
165
  langfun/core/templates/demonstration_test.py,sha256=SafcDQ0WgI7pw05EmPI2S4v1t3ABKzup8jReCljHeK4,2162
166
166
  langfun/core/templates/selfplay.py,sha256=yhgrJbiYwq47TgzThmHrDQTF4nDrTI09CWGhuQPNv-s,2273
167
167
  langfun/core/templates/selfplay_test.py,sha256=Ot__1P1M8oJfoTp-M9-PQ6HUXqZKyMwvZ5f7yQ3yfyM,2326
168
- langfun-0.1.2.dev202509020804.dist-info/licenses/LICENSE,sha256=WNHhf_5RCaeuKWyq_K39vmp9F28LxKsB4SpomwSZ2L0,11357
169
- langfun-0.1.2.dev202509020804.dist-info/METADATA,sha256=MZpp4VIDj5JoSMmcevB9VEKV74DpqCDJXRZftxeAKPI,7380
170
- langfun-0.1.2.dev202509020804.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
171
- langfun-0.1.2.dev202509020804.dist-info/top_level.txt,sha256=RhlEkHxs1qtzmmtWSwYoLVJAc1YrbPtxQ52uh8Z9VvY,8
172
- langfun-0.1.2.dev202509020804.dist-info/RECORD,,
168
+ langfun-0.1.2.dev202509040804.dist-info/licenses/LICENSE,sha256=WNHhf_5RCaeuKWyq_K39vmp9F28LxKsB4SpomwSZ2L0,11357
169
+ langfun-0.1.2.dev202509040804.dist-info/METADATA,sha256=Dau1NcO_2ibt6kdGDyO-x4EaR2wTbOQTMRpVfdmKYIo,7380
170
+ langfun-0.1.2.dev202509040804.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
171
+ langfun-0.1.2.dev202509040804.dist-info/top_level.txt,sha256=RhlEkHxs1qtzmmtWSwYoLVJAc1YrbPtxQ52uh8Z9VvY,8
172
+ langfun-0.1.2.dev202509040804.dist-info/RECORD,,