Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[OTHER] Long-running callbacks tasks #2294

Open
1 of 2 tasks
JosuaCarl opened this issue Nov 29, 2024 · 1 comment
Open
1 of 2 tasks

[OTHER] Long-running callbacks tasks #2294

JosuaCarl opened this issue Nov 29, 2024 · 1 comment
Assignees
Labels
Core Related to Taipy Core 🖰 GUI Related to GUI ❓ Question Can be unblocked with an answer 🔒 Staff only Can only be assigned to the Taipy R&D team

Comments

@JosuaCarl
Copy link
Contributor

What would you like to share or ask?

Hi, I would like to use long-running functions in a scenario, without basically freezing my application.
I tried to implement my functions with invoke_long_callback, but I don't grasp how to correctly pass on a state as a data_node, as it is otherwise not passable. Do you have any tips/examples of heavy functions in scenarios ? Maybe I'm getting this all wrong and scenarios deal with heavy functions in a completely different way.

Code of Conduct

  • I have checked the existing issues.
  • I am willing to work on this issue (optional)
@FlorianJacta
Copy link
Member

FlorianJacta commented Nov 29, 2024

Can you specify your use case? Do you have some code?

Scenario should be used asynchronously. Then, you can use Core viz elements to show data in real time or track the progress in real time.

Using Data Node viewer

from taipy import Config
import taipy as tp
import taipy.gui.builder as tgb
import pandas as pd
import datetime as dt


data = pd.read_csv("https://raw.githubusercontent.com/Avaiga/taipy-getting-started-core/develop/src/daily-min-temperatures.csv")


# Normal function used by Taipy
def predict(historical_temperature: pd.DataFrame, date_to_forecast: dt.datetime) -> float:
    print(f"Running baseline...")
    historical_temperature["Date"] = pd.to_datetime(historical_temperature["Date"])
    historical_same_day = historical_temperature.loc[
        (historical_temperature["Date"].dt.day == date_to_forecast.day) &
        (historical_temperature["Date"].dt.month == date_to_forecast.month)
    ]
    return historical_same_day["Temp"].mean()

# Configuration of Data Nodes
historical_temperature_cfg = Config.configure_data_node("historical_temperature")
date_to_forecast_cfg = Config.configure_data_node("date_to_forecast")
predictions_cfg = Config.configure_data_node("predictions")

# Configuration of tasks
task_predict_cfg = Config.configure_task("predict",
                                        predict,
                                        [historical_temperature_cfg, date_to_forecast_cfg],
                                        predictions_cfg)

# Configuration of scenario
scenario_cfg = Config.configure_scenario(id="my_scenario",
                                         task_configs=[task_predict_cfg])

Config.export("config.toml")

if __name__ == "__main__":
    # Run of the Orchestrator
    tp.Orchestrator().run()

    # Creation of the scenario and execution
    scenario = tp.create_scenario(scenario_cfg)
    scenario.historical_temperature.write(data)
    scenario.date_to_forecast.write(dt.datetime.now())
    tp.submit(scenario)

    print("Value at the end of task", scenario.predictions.read())

    def save(state):
        state.scenario.historical_temperature.write(data)
        state.scenario.date_to_forecast.write(state.date)
        state.refresh("scenario")
        tp.gui.notify(state, "s", "Saved! Ready to submit")

    date = None
    with tgb.Page() as scenario_page:
        tgb.scenario_selector("{scenario}")
        tgb.text("Select a Date")
        tgb.date("{date}", on_change=save, active="{scenario}")

        tgb.text("Run the scenario")
        tgb.scenario("{scenario}")
        tgb.scenario_dag("{scenario}")

        tgb.text("View all the information on your prediction here")
        tgb.data_node("{scenario.predictions}")

    tp.Gui(scenario_page).run()

Using Scenario viewer

import taipy as tp
from taipy.common.config import Config
from taipy.core import Status
from taipy.gui import Gui, notify
import taipy.gui.builder as tgb


Config.configure_job_executions(mode="standalone", max_nb_of_workers=2)


# Normal function used by Taipy
def double(nb):
    return nb * 2


def add(nb):
    return nb + 10


def on_submission_status_change(state=None, submittable=None, details=None):
    submission_status = details.get("submission_status")

    if submission_status == "COMPLETED":
        print(details)
        notify(state, "success", "Completed!")
        # Add additional actions here, like updating the GUI or logging the completion.

    elif submission_status == "FAILED":
        notify(state, "error", "Completed!")
        # Handle failure, like sending notifications or logging the error.

    # Add more conditions for other statuses as needed.


if __name__ == "__main__":
    # Configuration of Data Nodes
    input_cfg = Config.configure_data_node("my_input", default_data=21)
    intermediate_cfg = Config.configure_data_node("intermediate")
    output_cfg = Config.configure_data_node("my_output")

    # Configuration of tasks
    first_task_cfg = Config.configure_task(
        "double", double, input_cfg, intermediate_cfg
    )

    second_task_cfg = Config.configure_task("add", add, intermediate_cfg, output_cfg)

    # Configuration of scenario
    scenario_cfg = Config.configure_scenario(
        id="my_scenario",
        task_configs=[first_task_cfg, second_task_cfg],
        name="my_scenario",
    )

    tp.Orchestrator().run()
    scenario_1 = tp.create_scenario(scenario_cfg)

    scenario_1.submit(wait=True)

    with tgb.Page() as page:
        tgb.scenario("{scenario_1}", on_submission_change=on_submission_status_change)

    Gui(page).run()

@FlorianJacta FlorianJacta added Core Related to Taipy Core 🖰 GUI Related to GUI ❓ Question Can be unblocked with an answer labels Dec 6, 2024
@jrobinAV jrobinAV added the 🔒 Staff only Can only be assigned to the Taipy R&D team label Dec 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Core Related to Taipy Core 🖰 GUI Related to GUI ❓ Question Can be unblocked with an answer 🔒 Staff only Can only be assigned to the Taipy R&D team
Projects
None yet
Development

No branches or pull requests

3 participants