摄影-曝光口诀(阳光16法则)

本文介绍了摄影中的阳光16法则,包括不同天气条件下摄影曝光的基本规则和计算方式,帮助摄影师掌握在各种光线环境下正确的曝光设置。

http://www.j-sunny.com/?p=1297

摄影-曝光口诀(阳光16法则)

口决:艳阳十六阴天八,多云十一日暮四,阴云压顶五点六,雨天落雪同日暮,室内球场二秒足,客厅戏台快门八。

阳光灿烂直射阳光下

ISO, T(快门), F(光圈)

100, 1/100, 16

100, 1/200, 11

100, 1/400, 8

100, 1/800, 5.6

100, 1/1600, 4

多云天气户外阳光下

ISO, T(快门), F(光圈)

100, 1/100, 11

100, 1/200, 8

100, 1/400, 5.6

100, 1/800, 4

100, 1/1600, 2.8

阴天户外天光下

ISO, T(快门), F(光圈)

100, 1/100, 8

100, 1/200, 5.6

100, 1/400, 4

100, 1/800, 2.8

100, 1/1600, 2

下雨时或下雨前户外

ISO, T(快门), F(光圈)

100, 1/100, 5.6

100, 1/200, 4

100, 1/400, 2.8

100, 1/800, 2

100, 1/1600, 1.4

快门表:1/100、1/200、1/400、1/800、1/1600、1/3200、1/6400(按一档变化,曝光减一半)

光圈表:1、1.4、2、2.8、4、5.6、8、11、16、22(按一档变化,曝光减一半)

盘算方式就是:当ISO不变时,快门减少一档(即快门速度乘1/2),则光圈增添一档

该法则要依据空气污染和时光做调整,以艳阳16为例,在现在的冬天只能在上午九点半到下午三点半之间使用,而上午八点半到九点半要用8――11的样子,自行试验了。

1/15――1/30是翻拍电视的安全快门.

“阳光16法则”,不是指景致摄影中光圈用法的法则,仅仅是一个便于记忆,到达摄影请求曝光基础正确的一个法则而已。然后用倒易律进行快门和光圈的组合以到达摄影者的构思请求。

在众多的优良摄影作品中,很少有用F22的光圈的作品(没有人说不可以用),用F16的光圈都很少。另外在风光摄影中,大多数人(不是全体)都不用135这样的小型相机,至少应当是120这样的中幅相机。

对中幅相机而言,尺度镜头都是80~110毫米,因此有一些特色也和小型相机不一样。如同样是F11的光圈,绝对孔径是大不一样的。光的衍射现象只对绝对孔径而言的。

数码相机的手动功能有没有用,是看其能不能照出与主动功能不一样的后果,如果都差不多,显然是没有用,如果差异很大,那就非常有用。ni用不用它的手动功效与手动功效有没有用是完整不同的概念。

上面说到最佳光圈是F8,其实很多镜头的最佳光圈是5.6左右。同时,对于不同的摄影,用的光圈也不雷同,景致摄影一般使用F11的光圈或者更小,所以在摄影中有“阳光16法则”,也就是在阳光充分的处所,使用F16的光圈,快门速度为ISO值的导数。

阳光16法是室外暴光的估计方式,由于wo过去长期使用无测光功效的全手动机,就的用估量暴光参数,现在将wo的估量办法介绍给大家,大家可以试一下(这个全凭经验,多试试就控制了):

1.阳光灿烂(被摄体有显明的影子)――F16+快门(胶卷ISO倒数)

2.薄云(被摄体有淡淡的影子)――F11+快门(胶卷ISO倒数)

3.厚云(被摄体几乎没有影子)――F8+快门(胶卷ISO倒数)

4.阴天――F5.6+快门(胶卷ISO倒数)

注意一下几点:

1.以上估量值实用于春秋两季的日出后两小时和日落前两小时;在夏季要缩小一档光圈,冬季开大一档光圈;

2.阳光下,被摄体正面受光时实用,侧面受光时加一档光圈;背面受光时加2-3档光圈;

3.阳光下的开阔暗影处可参照阴天的暴光量。

### L1-0080 乘法口诀数列算法实现 #### 算法描述 该问题的核心在于通过模拟的方式生成一个由初始两个数 `a1` 和 `a2` 开始的序列 `{an}`。具体规则如下: 从第一个数开始,依次计算当前项与其下一项的乘积,并将结果按位拆分加入到序列中。如果乘积是一个两位数,则需分别将其十位和个位作为独立的两项加入序列。 为了高效存储动态增长的数据结构,可以采用 C++ 中的 `std::vector<int>` 或者其他编程语言中的类似数据容器来保存生成的序列[^2]。 以下是基于上述逻辑的具体实现: --- #### C++ 实现代码 ```cpp #include <iostream> #include <vector> using namespace std; int main() { int a1, a2, n; cin >> a1 >> a2 >> n; // 输入三个参数 vector<int> sequence; // 使用向量存储序列 sequence.push_back(a1); sequence.push_back(a2); for (int i = 1; sequence.size() <= n && i < sequence.size(); ++i) { int product = sequence[i - 1] * sequence[i]; if (product >= 10) { // 如果乘积大于等于10,分解成两位数 sequence.push_back(product / 10); // 十位部分 sequence.push_back(product % 10); // 个位部分 } else { // 否则直接添加单个数 sequence.push_back(product); } if (sequence.size() > n) break; // 控制长度不超过n } // 输出前n个元素 cout << sequence[0]; for (int i = 1; i < min((int)n, (int)sequence.size()); ++i) { cout << " " << sequence[i]; } return 0; } ``` --- #### Python 实现代码 Python 的列表操作非常方便,因此可以用更简洁的方式来完成相同功能: ```python def generate_sequence(a1, a2, n): seq = [a1, a2] while len(seq) < n: product = seq[-2] * seq[-1] if product >= 10: # 将两位数分开 seq.extend([product // 10, product % 10]) else: seq.append(product) if len(seq) >= n: break return seq[:n] if __name__ == "__main__": a1, a2, n = map(int, input().split()) result = generate_sequence(a1, a2, n) print(" ".join(map(str, result))) ``` --- #### 关键点解析 1. **输入范围验证** 题目规定了 `a1`, `a2` 是小于等于9的一位正整数,而 `n` 则限定在 `[1, 10^3]` 范围内[^5]。这使得我们可以放心假设不会遇到超出预期的情况。 2. **乘积处理方式** 当两数相乘得到的结果超过9时,需要特别注意如何分离出每一位并正确插入至最终序列中。例如,当乘积为17时,应该先插入1再插入7[^4]。 3. **边界条件控制** 序列的增长速度可能较快,在某些情况下甚至会提前达到目标长度 `n`。此时应当及时终止循环以免浪费资源或引发错误行为[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值