import { Duration } from "@tsplus/stdlib/data/Duration";
import { Chunk } from "@tsplus/stdlib/collections/Chunk/definition";
import { Effect } from "@effect/core/io/Effect/definition";
import { Stream } from "@effect/core/stream/Stream/definition";
import { Channel } from "@effect/core/stream/Channel/definition/base";
/**
* Delays the chunks of this stream according to the given bandwidth
* parameters using the token bucket algorithm. Allows for burst in the
* processing of elements by allowing the token bucket to accumulate tokens up
* to a `units + burst` threshold. The weight of each chunk is determined by
* the `costFn` effectful function.
* @tsplus static effect/core/stream/Stream.Aspects throttleShapeEffect
* @tsplus pipeable effect/core/stream/Stream throttleShapeEffect
* @tsplus location "@effect/core/stream/Stream/operations/throttleShapeEffect"
*/
export declare function throttleShapeEffect(units: number, duration: Duration, costFn: (input: Chunk) => Effect, burst?: number): (self: import("../definition").Stream) => import("../definition").Stream;
//# sourceMappingURL=throttleShapeEffect.d.ts.map